grub-pc는 Debian jessie에서 반구성되어 있습니다.

grub-pc는 Debian jessie에서 반구성되어 있습니다.

지난 달에 새 Linux 커널을 설치하면 몇 가지 무인 업그레이드 문제가 발생했습니다.

# cat /var/log/unattended-upgrades/unattended-upgrades-dpkg.log
Log started: 2018-05-02  00:33:09
Lettura dei changelog...
/usr/bin/locale: 1: /usr/bin/locale: %!PS-Adobe-3.0: not found
/usr/bin/locale: 2: /usr/bin/locale: Syntax error: word unexpected 
(expecting ")")
Preconfigurazione dei pacchetti in corso
Selezionato il pacchetto linux-image-3.16.0-6-amd64 non precedentemente  
selezionato.
(Lettura del database... 207164 file e directory attualmente installati.)
Preparativi per estrarre .../linux-image-3.16.0-6-amd64_3.16.56- 
1_amd64.deb...
/usr/bin/locale: 1: /usr/bin/locale: %!PS-Adobe-3.0: not found
/usr/bin/locale: 2: /usr/bin/locale: Syntax error: word unexpected 
(expecting ")")
Estrazione di linux-image-3.16.0-6-amd64 (3.16.56-1)...
Preparativi per estrarre .../linux-image- 
amd64_3.16+63+deb8u2_amd64.deb...
Estrazione di linux-image-amd64 (3.16+63+deb8u2) su (3.16+63+deb8u1)...
Preparativi per estrarre .../linux-libc-dev_3.16.56-1_amd64.deb...
Estrazione di linux-libc-dev:amd64 (3.16.56-1) su (3.16.51-3+deb8u1)...
Configurazione di linux-image-3.16.0-6-amd64 (3.16.56-1)...
/usr/bin/locale: 1: /usr/bin/locale: %!PS-Adobe-3.0: not found
/usr/bin/locale: 2: /usr/bin/locale: Syntax error: word unexpected 
(expecting ")")
/etc/kernel/postinst.d/initramfs-tools:
update-initramfs: Generating /boot/initrd.img-3.16.0-6-amd64
/etc/kernel/postinst.d/zz-update-grub:
/usr/bin/gettext: 1: /usr/bin/gettext: %!PS-Adobe-3.0: not found
/usr/bin/gettext: 2: /usr/bin/gettext: Syntax error: word unexpected 
(expecting ")")
run-parts: /etc/kernel/postinst.d/zz-update-grub exited with return code 
2
Failed to process /etc/kernel/postinst.d at /var/lib/dpkg/info/linux- 
image-3.16.0-6-amd64.postinst line 634.
dpkg: errore nell'elaborare il pacchetto linux-image-3.16.0-6-amd64 (-- 
configure):
il sottoprocesso installato script di post-installation ha restituito lo 
stato di errore 1
dpkg: problemi con le dipendenze impediscono la configurazione di linux- 
image-amd64:
linux-image-amd64 dipende da linux-image-3.16.0-6-amd64; comunque:
Il pacchetto linux-image-3.16.0-6-amd64 non è ancora configurato.

dpkg: errore nell'elaborare il pacchetto linux-image-amd64 (--configure):
problemi con le dipendenze - lasciato non configurato
Configurazione di linux-libc-dev:amd64 (3.16.56-1)...
Si sono verificati degli errori nell'elaborazione:
linux-image-3.16.0-6-amd64
linux-image-amd64
Error in function: 
Log ended: 2018-05-02  00:36:46

