AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 425280
Accepted
Multisync
Multisync
Asked: 2018-02-20 13:19:24 +0800 CST2018-02-20 13:19:24 +0800 CST 2018-02-20 13:19:24 +0800 CST

提供 `console` 启动参数以启用串行访问时,系统无法启动

  • 772

我想要完成的

我想通过 USB-RS232 适配器远程终端访问我的 NAS(运行 Debian Stretch)。由于这台机器应该是无头的,所以我也想看看串口线的启动过程。

(不过,为了评估这个问题,目前 HDMI 端口上连接了一个屏幕。)

我采取的行动

我附加console=ttyUSB0到内核参数列表中。启动时,这会导致我的系统冻结。

引导输出的最后几行是:(Bootloader 是 extlinux)

Loading /vmlinuz... ok
Loading /initrd.img...ok
Probing EDD (edd=off to disable)... ok

当不使用所述内核参数时,机器正在引导而没有问题。从那里开始,我可以通过运行轻松完成串行终端访问

systemctl enable [email protected]
systemctl start [email protected]

在远程服务器上,以及

screen -F /dev/ttyUSB0 9600

在我的本地机器上。因此,USB-RS232 适配器工作正常。该服务器是带有 Braswell 芯片组的Intel NUC 5CPYH,运行Linux 4.9.0-4-amd64debian 内核。

我的问题

我必须采取哪些措施才能使其正常工作?

编辑№1

当提供console=tty0 console=ttyUSB0,9600n8启动参数时,机器启动得很好,但我仍然无法连接到串行端口。另外,systemctl status [email protected]说服务是loadedand inactive (dead)。我本来预计它会在那时启动并运行。

编辑№2

我做了一些研究,发现我的 initramfs 缺少相关的内核模块。我通过提供内核参数设法进入 initramfs shell,break=init发现没有/dev/ttyUSB0设备。

我在重新创建 initramfs 后添加了cp210x,pl2303和ftdi_sioto /etc/initramfs-tools/modules,看到现在/dev/ttyUSB0initramfs shell 中有一个设备。

不过,我无法从我的另一台机器连接。所以我尝试在该设备上手动启动 getty:

# /sbin/getty -L 9600 /dev/ttyUSB0 vt100
getty: setsid: Operation not permitted
# su root -c "/sbin/getty -L 9600 /dev/ttyUSB0 vt100"
sh: su: not found

这就是我现在的位置。

linux debian
  • 2 2 个回答
  • 2183 Views

2 个回答

  • Voted
  1. Rui F Ribeiro
    2018-02-20T13:37:42+08:002018-02-20T13:37:42+08:00

    您的系统没有冻结。您刚刚将所有输出定向到串行控制台。

    将控制台参数传递给内核,您必须同时包含本地控制台和串行接口。

    请参阅TLDP - 远程串行控制台 HOWTO - 第 5 章。配置 Linux 内核

    图 5-2。推荐内核参数,带显卡的PC

    console=tty0 console=ttyS0,9600n8
    

    内核消息将同时出现在第一个虚拟终端和串行端口上。来自 init 系统和系统记录器的消息将仅出现在第一个串行端口上。在查看连接的监视器时,这可能会有点令人困惑:机器似乎正在启动然后挂起。不要惊慌,init 系统已经启动,但现在正在向串行端口打印消息,但在屏幕上没有打印任何内容。如果配置了 getty,则登录:提示最终将出现在连接的监视器上。

    对于没有显卡的 PC,此 HOWTO 建议内核参数:

    图 5-3。推荐内核参数,不带显卡的PC

    console=ttyS0,9600n8
    

    这些参数由引导加载程序传递给引导内核。接下来,我们将配置您的 Linux 安装使用的引导加载程序,以将控制台参数传递给内核。

    • 3
  2. Best Answer
    Michael
    2021-07-29T00:07:19+08:002021-07-29T00:07:19+08:00

    Debian 目前不使用 构建它的 Linux 内核CONFIG_USB_SERIAL_CONSOLE=y,这是该功能工作所必需的。

    对应的错误报告是https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=868352

    CONFIG_USB_SERIAL_CONSOLE=y在使用(参见https://kernel-team.pages.debian.net/kernel-handbook/ch-common-tasks.html#s-common-official )构建我自己的内核之后,我还必须包含 FTDI 串行驱动程序对于我在 initrd 中的适配器:

    # echo ftdi_sio >> /etc/initramfs-tools/modules
    # update-initramfs -u
    

    最后,我调整/etc/default/grub阅读:

    GRUB_CMDLINE_LINUX_DEFAULT="panic=10 panic_on_oops=1 console=tty0 console=ttyUSB0,115200"
    

    ……然后跑了update-grub。

    之后,我成功看到了启动信息,并且可以通过自动启动的serial-getty@ttyUSB0 服务登录。

    • 1

相关问题

  • astyle 不会更改源文件格式

  • 接收有关全新 Debian 的电子邮件

  • Debian Stretch:libgs_plugin_systemd-updates.so 中的 gnome-software 段错误

  • 通过标签将根文件系统传递给linux内核

  • 如何在拼音输入法中输入ü?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    ssh 无法协商:“找不到匹配的密码”,正在拒绝 cbc

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    如何卸载内核模块“nvidia-drm”?

    • 13 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add 返回:“连接代理时出错:没有这样的文件或目录” 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve