错误完整提示:
starting version 230
MT_ARCH: clean, 11/2623488 files, 392540/10490412 blocks
ERROR:Root device mounted successfully, but /sbin/init does not exist.
Bailing out, you are on your own. Good luck.
sh:can't access tty; job control turned off
[rootfs ]#
1、/usr 没有单独分区。
2、/boot等所有根目录文件在一个分区内。
3、查找mkinitcpio.conf文件里: HOOKS="base udev autodetect modconf block filesystems keyboard fsck"
4、还会出现随机现象:有时系统可进入和不可进入现象,系统进入后一切完好。
不知从何下手,折腾,再折腾,还是无果,=(
最近编辑记录 schux (2016-07-06 12:34:42)
离线
安装了 systemd-sysvcompat 吗?
安装完、重启前,执行过 mkinitcpio -p linux 了吗?
使用的是什么方式启动的?BIOS / UEFI?grub 还是其它的引导器?
离线
1.第一个问:已经安装systemd-sysvcompat。
2.第二个问:已经执行过。
3.第三个问:BIOS -> grub ... ,可以确定grub.cfg(安装引导时自动生成文件并且检查无误)和fstab关键文件是正确的。
离线
在出错的时候 ls /new_root 看看,那里是你的 / 分区的内容吗?你是不是把 / 分区弄错了呢?
离线
在出错的时候 ls /new_root 看看,那里是你的 / 分区的内容吗?你是不是把 / 分区弄错了呢?
出错时就跳出
...(之前说的内容)和终端提示符
[rootfs ]#
输入命令:ls /new_root, 显示如下内容
grub initramfs-linux.img vmlinuz-linux initramfs-linux-fallback.img lost+found
肯定不是正常终端提示符和内容。
按热启动键,暴力点重新启动不论何种状态基本就跳到这个错误的地方。
最近编辑记录 schux (2016-07-06 19:04:09)
离线
输入命令:ls /new_root, 显示如下内容
grub initramfs-linux.img vmlinuz-linux initramfs-linux-fallback.img lost+found
你这是 /boot 分区被当作 / 分区了啊……改内核命令行 / grub.cfg 吧。
离线
schux 说:输入命令:ls /new_root, 显示如下内容
grub initramfs-linux.img vmlinuz-linux initramfs-linux-fallback.img lost+found你这是 /boot 分区被当作 / 分区了啊……改内核命令行 / grub.cfg 吧。
可我没单独把boot分区,直接修改grub.cfg?文件里头就看到一个安装系统的分区。而且有的时候可以进入系统,没有任何错误提示。
最近编辑记录 schux (2016-07-06 21:59:03)
离线
那你这是哪里?你内核的 root 参数是怎么写的?或者用 mount 命令看看挂载的是哪个设备。
离线
那你这是哪里?你内核的 root 参数是怎么写的?或者用 mount 命令看看挂载的是哪个设备。
出错的情况是这样的,在出错的地方“ [rootfs ]# ”输入命令行,每次跳出了错误是随机的,就是看到东西不一样,比如用ls查看内容都不一样。系统进入lxde桌面调用桌面的系统开关机重启等键,一切正常。如果退出到终端直接reboot,或者systemctl reboot,就要看运气,不过出错机率非常大。
附上grub.cfg原始配置文件。
#/boot/grub/grub.cfg
#
# 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,msdos2'
if [ x$feature_platform_search_hint = xy ]; then
search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos2 --hint-efi=hd0,msdos2 --hint-baremetal=ahci0,msdos2 6368746f-2074-616b-6f65-207575696400
else
search --no-floppy --fs-uuid --set=root 6368746f-2074-616b-6f65-207575696400
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
if [ x$feature_timeout_style = xy ] ; then
set timeout_style=menu
set timeout=5
# Fallback normal timeout code in case the timeout_style feature is
# unavailable.
else
set timeout=5
fi
### END /etc/grub.d/00_header ###
### BEGIN /etc/grub.d/10_linux ###
menuentry 'Arch Linux, with Linux linux' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-linux-advanced-6368746f-2074-616b-6f65-207575696400' {
load_video
set gfxpayload=keep
insmod gzio
insmod part_msdos
insmod ext2
set root='hd0,msdos2'
if [ x$feature_platform_search_hint = xy ]; then
search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos2 --hint-efi=hd0,msdos2 --hint-baremetal=ahci0,msdos2 6368746f-2074-616b-6f65-207575696400
else
search --no-floppy --fs-uuid --set=root 6368746f-2074-616b-6f65-207575696400
fi
echo 'Loading Linux linux ...'
linux /boot/vmlinuz-linux root=UUID=6368746f-2074-616b-6f65-207575696400 rw quiet
echo 'Loading initial ramdisk ...'
initrd /boot/initramfs-linux.img
}
menuentry 'Arch Linux, with Linux linux (fallback initramfs)' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-linux-fallback-6368746f-2074-616b-6f65-207575696400' {
load_video
set gfxpayload=keep
insmod gzio
insmod part_msdos
insmod ext2
set root='hd0,msdos2'
if [ x$feature_platform_search_hint = xy ]; then
search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos2 --hint-efi=hd0,msdos2 --hint-baremetal=ahci0,msdos2 6368746f-2074-616b-6f65-207575696400
else
search --no-floppy --fs-uuid --set=root 6368746f-2074-616b-6f65-207575696400
fi
echo 'Loading Linux linux ...'
linux /boot/vmlinuz-linux root=UUID=6368746f-2074-616b-6f65-207575696400 rw quiet
echo 'Loading initial ramdisk ...'
initrd /boot/initramfs-linux-fallback.img
}
### 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+ ###
最近编辑记录 schux (2016-07-07 08:55:10)
离线
lsblk -o+UUID
离线
lsblk -o+UUID
[root@sch sch]# lsblk -o+UUID
NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT UUID
sda 8:0 0 465.8G 0 disk
├─sda1 8:1 0 1G 0 part 6368746f-2074-616b-6f65-207575696400
├─sda2 8:2 0 40G 0 part / 6368746f-2074-616b-6f65-207575696400
├─sda3 8:3 0 80G 0 part 6368746f-2074-616b-6f65-207575696400
├─sda4 8:4 0 1K 0 part
├─sda5 8:5 0 5G 0 part [SWAP]
├─sda6 8:6 0 10G 0 part 6368746f-2074-616b-6f65-207575696400
├─sda7 8:7 0 10G 0 part 6368746f-2074-616b-6f65-207575696400
├─sda8 8:8 0 120G 0 part 06EA-06EB
├─sda9 8:9 0 100G 0 part 070A-070A
└─sda10 8:10 0 99.7G 0 part 0729-072A
离线
天哪,你有五个分区的 UUID 都一样…………你是怎么分区的啊。
离线
天哪,你有五个分区的 UUID 都一样…………你是怎么分区的啊。
用工具分的,不是直接用安装盘的工具,为了省事,嘿嘿。这么说是分区的问题?那我硬盘从头到尾再折腾一遍?有没有直接修改分区UUID的方法?(如果可以,直接改掉其他几个也许问题就解决了,正在尝试中......)
我自己也觉得奇怪怎么会是一样,以为是硬盘的标识,可看了最后几个盘,也不对,汗。。。
最近编辑记录 schux (2016-07-07 11:06:14)
离线
依云 说:天哪,你有五个分区的 UUID 都一样…………你是怎么分区的啊。
用工具分的,不是直接用安装盘的工具,为了省事,嘿嘿。这么说是分区的问题?那我硬盘从头到尾再折腾一遍?有没有直接修改分区UUID的方法?(如果可以,直接改掉其他几个也许问题就解决了,正在尝试中......)
我自己也觉得奇怪怎么会是一样,以为是硬盘的标识,可看了最后几个盘,也不对,汗。。。
你这是用的什么工具啊,UUID 竟然分配得一样。我不知道有什么工具可以修改 UUID 呢。
离线
用
uuidgen | xargs tune2fs /dev/sdaX -U 搞定其余几个分区的UUID
只剩下系统分区不修改,问题果然解决,不会再出现随机的bug(本就奇怪错误怎么是随机的),原来自己才是无形制造bug始作俑者,汗!
最后非常感谢
依云
a.k.a. 百合仙子
的无私帮助。受教了。
最近编辑记录 schux (2016-07-07 12:19:28)
离线