Log started: 2018-05-05  13:26:51
Lettura dei changelog...
/usr/bin/locale: 1: /usr/bin/locale: %!PS-Adobe-3.0: not found
/usr/bin/locale: 2: /usr/bin/locale: Syntax error: word unexpected 
(expecting ")")
(Lettura del database... 210939 file e directory attualmente installati.)
Preparativi per estrarre .../libmad0_0.15.1b-8+deb8u1_amd64.deb...
Estrazione di libmad0:amd64 (0.15.1b-8+deb8u1) su (0.15.1b-8)...
Configurazione di linux-image-3.16.0-6-amd64 (3.16.56-1)...
/usr/bin/locale: 1: /usr/bin/locale: %!PS-Adobe-3.0: not found
/usr/bin/locale: 2: /usr/bin/locale: Syntax error: word unexpected 
(expecting ")")
vmlinuz(/boot/vmlinuz-3.16.0-6-amd64
) points to /boot/vmlinuz-3.16.0-6-amd64
(/boot/vmlinuz-3.16.0-6-amd64) -- doing nothing at 
/var/lib/dpkg/info/linux-image-3.16.0-6-amd64.postinst line 263.
initrd.img(/boot/initrd.img-3.16.0-6-amd64
) points to /boot/initrd.img-3.16.0-6-amd64
(/boot/initrd.img-3.16.0-6-amd64) -- doing nothing at 
/var/lib/dpkg/info/linux-image-3.16.0-6-amd64.postinst line 263.
/etc/kernel/postinst.d/initramfs-tools:
update-initramfs: Generating /boot/initrd.img-3.16.0-6-amd64
/etc/kernel/postinst.d/zz-update-grub:
/usr/bin/gettext: 1: /usr/bin/gettext: %!PS-Adobe-3.0: not found
/usr/bin/gettext: 2: /usr/bin/gettext: Syntax error: word unexpected 
(expecting ")")
 run-parts: /etc/kernel/postinst.d/zz-update-grub exited with return code 
2
Failed to process /etc/kernel/postinst.d at /var/lib/dpkg/info/linux- 
image-3.16.0-6-amd64.postinst line 634.
dpkg: errore nell'elaborare il pacchetto linux-image-3.16.0-6-amd64 (-- 
configure):
il sottoprocesso installato script di post-installation ha restituito lo 
stato di errore 1
dpkg: problemi con le dipendenze impediscono la configurazione di linux- 
image-amd64:
linux-image-amd64 dipende da linux-image-3.16.0-6-amd64; comunque:
Il pacchetto linux-image-3.16.0-6-amd64 non è ancora configurato.

dpkg: errore nell'elaborare il pacchetto linux-image-amd64 (--configure):
problemi con le dipendenze - lasciato non configurato
Configurazione di libmad0:amd64 (0.15.1b-8+deb8u1)...
Elaborazione dei trigger per libc-bin (2.19-18+deb8u10)...
Si sono verificati degli errori nell'elaborazione:
linux-image-3.16.0-6-amd64
linux-image-amd64
Error in function: 
Log ended: 2018-05-05  13:28:47

Log started: 2018-05-06  10:01:20
Lettura dei changelog...
/usr/bin/locale: 1: /usr/bin/locale: %!PS-Adobe-3.0: not found
/usr/bin/locale: 2: /usr/bin/locale: Syntax error: word unexpected 
(expecting ")")
Preconfigurazione dei pacchetti in corso
(Lettura del database... 210939 file e directory attualmente installati.)
Preparativi per estrarre .../tzdata_2018e-0+deb8u1_all.deb...
Estrazione di tzdata (2018e-0+deb8u1) su (2018d-0+deb8u1)...
Configurazione di tzdata (2018e-0+deb8u1)...
/usr/bin/locale: 1: /usr/bin/locale: %!PS-Adobe-3.0: not found
/usr/bin/locale: 2: /usr/bin/locale: Syntax error: word unexpected 
(expecting ")")

Current default time zone: 'Europe/Rome'
Local time is now:      Sun May  6 10:01:48 CEST 2018.
Universal Time is now:  Sun May  6 08:01:48 UTC 2018.
Run 'dpkg-reconfigure tzdata' if you wish to change it.

Configurazione di linux-image-3.16.0-6-amd64 (3.16.56-1)...
/usr/bin/locale: 1: /usr/bin/locale: %!PS-Adobe-3.0: not found
/usr/bin/locale: 2: /usr/bin/locale: Syntax error: word unexpected 
(expecting ")")
vmlinuz(/boot/vmlinuz-3.16.0-6-amd64
) points to /boot/vmlinuz-3.16.0-6-amd64
 (/boot/vmlinuz-3.16.0-6-amd64) -- doing nothing at 
