Я могу предположить, что после удаления файлов в /var/lib/apt/... вы сделали новое apt-get update
?
Вы также можете попробовать apt-get check -m -f
и проверить /etc/apt/sources.list
на валидность, посетив адрес каждого репозитория в браузере, это должно дать список файлов.
Это подойдет?
while ! dd if=/dev/sr2 bs=2048 count=1 of=/dev/null 2>/dev/null; do sleep 1; done
Замените /dev/sr2
на фактическое устройство CD/DVD.
Вы можете сделать его более надежным, проверив наличие ошибок, отличных от No medium found
; не проверено, так как у меня нет под рукой сломанного DVD:
dev=/dev/sr2
while :; do
err=$(dd if=$dev of=/dev/null bs=2048 status=none count=1 2>&1)
case $err in
"dd: failed to open '$dev': No medium found")
sleep 1 ;;
'')
# successfully opened
break ;;
*)
# unexpected error
# play some SOUND in the speakers
# and wait for user input to continue
read wtf ;;
esac
done
Обновление:
На дисках, поддерживающих эту функцию, Linux автоматически закроет лоток при попытке открыть устройство. Хотя это, вероятно, можно было бы отключить с помощью ioctl(CDROM_CLEAR_OPTIONS, CDO_AUTO_CLOSE)
, я не смог найти утилиту командной строки, реализующую это. Так как это вынуждает использовать C
, лучше использовать C
для всего этого.
Итак, вот небольшое приложение, которое может проверять и опрашивать состояние привода CD/DVD.
При вызове с одним аргументом:
cdstatus /dev/sr1
будет напечатан статус/dev/sr1
:одного из no_disc
, tray_open
, drive_not_ready
или disc_ok
.
При вызове с двумя аргументами:
cdstatus /dev/sr1 1.3
он будет опрашивать /dev/sr1
каждые 1,3 секунды, пока его состояние не станет disk_ok
.
Его можно легко собрать с помощью cc -Os -Wall cdstatus.c -s -o cdstatus
при условии, что установлены пакеты gcc и libc6 -dev.
cdstatus.c
#include <sys/ioctl.h>
#include <linux/cdrom.h>
#include <fcntl.h>
#include <err.h>
#include <stdio.h>
#include <stdlib.h>
#include <poll.h>
int main(int argc, char **argv){
int fd, s; int pt = -1;
if(argc < 2)
errx(1, "usage: %s /dev/srX [poll_secs] [verbose]", argv[0]);
if((fd = open(argv[1], O_RDONLY|O_NONBLOCK)) == -1)
err(1, "open %s", argv[1]);
if(argc > 2 && ((pt = strtod(argv[2], 0) * 1000) < 1 || pt > 3600000))
errx(1, "bad timeout '%s'", argv[2]);
redo:
switch(s = ioctl(fd, CDROM_DRIVE_STATUS, 0)){
case -1: err(1, "ioctl(CDROM_DRIVE_STATUS)");
case CDS_NO_INFO: errx(1, "ioctl(CDROM_DRIVE_STATUS) not implemented");
}
if(pt < 0 || argc > 3)
switch(s){
case CDS_NO_DISC: printf("no_disc\n"); break;
case CDS_TRAY_OPEN: printf("tray_open\n"); break;
case CDS_DRIVE_NOT_READY: printf("drive_not_ready\n"); break;
case CDS_DISC_OK: printf("disc_ok\n"); break;
default: printf("status=%d\n", s); break;
}
if(pt > 0 && s != CDS_DISC_OK){
if(poll(0, 0, pt) < 0) err(1, "poll");
goto redo;
}
return s != CDS_DISC_OK;
}
В конце концов, сообщение в этой смутно -связанной ветке на linuxquestions предложило использоватьwodim -atip
(среди прочего ), что, как оказалось, отлично работает для блокировки до тех пор, пока носитель не будет доступен..
#!/bin/bash
set -e
DRIVE=${DRIVE:-"sr0"}
DESTROOT=${DESTROOT:-"/mnt/newshare"}
DRV_FULLNAME="$(</sys/class/block/$DRIVE/device/vendor) $(</sys/class/block/$DRIVE/device/model)"
[ -d /tmp/$DRIVE ] || mkdir /tmp/$DRIVE
while true; do
eject /dev/$DRIVE
echo "$DRV_FULLNAME is ready."
read -p "Enter next disc code: " DISC
if [ -z "$DISC" ]; then
echo "No disc code = we're done, exiting"
break
fi
eject -t /dev/$DRIVE || {
read -n1 -r -p "Unable to load tray. Push it in and hit Any key..."
echo
}
wodim dev=/dev/$DRIVE -atip > /dev/null || {
echo "Medium not detected."
break
}
mount /dev/$DRIVE /tmp/$DRIVE -o ro || {
echo "Couldn't mount medium."
break
}
cp -ia /tmp/$DRIVE/. $DESTROOT/$DISC/ || {
echo "COPY FAILED. Put it on the read-error pile and continue with next one."
}
done