phusion/baseimage
は、軽量のinitプロセスでpid1の問題を処理することを誇っています。どのようにしてphusion/baseimageを適切に使用できますか?コマンドps aux
は、PID1で実行されているps
を表示してイメージを呼び出そうとしました。
私は何を間違えましたか?画像を使用する適切な方法は何ですか?
me@Host:~/app1$ docker run --rm phusion/baseimage ps aux
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
root 1 3.0 0.0 29180 1404 ? Rs 01:27 0:00 ps aux
dockerにはオプション--init
があります。これにより、initシステムが開始されます tini Pid1として。
tini
はホストに/usr/bin/docker-init
として保存されます。残念ながら、FedoraやopenSUSEなどの一部のシステムでは、--init
がdocker run --help
に表示されていても、initバイナリが欠落しています。
Dockerイメージにtini
を自分で追加し、ENTRYPOINT /tini --
でエントリポイントを定義できます。 TiniのREADME を参照してください。
/usr/bin/docker-init
の欠落に関する詳細情報: https://github.com/mviereck/x11docker/issues/23#issuecomment-386817295
phusion/baseimage
を使用する適切な方法は、次のように実行することであることがわかりました( ここから )。
docker run --rm -t -i phusion/baseimage /sbin/my_init ps aux`
my_init
をPID1として実行し、my_init
にps aux
のプロセスを生成させる
*** Running /etc/my_init.d/00_regen_ssh_Host_keys.sh...
*** Running /etc/my_init.d/10_syslog-ng.init...
May 8 04:18:23 daf3cfab8573 syslog-ng[10]: syslog-ng starting up; version='3.5.6'
May 8 04:18:23 daf3cfab8573 syslog-ng[10]: WARNING: you are using the pipe driver, underlying file is not a FIFO, it should be used by file(); filename='/dev/stdout'
May 8 04:18:24 daf3cfab8573 syslog-ng[10]: EOF on control channel, closing connection;
*** Running /etc/rc.local...
*** Booting runit daemon...
*** Runit started as PID 16
*** Running ps aux...
May 8 04:18:24 daf3cfab8573 cron[20]: (CRON) INFO (pidfile fd = 3)
May 8 04:18:24 daf3cfab8573 cron[20]: (CRON) INFO (Running @reboot jobs)
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
root 1 5.0 0.0 32304 10796 ? Ss+ 04:18 0:00 /usr/bin/python3 -u /sbin/my_init ps aux
root 10 1.0 0.0 72364 7552 ? S 04:18 0:00 /usr/sbin/syslog-ng --pidfile /var/run/syslog-ng.pid -F --no-caps
root 16 0.0 0.0 4392 1124 ? S+ 04:18 0:00 /usr/bin/runsvdir -P /etc/service
root 17 0.0 0.0 37656 3340 ? R+ 04:18 0:00 ps aux
root 18 0.0 0.0 4240 672 ? Ss 04:18 0:00 runsv cron
root 19 0.0 0.0 4240 800 ? Ss 04:18 0:00 runsv sshd
root 20 0.0 0.0 29272 2840 ? S 04:18 0:00 /usr/sbin/cron -f
*** ps exited with status 0.
*** Shutting down runit daemon (PID 16)...
*** Running /etc/my_init.post_shutdown.d/10_syslog-ng.shutdown...
May 8 04:18:24 daf3cfab8573 syslog-ng[10]: syslog-ng shutting down; version='3.5.6'
May 8 04:18:24 daf3cfab8573 syslog-ng[10]: EOF on control channel, closing connection;
*** Killing all processes...