bash: no job control in this shell

2:11:00 PM 0 Comments

当 我们从shell, 启动一个跑在另外一个tty的shell时将会碰到这个提示。 最常见的是, shell直接把/dev/console作为它的标准输入输出。比如 gentoo, arch使用硬盘安装大法, 但是却找不到硬盘是, 它会自动启动一个shell, 这个shell就是没有job control的了。

至于原因, 涉及的内容比较多, 所以我就不想在这里作详细的分析了。想深入了解的话, 自己看看 AUPE就是了。 大致的原因是, 一个session leader试图打开一个终端设备时, 假如这个leader没有控制终端, 那么这个终端设备将自动成为改session leader的的控制终端。了解这一点就不难理解为什么会有这个提示了: 就是说shell没有找到控制终端。

解决的办法很简单: 使用agetty 来调用shell。 agetty会创建新的会话, 自然没有了控制终端。所以自然, agetty所打开的tty自动成为了它的控制终端, 并且被agetty调用shell也会继承这一点。

以下是一个例子:



#!/bin/sh

TMPNAME=`mktemp /tmp/bbsh.XXX`
echo '#!/bin/sh' > $TMPNAME
echo 'exec /bin/sh' >> $TMPNAME

chmod +x $TMPNAME

#请确保tty8 没有被其他程序正在使用
/sbin/agetty -l /tmp/bbsh 38400 tty8 linux
rm $TMPNAME

执行该脚本之后将在tty8, 运行一个agetty。 随意输入一个login name: 之后回车,
将看到一个shell, 并且这个shell是带有job control的。这样你就可以建一个更好的
minilinux了。

Some say he’s half man half fish, others say he’s more of a seventy/thirty split. Either way he’s a fishy bastard.