您尚未登录。

#1 2016-07-06 12:13:20

schux
会员
注册时间: 2016-06-29
帖子: 8

安装“archlinux-2016.06.01-dualbut”,经常出现"but /sbin/init does not exist."

错误完整提示:

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)

离线

#2 2016-07-06 14:11:44

依云
会员
所在地: a.k.a. 百合仙子
注册时间: 2011-08-21
帖子: 8,917
个人网站

Re: 安装“archlinux-2016.06.01-dualbut”,经常出现"but /sbin/init does not exist."

安装了 systemd-sysvcompat 吗?
安装完、重启前,执行过 mkinitcpio -p linux 了吗?
使用的是什么方式启动的?BIOS / UEFI?grub 还是其它的引导器?

离线

#3 2016-07-06 15:31:52

schux
会员
注册时间: 2016-06-29
帖子: 8

Re: 安装“archlinux-2016.06.01-dualbut”,经常出现"but /sbin/init does not exist."

1.第一个问:已经安装systemd-sysvcompat。
2.第二个问:已经执行过。
3.第三个问:BIOS -> grub ... ,可以确定grub.cfg(安装引导时自动生成文件并且检查无误)和fstab关键文件是正确的。

离线

#4 2016-07-06 16:00:51

依云
会员
所在地: a.k.a. 百合仙子
注册时间: 2011-08-21
帖子: 8,917
个人网站

Re: 安装“archlinux-2016.06.01-dualbut”,经常出现"but /sbin/init does not exist."

在出错的时候 ls /new_root 看看,那里是你的 / 分区的内容吗?你是不是把 / 分区弄错了呢?

离线

#5 2016-07-06 18:56:19

schux
会员
注册时间: 2016-06-29
帖子: 8

Re: 安装“archlinux-2016.06.01-dualbut”,经常出现"but /sbin/init does not exist."

依云 说:

在出错的时候 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)

离线

#6 2016-07-06 21:38:25

依云
会员
所在地: a.k.a. 百合仙子
注册时间: 2011-08-21
帖子: 8,917
个人网站

Re: 安装“archlinux-2016.06.01-dualbut”,经常出现"but /sbin/init does not exist."

schux 说:

输入命令:ls /new_root, 显示如下内容
grub     initramfs-linux.img     vmlinuz-linux   initramfs-linux-fallback.img     lost+found

你这是 /boot 分区被当作 / 分区了啊……改内核命令行 / grub.cfg 吧。

离线

#7 2016-07-06 21:53:31

schux
会员
注册时间: 2016-06-29
帖子: 8

Re: 安装“archlinux-2016.06.01-dualbut”,经常出现"but /sbin/init does not exist."

依云 说:
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)

离线

#8 2016-07-07 07:53:01

依云
会员
所在地: a.k.a. 百合仙子
注册时间: 2011-08-21
帖子: 8,917
个人网站

Re: 安装“archlinux-2016.06.01-dualbut”,经常出现"but /sbin/init does not exist."

那你这是哪里?你内核的 root 参数是怎么写的?或者用 mount 命令看看挂载的是哪个设备。

离线

#9 2016-07-07 08:05:08

schux
会员
注册时间: 2016-06-29
帖子: 8

Re: 安装“archlinux-2016.06.01-dualbut”,经常出现"but /sbin/init does not exist."

依云 说:

那你这是哪里?你内核的 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)

离线

#10 2016-07-07 09:52:15

依云
会员
所在地: a.k.a. 百合仙子
注册时间: 2011-08-21
帖子: 8,917
个人网站

Re: 安装“archlinux-2016.06.01-dualbut”,经常出现"but /sbin/init does not exist."

lsblk -o+UUID

离线

#11 2016-07-07 10:03:36

schux
会员
注册时间: 2016-06-29
帖子: 8

Re: 安装“archlinux-2016.06.01-dualbut”,经常出现"but /sbin/init does not exist."

依云 说:

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

离线

#12 2016-07-07 10:35:09

依云
会员
所在地: a.k.a. 百合仙子
注册时间: 2011-08-21
帖子: 8,917
个人网站

Re: 安装“archlinux-2016.06.01-dualbut”,经常出现"but /sbin/init does not exist."

天哪,你有五个分区的 UUID 都一样…………你是怎么分区的啊。

离线

#13 2016-07-07 10:52:02

schux
会员
注册时间: 2016-06-29
帖子: 8

Re: 安装“archlinux-2016.06.01-dualbut”,经常出现"but /sbin/init does not exist."

依云 说:

天哪,你有五个分区的 UUID 都一样…………你是怎么分区的啊。


用工具分的,不是直接用安装盘的工具,为了省事,嘿嘿。这么说是分区的问题?那我硬盘从头到尾再折腾一遍?有没有直接修改分区UUID的方法?(如果可以,直接改掉其他几个也许问题就解决了,正在尝试中......)
我自己也觉得奇怪怎么会是一样,以为是硬盘的标识,可看了最后几个盘,也不对,汗。。。

最近编辑记录 schux (2016-07-07 11:06:14)

离线

#14 2016-07-07 11:36:27

依云
会员
所在地: a.k.a. 百合仙子
注册时间: 2011-08-21
帖子: 8,917
个人网站

Re: 安装“archlinux-2016.06.01-dualbut”,经常出现"but /sbin/init does not exist."

schux 说:
依云 说:

天哪,你有五个分区的 UUID 都一样…………你是怎么分区的啊。


用工具分的,不是直接用安装盘的工具,为了省事,嘿嘿。这么说是分区的问题?那我硬盘从头到尾再折腾一遍?有没有直接修改分区UUID的方法?(如果可以,直接改掉其他几个也许问题就解决了,正在尝试中......)
我自己也觉得奇怪怎么会是一样,以为是硬盘的标识,可看了最后几个盘,也不对,汗。。。

你这是用的什么工具啊,UUID 竟然分配得一样。我不知道有什么工具可以修改 UUID 呢。

离线

#15 2016-07-07 11:39:37

schux
会员
注册时间: 2016-06-29
帖子: 8

Re: 安装“archlinux-2016.06.01-dualbut”,经常出现"but /sbin/init does not exist."

用   
uuidgen | xargs tune2fs /dev/sdaX -U 搞定其余几个分区的UUID

只剩下系统分区不修改,问题果然解决,不会再出现随机的bug(本就奇怪错误怎么是随机的),原来自己才是无形制造bug始作俑者,汗!

最后非常感谢

    依云
    a.k.a. 百合仙子

的无私帮助。受教了。

最近编辑记录 schux (2016-07-07 12:19:28)

离线

页脚