/var/lib/dpkg/info/linux-image-3.16.0-6-amd64.postinst line 263.
initrd.img(/boot/initrd.img-3.16.0-6-amd64
) points to /boot/initrd.img-3.16.0-6-amd64
(/boot/initrd.img-3.16.0-6-amd64) -- doing nothing at 
/var/lib/dpkg/info/linux-image-3.16.0-6-amd64.postinst line 263.
/etc/kernel/postinst.d/initramfs-tools:
update-initramfs: Generating /boot/initrd.img-3.16.0-6-amd64
/etc/kernel/postinst.d/zz-update-grub:
/usr/bin/gettext: 1: /usr/bin/gettext: %!PS-Adobe-3.0: not found
/usr/bin/gettext: 2: /usr/bin/gettext: Syntax error: word unexpected 
(expecting ")")
run-parts: /etc/kernel/postinst.d/zz-update-grub exited with return code 
2
Failed to process /etc/kernel/postinst.d at /var/lib/dpkg/info/linux- 
image-3.16.0-6-amd64.postinst line 634.
dpkg: errore nell'elaborare il pacchetto linux-image-3.16.0-6-amd64 (-- 
configure):
il sottoprocesso installato script di post-installation ha restituito lo 
stato di errore 1
dpkg: problemi con le dipendenze impediscono la configurazione di linux- 
image-amd64:
linux-image-amd64 dipende da linux-image-3.16.0-6-amd64; comunque:
Il pacchetto linux-image-3.16.0-6-amd64 non è ancora configurato.

dpkg: errore nell'elaborare il pacchetto linux-image-amd64 (--configure):
problemi con le dipendenze - lasciato non configurato
Si sono verificati degli errori nell'elaborazione:
linux-image-3.16.0-6-amd64
linux-image-amd64
Error in function: 
Log ended: 2018-05-06  10:04:18

이후 이것내 문제를 해결했습니다. grub2를 지우고 다시 설치한 다음 얻은 단계를 따랐습니다.

# dpkg --configure -a 
Configurazione di grub-pc (2.02~beta2-22+deb8u1)...
/usr/bin/locale: 1: /usr/bin/locale: %!PS-Adobe-3.0: not found
/usr/bin/locale: 2: /usr/bin/locale: Syntax error: word unexpected 
(expecting ")")
/usr/bin/locale: 1: /usr/bin/locale: %!PS-Adobe-3.0: not found
/usr/bin/locale: 2: /usr/bin/locale: Syntax error: word unexpected 
(expecting ")")
Installing for i386-pc platform.
Installazione completata, nessun errore segnalato.
/usr/bin/gettext: 1: /usr/bin/gettext: %!PS-Adobe-3.0: not found
/usr/bin/gettext: 2: /usr/bin/gettext: Syntax error: word unexpected 
(expecting ")")
dpkg: errore nell'elaborare il pacchetto grub-pc (--configure):
il sottoprocesso installato script di post-installation ha restituito lo 
stato di errore 2
Si sono verificati degli errori nell'elaborazione:

제가 걱정하는 것은 충돌이 grub이 아닌 경우 grub을 다시 설치해도 작동하지 않으면 시작되지 않는다는 것입니다. chroot를 통해 문제를 해결하지 못했습니다. grub만 복구할 수 있습니다. grub-pc의 내 dpkg 상태 파일이 알려줍니다.

