Arch GRUB ขอ /run/lvm/lvmetad.socket บนดิสก์ที่ไม่ใช่ lvm


18

ฉันใช้งานสคริปต์นี้ตามขั้นตอนการตั้งค่าArchWiki มันล้มเหลวในขั้นตอนการกำหนดค่า GRUB

ฉันใช้ archlinux-2013.12.01-dual.iso ภายใน VMware Player ที่มี RAM 1 GB sdaคือ 810 MB ฉันได้ติดตั้ง CIFS ที่ใช้ร่วมกันบนเครื่องโฮสต์แล้ว

# DEV=sda
# PART=sda1
# echo "1,,L,*" | sfdisk /dev/$DEV
# mkfs.ext3 /dev/$PART
# mount /dev/$PART /mnt
# pacstrap -i /mnt base 
# genfstab -U -p /mnt >> /mnt/etc/fstab
# arch-chroot /mnt 
# pacman -S grub
# pacman -S os-prober
# grub-mkconfig -o /boot/grub/grub.cfg

ฉันเข้าใจ:

Generating grub configuration file ...
Found linux image: /boot/vmlinuz-linux
Found initrd image: /boot/initramfs-linux.img
  /run/lvm/lvmetad.socket: connect failed: No such file or directory
  WARNING: Failed to connect to lvmetad: No such file or directory. Falling back to internal scanning.
  /run/lvm/lvmetad.socket: connect failed: No such file or directory
  /run/lvm/lvmetad.socket: connect failed: No such file or directory
  No volume groups found
