Şu anda bu sorunla ilgilenmiyoruz.
Genellikle aygıtı engellemek için okuma veya yazı ile ilgili bazı sorunlardan sonra, çekirdek BÜTÜN CİHAZ için bayrağı salt okunur olarak değiştirmeye karar verir. Bundan sonra, bu cihazda bulunan herhangi bir bölüm / dosya sistemine yapılan yazılar, cihaz durumu ile birlikte salt okunur olarak değiştirilmesine neden olur, çünkü herhangi bir yazı imkansızdır.
Dmesg örneği, bu defrag konukların cihaz resmini çektiğinde VirtualBox kullanan windows8'deki konuk linux simülasyonudur:
[11903.002030] ata3.00: exception Emask 0x0 SAct 0x1 SErr 0x0 action 0x6 frozen
[11903.003179] ata3.00: failed command: READ FPDMA QUEUED
[11903.003364] ata3.00: cmd 60/08:00:a8:77:57/00:00:00:00:00/40 tag 0 ncq 4096 in
[11903.003385] res 40/00:01:00:00:00/00:00:00:00:00/00 Emask 0x4 (timeout)
[11903.004074] ata3.00: status: { DRDY }
[11903.004248] ata3: hard resetting link
[11903.325703] ata3: SATA link up 3.0 Gbps (SStatus 123 SControl 300)
[11903.327097] ata3.00: configured for UDMA/133
[11903.328025] ata3.00: device reported invalid CHS sector 0
[11903.329664] ata3: EH complete
[11941.000472] ata3.00: exception Emask 0x0 SAct 0x1 SErr 0x0 action 0x6 frozen
[11941.000769] ata3.00: failed command: READ FPDMA QUEUED
[11941.000952] ata3.00: cmd 60/08:00:c8:77:57/00:00:00:00:00/40 tag 0 ncq 4096 in
[11941.000961] res 40/00:01:00:00:00/00:00:00:00:00/00 Emask 0x4 (timeout)
[11941.001353] ata3.00: status: { DRDY }
[11941.001504] ata3: hard resetting link
[11941.320297] ata3: SATA link up 3.0 Gbps (SStatus 123 SControl 300)
[11941.321252] ata3.00: configured for UDMA/133
[11941.321379] ata3.00: device reported invalid CHS sector 0
[11941.321553] ata3: EH complete
[11980.001746] ata3.00: exception Emask 0x0 SAct 0x11fff SErr 0x0 action 0x6 frozen
[11980.002070] ata3.00: failed command: WRITE FPDMA QUEUED
[11980.002255] ata3.00: cmd 61/18:00:28:23:59/00:00:00:00:00/40 tag 0 ncq 12288 out
[11980.002265] res 40/00:01:00:00:00/00:00:00:00:00/00 Emask 0x4 (timeout)
-------------------
There are many other errors, like "lost write page", "Journal has aborted", "Buffer I/O error", "hard resetting link" and many others.
Bundan sonra, yeniden neden:
mount / -o remount,rw
mount: cannot remount block device /dev/sda1 read-write, is write-protected
çünkü sda1 rootfs'i tutan WHOLE cihazı sda READONLY.
Benim durumumda bu, aşağıdaki durumlarda gerçekleşir:
- HDD gerçekten hasarlı. İade yazma sorunları HDD durumuna bağlıdır
- Ana makine aşırı yüklendi, ardından linux konuk sanal HDD yazıları zaman aşımına uğradı
- FC kablosu veya SAN cihazı (Fiber Kanal üzerinden dizi diskleri) aşırı yüklenmiş
- FC veya FCoE üzerinden anlık bağlantı kesildi. Belki kayıp / zaman aşımı olan FC paketi
Bu durumlarda cihaz gerçekten okuma-yazmadır, ancak linux çekirdeği bu cihazı dahili olarak salt okunur olarak işaretler ve salt okunur olarak kullanılır. Bu, hasarın önlenmesi için oluşturulmuş çekirdek işlevselliğidir, ancak yalnızca 1. noktada kullanılabilir.
Soru şu ki. Çekirdeğe manuel olarak nasıl söylenir, hdd blok cihazı normal çalışır?
Bunun üzerine, çekirdek hizmeti aygıtı 'CD-ROM' gibi salt okunur olarak sunulur ve mount / remount -o read-write, fsck ve diğerleri de dahil olmak üzere başka hiçbir komutun düzgün çalışma şansı yoktur.
Kullanılamaz yanıtlar, gerçekten yardım etmek isteyen ancak sorun niteliğini anlamayan kişilerden spam olarak nitelendirilmiş:
- Yeniden yazmayı okuma-yazma olarak deneyin (imkansız, cihaz RO)
- fsck this (ne için? cihaz RO, hiçbir onarım mümkün değildir)
- 'Bilmiyorum' (önce mantıklı ama kullanılamaz)
- 'Cihazınızı değiştirin' * (genellikle sorun başka bir şeydir)
Yukarıda soru için herhangi bir formül var mı? Salt okunur durumdan okuma-yazma durumuna geri döndüren yazılabilir blok aygıtı için bayrak değiştirilsin mi? Şu anda kimse nasıl olduğunu bilmiyor gibi görünüyor.
Bazı geçici çözümlerdir, ancak genellikle yarı yarıya veya kullanılamaz:
- Modül kaldır, belirtilen hdd veya depolama dizisine erişimi destekler. Ne yazık ki genellikle hasarlı aygıt rootf'leri tutar veya sürücü hem hasarlı aygıtı hem de rootf'leri tutan aygıtı tutar
- Cihaza FC erişimini kaldırın ve buna tekrar katılın (fctools), her zaman mümkün değil, her zaman işe yaramıyor.
- BÜTÜN makineyi yeniden başlatın. Genellikle sadece bu her zaman mümkündür ve hep zorlanırız.
1. ve 2. noktalarda, çekirdeğe cihazın bağlantısını tamamen kesip tekrar bağladığımızı söylüyoruz. Çekirdek bunu doğru şekilde çalışan yeni bir aygıta katmak olarak kabul etti. Bunu USB cihazı ve anlık kaldırma gücünü kullanarak simüle edebiliriz. 3. nokta son şanstır ve genellikle işe yarar. Ama neden hepsini yeniden başlatmalıyız? Maalesef her noktada tüm dergi güncellemelerini ve kirli arabellekleri kaybettik.
Dikkat edin, aynı durumlarda Windows (masaüstü ve sunucu) ile hiçbir sorunum yok.