Package: grub-pc
Status: install ok half-configured
Priority: optional
Section: admin
Installed-Size: 514
Maintainer: GRUB Maintainers <[email protected]>
Architecture: amd64
Multi-Arch: foreign
Source: grub2
Version: 2.02~beta2-22+deb8u1
Replaces: grub, grub-common (<= 1.97~beta2-1), grub-coreboot, grub-efi-$
Depends: debconf (>= 0.5) | debconf-2.0, grub-common (= 2.02~beta2-22+d$
Conflicts: grub (<< 0.97-54), grub-coreboot, grub-efi-amd64, grub-efi-i$
Conffiles:
/etc/kernel/postinst.d/zz-update-grub 269828d3b8e5bfb266c58fb0a00abcd5
/etc/kernel/postrm.d/zz-update-grub 269828d3b8e5bfb266c58fb0a00abcd5
...

기타 정보:

# uname -r
3.16.0-6-amd64
# apt-cache policy grub-pc
grub-pc:
Installato: 2.02~beta2-22+deb8u1
Candidato:  2.02~beta2-22+deb8u1
Tabella versione:
*** 2.02~beta2-22+deb8u1 0
500 http://ftp.uk.debian.org/debian/ jessie/main amd64 Packages
500 http://security.debian.org/ jessie/updates/main amd64 Packages
100 /var/lib/dpkg/status
# ls -al /vmlinuz*
lrwxrwxrwx 1 root root 27 mag  2 00:35 /vmlinuz -> boot/vmlinuz-3.16.0-6- 
amd64
lrwxrwxrwx 1 root root 27 gen 26 13:30 /vmlinuz.old -> boot/vmlinuz- 
3.16.0-5-amd64
# ls -a /initrd.img*
/initrd.img  /initrd.img.old
# ls -al /boot
totale 62164
drwxr-xr-x  3 root root     4096 mag 11 11:35 .
drwxr-xr-x 22 root root     4096 mag 11 14:20 ..
-rw-r--r--  1 root root   157756 dic 14 22:27 config-3.16.0-4-amd64
-rw-r--r--  1 root root   157786 gen  9 12:42 config-3.16.0-5-amd64
-rw-r--r--  1 root root   157842 mag  8 19:36 config-3.16.0-6-amd64
drwxr-xr-x  5 root root     4096 mag 12 10:47 grub
-rw-r--r--  1 root root 15164265 mag  7 11:27 initrd.img-3.16.0-4-amd64
-rw-r--r--  1 root root 15164783 gen 26 13:31 initrd.img-3.16.0-5-amd64
-rw-r--r--  1 root root 15310597 mag 11 11:35 initrd.img-3.16.0-6-amd64
-rw-r--r--  1 root root  2684316 dic 14 22:27 System.map-3.16.0-4-amd64
-rw-r--r--  1 root root  2683305 gen  9 12:42 System.map-3.16.0-5-amd64
-rw-r--r--  1 root root  2683087 mag  8 19:36 System.map-3.16.0-6-amd64
-rw-r--r--  1 root root  3137712 dic 14 22:25 vmlinuz-3.16.0-4-amd64
-rw-r--r--  1 root root  3139776 gen  9 12:40 vmlinuz-3.16.0-5-amd64
-rw-r--r--  1 root root  3170464 mag  8 19:34 vmlinuz-3.16.0-6-amd64
# df -h
File system     Dim. Usati Dispon. Uso% Montato su
/dev/sda1        46G   21G     24G  47% /
udev             10M     0     10M   0% /dev
tmpfs           401M  6,0M    395M   2% /run
tmpfs          1001M   28M    973M   3% /dev/shm
tmpfs           5,0M  4,0K    5,0M   1% /run/lock
tmpfs          1001M     0   1001M   0% /sys/fs/cgroup
/dev/sda2       180G   34G    137G  20% /home
tmpfs           201M   12K    201M   1% /run/user/1000
/dev/sdb1       3,8G  3,8G       0 100% /media/stefano/Debian 8.0.0 amd64 
1
# df -i
File system       Inode IUsati  ILiberi IUso% Montato su
/dev/sda1       3055616 448579  2607037   15% /
udev             253925    424   253501    1% /dev
tmpfs            256068    604   255464    1% /run
tmpfs            256068    129   255939    1% /dev/shm
tmpfs            256068      4   256064    1% /run/lock
tmpfs            256068     13   256055    1% /sys/fs/cgroup
/dev/sda2      11968512 320153 11648359    3% /home
tmpfs            256068     18   256050    1% /run/user/1000
/dev/sdb1             0      0        0     - /media/stefano/Debian 8.0.0 
amd64 1

편집 1

내 로케일 파일

# locale
/usr/bin/locale: riga 1: fg: nessun controllo dei job
/usr/bin/locale: riga 2: errore di sintassi vicino al token non atteso 
"ImageMagick"
/usr/bin/locale: riga 2: `%%Creator: (ImageMagick)'
# cat /etc/default/locale 
#  File generated by update-locale
LANG="it_IT.UTF-8"
# gettext -d coreutils -s "write error"/usr/bin/gettext: riga 1: fg: 
nessun controllo dei job
/usr/bin/gettext: riga 2: errore di sintassi vicino al token non atteso 
"ImageMagick"
/usr/bin/gettext: riga 2: `%%Creator: (ImageMagick)'

답변1

/usr/bin/locale귀하의 및 명령이 /usr/bin/gettextPostScript 문서 헤더와 같은 것을 발견하여 일부 오류를 일으키는 것으로 보입니다. 이러한 오류는 문제의 근본 원인일 수도 있고 아닐 수도 있지만 확실히 다른 시스템 기능을 방해할 수 있습니다.

뭔가 이상한 게 있는 게 아닐까요 /etc/default/locale? sh-style 변수 정의 및/또는 주석 만 포함해야 합니다 .

달리면 어떻게 되나요 locale? 오류 메시지 없이 현재 로케일이 표시되어야 합니다.

아니면 도망치면 어떡하지 gettext -d coreutils -s "write error"? 현재 로케일에 따라 "쓰기 오류" 메시지의 번역된 버전이 출력되어야 합니다.

아니면 PostScript 파일이 메시지 카탈로그 디렉토리에 들어 갔을까요? 그러면 다음 명령으로 찾을 수 있습니다.

find /usr/share/locale -type f -exec file {} \+ |grep -E -v 'GNU (gettext )?message catalog'

이 명령은 메시지 카탈로그 파일이 아닌 /usr/share/locale 아래의 모든 파일을 식별해야 합니다. 명령 출력도 번역된 경우 검색 문자열이 출력에서 ​​메시지 카탈로그 파일을 올바르게 제외하도록 표준 미국 영어로 메시지를 가져오려면 file이 명령 앞에 접두사를 붙여야 할 수 있습니다 .LC_ALL=C


귀하의 /usr/bin/locale및 또한 /usr/bin/gettextImageMagick에서 만든 PostScript 파일로 대체된 것으로 나타났습니다. 이것은 파일 시스템이 손상될 가능성이 있거나 루트로 실행할 때 ImageMagick 명령을 사용할 때 "죄송합니다"라고 들리는 것 같습니다.

/usr/bin/locale합계를 수정하려면 /usr/bin/gettext다음 명령어를 실행하세요.

apt-get install --reinstall libc-bin gettext-base

이렇게 하면 해당 파일에 종속된 패키지를 먼저 제거하지 않고 모든 파일을 다시 설치 libc-bin하고 패키지합니다. gettext-base이렇게 하면 원래 오류 메시지 중 적어도 일부가 수정됩니다. 그런 다음 dpkg --configure -a다시 실행하여 이것이 전체 문제의 실제 근본 원인인지 또는 수정해야 할 문제가 더 있는지 확인할 수 있습니다 .

파일 시스템이 손상될 가능성이 있으므로 출력을 확인해야 한다고 생각합니다 dmesg | less. 디스크 오류처럼 보이는 것이 있습니까?

이는 smartctl -a /dev/<your system disk device>디스크가 내부 SMART 상태 점검을 통과했음을 의미합니까? 이 명령은 많은 정보를 출력하지만 중요한 부분은 다음과 같습니다.

=== START OF READ SMART DATA SECTION ===
SMART overall-health self-assessment test result: PASSED

"PASSED"라고 표시되지 않으면 디스크에 결함이 있는 것이므로 교체해야 합니다.

디스크가 정상이라고 생각 되더라도 smartctl전체 백업과 전체 파일 시스템 검사를 수행하는 것이 좋습니다. 파일 시스템 검사에 도움이 필요하면 새로운 질문을 해주세요.

관련 정보