Docker を使い始めました。WordPress
ベースイメージと を使用していますdocker-compose
。
コンテナーの 1 つにsshで接続して、初期ビルド中に作成されたファイル/ディレクトリを調べようとしています。 を実行しようとしましたdocker-compose run containername ls -la
が、何も起こりませんでした。 たとえ起こったとしても、単一のコマンドを実行するのではなく、ディレクトリ構造をトラバースできるコンソールを使用したいです。 Docker でこれを行う正しい方法は何ですか?
ベストアンサー1
docker attach
を使用すると、Docker コンテナに接続できますが、これは とはまったく同じではありませんssh
。たとえば、コンテナが Web サーバーを実行している場合、は、おそらく Web サーバー プロセスのstdoutdocker attach
に接続します。必ずしもシェルが提供されるわけではありません。
おそらく、このdocker exec
コマンドはあなたが探しているものです。これにより、既存のコンテナ内で任意のコマンドを実行できます。例:
docker exec -it <mycontainer> bash
もちろん、実行するコマンドはコンテナのファイルシステム内に存在している必要があります。
上記のコマンドでは、 は<mycontainer>
ターゲット コンテナの名前または ID です。 を使用しているかどうかは関係ありませんdocker compose
。 を実行してdocker ps
、ID (最初の列に表示される 16 進文字列) または名前 (最後の列に表示される) のいずれかを使用します。たとえば、次のようになります。
$ docker ps
d2d4a89aaee9 larsks/mini-httpd "mini_httpd -d /cont 7 days ago Up 7 days web
走れる:
$ docker exec -it web ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
valid_lft forever preferred_lft forever
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
18: eth0: <BROADCAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP
link/ether 02:42:ac:11:00:03 brd ff:ff:ff:ff:ff:ff
inet 172.17.0.3/16 scope global eth0
valid_lft forever preferred_lft forever
inet6 fe80::42:acff:fe11:3/64 scope link
valid_lft forever preferred_lft forever
次のコマンドを実行することで同じことを実現できます。
$ docker exec -it d2d4a89aaee9 ip addr
同様に、コンテナ内でシェルを起動することもできます。
$ docker exec -it web sh
/ # echo This is inside the container.
This is inside the container.
/ # exit
$