error: out of memory.
error: syntax error.
error: Incorrect command.
error: syntax error.
Syntax error at line 164
Syntax errors are detected in generated GRUB config file.
Ensure that there are no errors in /etc/default/grub
and /etc/grub.d/* files or please file a bug report with
/boot/grub/grub.cfg.new file attached.done

ฉันไม่ได้ติดตั้งพาร์ทิชัน / ไดรฟ์ LVM

# fdisk -l /dev/sda

Disk /dev/sda: 819 MiB, 858783744 bytes, 1677312 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disklabel type: dos
Disk identifier: 0x000d5a2a

Device    Boot Start       End Blocks  Id System
/dev/sda1       2048   1677311 837632  83 Linux


# lsblk 

NAME              MAJ:MIN RM   SIZE RO TYPE MOUNTPOINT
fd0                 2:0    1     4K  0 disk 
sda                 8:0    0   819M  0 disk 
└─sda1              8:1    0   818M  0 part /mnt
sr0                11:0    1   522M  0 rom  /run/archiso/bootmnt
sr1                11:1    1    10M  0 rom  
loop0               7:0    0 224.2M  1 loop /run/archiso/sfs/root-image
loop1               7:1    0   1.4G  1 loop 
└─arch_root-image 254:0    0   1.4G  0 dm   /
loop2               7:2    0   1.4G  0 loop 
└─arch_root-image 254:0    0   1.4G  0 dm   /

/boot/grub/grub.cfg.new คือ:

#
# DO NOT EDIT THIS FILE
#
# It is automatically generated by grub-mkconfig using templates
# from /etc/grub.d and settings from /etc/default/grub
#

### BEGIN /etc/grub.d/00_header ###
insmod part_gpt
insmod part_msdos
if [ -s $prefix/grubenv ]; then
  load_env
fi
if [ "${next_entry}" ] ; then
   set default="${next_entry}"
   set next_entry=
   save_env next_entry
   set boot_once=true
else
   set default="0"
fi

if [ x"${feature_menuentry_id}" = xy ]; then
  menuentry_id_option="--id"
else
  menuentry_id_option=""
fi

export menuentry_id_option

if [ "${prev_saved_entry}" ]; then
  set saved_entry="${prev_saved_entry}"
  save_env saved_entry
  set prev_saved_entry=
  save_env prev_saved_entry
  set boot_once=true
fi

function savedefault {
  if [ -z "${boot_once}" ]; then
    saved_entry="${chosen}"
    save_env saved_entry
  fi
}

function load_video {
  if [ x$feature_all_video_module = xy ]; then
    insmod all_video
  else
    insmod efi_gop
    insmod efi_uga
    insmod ieee1275_fb
    insmod vbe
    insmod vga
    insmod video_bochs
    insmod video_cirrus
  fi
}

if [ x$feature_default_font_path = xy ] ; then
   font=unicode
else
insmod part_msdos 
insmod ext2
set root='hd0,msdos1'
if [ x$feature_platform_search_hint = xy ]; then
  search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1  9d1d349e-d061-4e0f-9312-be19ca2dcb74
else
  search --no-floppy --fs-uuid --set=root 9d1d349e-d061-4e0f-9312-be19ca2dcb74
fi
    font="/usr/share/grub/unicode.pf2"
fi

if loadfont $font ; then
  set gfxmode=auto
  load_video
  insmod gfxterm
  set locale_dir=$prefix/locale
  set lang=en_US
  insmod gettext
fi
terminal_input console
terminal_output gfxterm
set timeout=5
### END /etc/grub.d/00_header ###

### BEGIN /etc/grub.d/10_linux ###
menuentry 'Arch Linux, with Linux core repo kernel' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-core repo kernel-true-9d1d349e-d061-4e0f-9312-be19ca2dcb74' {
    load_video
    set gfxpayload=keep
    insmod gzio
    insmod part_msdos 
    insmod ext2
    set root='hd0,msdos1'
    if [ x$feature_platform_search_hint = xy ]; then
      search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1  9d1d349e-d061-4e0f-9312-be19ca2dcb74
    else
      search --no-floppy --fs-uuid --set=root 9d1d349e-d061-4e0f-9312-be19ca2dcb74
    fi
    echo    'Loading Linux core repo kernel ...'
    linux   /boot/vmlinuz-linux root=UUID=9d1d349e-d061-4e0f-9312-be19ca2dcb74 rw  quiet
    echo    'Loading initial ramdisk ...'
    initrd  /boot/initramfs-linux.img
}
menuentry 'Arch Linux, with Linux core repo kernel (Fallback initramfs)' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-core repo kernel-fallback-9d1d349e-d061-4e0f-9312-be19ca2dcb74' {
    load_video
    set gfxpayload=keep
    insmod gzio
    insmod part_msdos 
    insmod ext2
    set root='hd0,msdos1'
    if [ x$feature_platform_search_hint = xy ]; then
      search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1  9d1d349e-d061-4e0f-9312-be19ca2dcb74
    else
      search --no-floppy --fs-uuid --set=root 9d1d349e-d061-4e0f-9312-be19ca2dcb74
    fi
    echo    'Loading Linux core repo kernel ...'
    linux   /boot/vmlinuz-linux root=UUID=9d1d349e-d061-4e0f-9312-be19ca2dcb74 rw  quiet
    echo    'Loading initial ramdisk ...'
    initrd  /boot/initramfs-linux-fallback.img
}
menuentry 'Arch Linux' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-simple-9d1d349e-d061-4e0f-9312-be19ca2dcb74' {
    load_video
    set gfxpayload=keep
    insmod gzio
    insmod part_msdos 
    insmod ext2
    set root='hd0,msdos1'
    if [ x$feature_platform_search_hint = xy ]; then
      search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1  9d1d349e-d061-4e0f-9312-be19ca2dcb74
    else
      search --no-floppy --fs-uuid --set=root 9d1d349e-d061-4e0f-9312-be19ca2dcb74
    fi
    echo    'Loading Linux core repo kernel ...'
    linux   /boot/vmlinuz-linux root=UUID=9d1d349e-d061-4e0f-9312-be19ca2dcb74 rw  quiet
    echo    'Loading initial ramdisk ...'
    initrd  /boot/initramfs-linux-fallback.img
}
submenu 'Advanced options for Arch Linux' $menuentry_id_option 'gnulinux-advanced-9d1d349e-d061-4e0f-9312-be19ca2dcb74' {

### END /etc/grub.d/10_linux ###

### BEGIN /etc/grub.d/20_linux_xen ###
### END /etc/grub.d/20_linux_xen ###

### BEGIN /etc/grub.d/30_os-prober ###
### END /etc/grub.d/30_os-prober ###

### BEGIN /etc/grub.d/40_custom ###
# This file provides an easy way to add custom menu entries.  Simply type the
# menu entries you want to add after this comment.  Be careful not to change
# the 'exec tail' line above.
### END /etc/grub.d/40_custom ###

### BEGIN /etc/grub.d/41_custom ###
if [ -f  ${config_directory}/custom.cfg ]; then
  source ${config_directory}/custom.cfg
elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
  source $prefix/custom.cfg;
fi
### END /etc/grub.d/41_custom ###

### BEGIN /etc/grub.d/60_memtest86+ ###
### END /etc/grub.d/60_memtest86+ ###

ดูเหมือนข้อผิดพลาด - "โปรดยื่นรายงานข้อผิดพลาดพร้อมไฟล์ /boot/grub/grub.cfg.new ที่แนบมา"
Panther

1
คุณกำลังใช้งาน grsec อยู่หรือไม่ คุณมีหน่วยความจำเพียงพอหรือไม่
เดซี่

@ warl0ck: grsecurity หรือไม่ ฉันใช้มาตรฐานarchlinux-2013.12.01-dual.isoภายใน VMware Player ด้วย 384 MB ram sdaคือ 810 MB ใน ISO รองsr1ฉันเรียกใช้สคริปต์เพื่อติดตั้ง Vim และติดตั้ง CIFS ที่ใช้ร่วมกันบนเครื่องโฮสต์
อันโตนิโอ

คำตอบ:


22

ฉันวิ่งข้ามปัญหาเดียวกันตอนนี้และพบวิธีแก้ปัญหาอื่น โดยทั่วไปจะเกี่ยวข้องกับการทำให้โฮสต์/runไดเรกทอรีพร้อมใช้งานสำหรับแขก

ก่อนอื่นเราติดตั้ง/runที่แขกสามารถเข้าถึงได้ ฉันจะสมมติว่าพาร์ติชันการติดตั้งของคุณติดตั้งอยู่ที่/mnt

mkdir /mnt/hostrun
mount --bind /run /mnt/hostrun

จากนั้นเรา chroot เป็นแขกและติดโฮสต์ของเรา/run/lvmในแขก/run

arch-chroot /mnt /bin/bash
mkdir /run/lvm
mount --bind /hostrun/lvm /run/lvm

จากนั้นคุณสามารถเรียกใช้grub-mkconfigและgrub-installไม่มีข้อผิดพลาด LVM สิ่งนี้ยังทำให้คำสั่งทำงานหากคุณติดตั้งด้วย LVM สำหรับสิ่งที่คุ้มค่า

เมื่อเสร็จแล้วอย่าลืมumount /run/lvmก่อนที่จะexitchroot


6

หลังจากการวิจัยที่ถูกกระตุ้นโดย @guest ฉันพบว่ามีข้อผิดพลาดที่เห็นได้ชัดในgrub-mkconfigสคริปต์ตัวช่วย/etc/grub.d/10_linuxซึ่งทำให้การเริ่มต้นรายการทางเลือก GRUB ไม่เข้ากันได้กับระบบเมนูย่อยของ GRUB เนื่องจากการใช้ตัวเลือกเริ่มต้นสำรองนั้นมีความเฉพาะเจาะจงกับ Arch และอนุพันธ์จึงไม่ได้รับการสนับสนุนจากอัปสตรี grub-mkconfigม การแก้ไขที่ชัดเจนยังอยู่ในระหว่างดำเนินการ ดูรายละเอียดเพิ่มเติมเกี่ยวกับ bugs.archlinux.org

วิธีแก้ปัญหาชั่วคราวคือปิดใช้งานเมนูย่อยในด้วงโดยต่อท้าย:

GRUB_DISABLE_SUBMENU=y

/etc/default/grubไปยัง

grub-mkconfigแต่น่าเสียดายที่โดยการปิดเมนูย่อยที่ผมหลีกเลี่ยงข้อผิดพลาดเพียงครั้งที่สองเกิดขึ้นโดย

ดังนั้นด้วย:

# arch-chroot /mnt grub-mkconfig -o /boot/grub/grub.cfg

ฉันยังรับ:

Generating grub configuration file ...
Found linux image: /boot/vmlinuz-linux
Found initrd image: /boot/initramfs-linux.img
  /run/lvm/lvmetad.socket: connect failed: No such file or directory
  WARNING: Failed to connect to lvmetad: No such file or directory. Falling back to internal scanning.
  /run/lvm/lvmetad.socket: connect failed: No such file or directory
  /run/lvm/lvmetad.socket: connect failed: No such file or directory
  No volume groups found

ฉันไม่เคยติดตั้งพาร์ทิชัน / ไดรฟ์ LVM และอย่างที่คุณเห็นได้จากคำถามของฉันฉันแบ่งพาร์ติชันและฟอร์แมตระบบ อย่างไรก็ตามหลังจากแก้ไขข้อผิดพลาดด้วงฉันลองทั้งสอง:

systemctl start lvmetad

และ

systemctl start lvmetad.service

และฉันก็วิ่งไปpacstrapอีกครั้งโดยไม่ประสบความสำเร็จ

ข้อผิดพลาดในปัจจุบันไม่สำคัญเช่น

arch-chroot /mnt grub-install --target=i386-pc --recheck /dev/$DEV

$DEVเป็นไปอย่างราบรื่นและฉันสามารถบูตจาก


การตอบคำถามของคุณเองนั้นไม่จำเป็นต้องทำในโพสต์ของวิกิชุมชน
terdon

1
ฉันไม่สามารถเข้าใจได้ว่านี่เป็นคำตอบหรือคำถามอื่น
Michael Mrozek

@MichaelMrozek: มันเป็นคำตอบบางส่วน / คำตอบสำหรับคำถาม: ข้อผิดพลาดที่สองได้รับการแก้ไข; ที่สะดุดตาที่สุดข้อผิดพลาดแรกในขณะนี้แสดงให้เห็นว่าไม่สำคัญสำหรับการติดตั้ง Arch ฉันยังคงตรวจสอบและหวังว่าหลังจะได้รับการแก้ไขด้วย
อันโตนิโอ

3

ผมมีปัญหาเหมือนกัน แต่ผมพบว่าวิธีการแก้ปัญหาที่ทำงานสำหรับฉัน: os-proberเพียงแค่ลบ


1
สำหรับอินสแตนซ์ที่เรียบง่ายของฉันมันก็โอเค แต่ในอินสแตนซ์ที่คุณมีระบบปฏิบัติการอื่นและคุณต้องการตั้งค่าเมนูหลายเมนูด้วยตนเองหรือไม่?
อันโตนิโอ

1
อย่าลบ os-prober เพียงแค่ปิดการใช้งานบิตที่เรียกใช้งานได้chmod -x /etc/grub.d/30_os-proberและควรลบคำเตือน
NuclearPeon

นี่ไม่ใช่วิธีแก้ปัญหาจริงๆ - os-prober นั้นเป็นส่วนสำคัญของด้วงนอกจากคุณจะใช้เพียงระบบเดียว
daboross


0

สำหรับข้อความแสดงข้อผิดพลาดครั้งแรก grub ไม่สามารถเชื่อมต่อกับ LVM metadata daemon ได้ให้ลองเรียกใช้คำสั่งนี้ในฐานะ root (ซึ่งจะเริ่มขึ้น):

systemctl start lvmetad

และอันที่สองลองเพิ่ม RAM ที่จัดสรรให้กับ VM ของคุณบางที512Mและเรียกใช้ด้วงอีกครั้ง


ฉันตั้งค่า RAM สูงสุด 1 GB systemctl start lvmetad(เรียกใช้นอก chroot) ไม่ให้ข้อความแสดงข้อผิดพลาด แต่การเรียกใช้grub-mkconfigภายในใหม่arch-chrootให้ข้อผิดพลาดเดียวกันทั้งหมด (รวมถึงข้อผิดพลาด mem)
อันโตนิโอ
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.