Dockerコンテナのシェルに入るにはどうすればいいですか? 質問する

Dockerコンテナのシェルに入るにはどうすればいいですか? 質問する

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
$

おすすめ記事