このオプションは正確には何をしますか?私はTTYについてたくさん読んでいますが、それでも混乱しています。私は持っていないと周りの演奏-t
だけを-i
し、それがユーザーの入力をせずにエラーをスロー期待しているプログラムのように思えます-t
。疑似TTYを有効にすることが重要なのはなぜですか?
このオプションは正確には何をしますか?私はTTYについてたくさん読んでいますが、それでも混乱しています。私は持っていないと周りの演奏-t
だけを-i
し、それがユーザーの入力をせずにエラーをスロー期待しているプログラムのように思えます-t
。疑似TTYを有効にすることが重要なのはなぜですか?
回答:
-t
オプションは、Unix / Linuxは、端末のアクセスをどのように処理するかに行きます。以前は、端末は固定回線接続でしたが、後でモデムベースの接続になりました。これらには物理的なデバイスドライバーがありました(実際の機器の一部でした)。一般化されたネットワークが使用されるようになると、疑似端末ドライバーが開発されました。それは、端末の能力は(上のmanページを読んで、直接あなたのプログラムにそれを記述する必要なしに使用することができるかを理解間の分離を作成するためですstty
、curses
)。
したがって、それを背景として、オプションなしでコンテナを実行すると、デフォルトでstdoutストリームが作成されます(正常にdocker run | <cmd>
動作します)。で実行すると-i
、stdinストリームが追加されます(<cmd> | docker run -i
機能します)。-t
通常は組み合わせて-it
を使用し、ターミナルドライバーを追加します。これは、プロセスと対話している場合に必要になる可能性があります。基本的に、コンテナの開始をターミナル接続セッションのように見せます。
docker run -i ubuntu
とdocker run -it ubuntu
、すぐに違いがわかります。「-i」を使用すると、コンテナがホストからの対話を待機するようになりますが、フラグ「-t」を使用して「ttyドライバーを割り当て」た後、コンソール(ターミナル)からの実際の対話が可能になります。
-t
が、本番環境ではdocker startコマンドを変更できません。だから私はそれがで始まったとアプリに思わせる必要があります-t
。
遅い答えですが、誰かを助けるかもしれません
docker run/exec -i
コンテナ内のコマンドのSTDINをdocker run/exec
それ自体のSTDINに接続します。
そう
docker run -i alpine cat
入力を待つ空の行が表示されます。「hello」と入力すると、「hello」というエコーが表示されます。メインプロセスがの端末入力である無限ストリームからの入力を待機しているため、コンテナはCTRL+ を送信するまで終了しません。Dcat
docker run
echo "hello" | docker run -i alpine cat
ことをcat
通知するため、「hello」を出力してすぐに終了します。docker ps
上記のいずれかを終了した後で試行した場合、実行中のコンテナは見つかりません。どちらの場合も、cat
それ自体が終了したため、Dockerはコンテナーを終了しました。
ここで「-t」の場合、これはdocker内のメインプロセスに、その入力が端末デバイスであることを伝えます。
そう
docker run -t alpine cat
空の行が表示されますが、「hello」と入力してもエコーは表示されません。これはcat
、が端子入力に接続されているが、この入力は入力に接続されていないためです。入力した「hello」はの入力に到達しませんでしたcat
。cat
到着しない入力を待っています。echo "hello" | docker run -t alpine cat
また、あなたの空行を与えるだろうと上のコンテナを終了していないだろうCTRL- Dしかし、あなたは合格しなかったので、あなたがエコー「こんにちは」を得ることはありません-i
CTRL+ を送信Cすると、シェルが元に戻りますが、docker ps
今すぐ試すと、cat
コンテナーがまだ実行中であることがわかります。それの訳はcat
閉じられなかった入力ストリームをまだ待機しているです。と-t
組み合わせずに、一人で使える便利なアプリは見つかりませんでした-i
。
今、-it
一緒に。これは、入力が端子であることをcatに伝え、同時にこの端子を端子である入力に接続しdocker run
ます。docker run/exec
に渡す前に、自身の入力が実際にttyであることを確認しcat
ます。この場合、それ自体の入力は前のエコーからのパイプであり、実行される端末ではないため、これinput device is not a TTY
を試してみるのecho "hello" | docker run -it alpine cat
はこのためです。docker run
docker run
最後に、入力をの入力に接続するトリックを実行する-t
場合、なぜ渡す必要があるのでしょうか。これは、コマンドが端末の場合、入力の扱いが異なるためです。これも例によって最もよく示されています-i
cat
docker run -e MYSQL_ROOT_PASSWORD=123 -i mariadb mysql -u root -p
パスワードプロンプトが表示されます。パスワードを入力すると、文字が表示されます。docker run -i alpine sh
空の行が表示されます。ls
出力を取得するようなコマンドを入力しても、プロンプトやカラー出力は表示されません。最後の2つのケースでは、この動作を得るmysql
だけでなく、としてshell
の入力をマスキングまたは出力を着色するようにttyの特定の動作を使用していなかったので、ttyのように、入力を処理していなかったと。
-t
、-i
オプションが何をするかです!
の -t
引数には、Google検索によると、多くの場合、多くの人々によって十分に文書化、または言及されていません。
docker
Bashプロンプト(最新バージョン1.8.1)で入力してすべてのDockerクライアント引数のリスト(表示されるはず)を表示しても表示されません。
実際、もしifと入力してこの引数について特定のヘルプを取得しようとすると、docker -t --help
次の驚くほどあいまいな応答が返されます。
提供されているが定義されていないフラグ:-t
したがって、この議論について混乱していると非難することはできません!
「疑似ttyを割り当てる」ことであり、多くの場合、 -i
。
https://docs.docker.com/reference/run/
私はそれjwilder/nginx-proxy
が次のように素晴らしいドッカーコンテナのドキュメントで使用されているのを見ました:
docker run -d -p 80:80 --name nginx -v /tmp/nginx:/etc/nginx/conf.d -t nginx
この場合、何をするかは、このDockerコンテナー内の「仮想」tty(Bashコマンドプロンプト/ターミナル)に出力を送信することです。次に、dockerコマンドを実行してこの出力を確認できますdocker logs CONTAINER
。CONTAINER
、このコンテナのIDの文字の最初のカップルです。このCONTAINER IDは、docker ps -a
私はこの-t
議論が次のリンクで簡単に言及されているのを見ました、そこでそれは言います
-t
そして-i
フラグは仮想端末を割り当て、接続されていない場合でも、オープン標準入力ください。これにより、bashプロンプトが実行されている限り、従来のVMのようにコンテナーを使用できます。
https://coreos.com/os/docs/latest/getting-started-with-docker.html
これが役に立てば幸いです!これが文書化されていない、またはあまり使用されていない理由がわかりません。多分それは実験的なものであり、今後のバージョンで文書化された機能として実装されるでしょう。
docker run --help
ではなくに表示されますdocker -t --help
: -t, --tty=false Allocate a pseudo-TTY
"
私が知っていること-t
は次のとおりです:
docker exec -ti CONTAINER bash
-コンテナに「ログイン」できます。ssh-ingのように感じます(そうではありません)。
しかし問題は、データベースを復元したいときでした。
通常私はそうしますdocker exec -ti mysql.5.7 mysql
-ここで、コンテナーでmysqlコマンドを実行し、インタラクティブなターミナルを取得します。
<dump.sql
前のコマンドに追加して、dbを復元できるようにしました。しかし、それは失敗しましたcannot enable tty mode on non tty input
。
-t
助けて削除。それでも理由がわかりません:
docker exec -i mysql.5.7 mysql < dump.sql
最後の1つは動作します。これが人々の役に立つことを願っています。
-t
が、本番環境ではdocker startコマンドを変更できません。だから私はそれがで始まったとアプリに思わせる必要があります-t
。
すべてのプロセスには3つのデータストリームがありますSTDIN/ STDOUT/ STDERR
。プロセスがコンテナで実行されている場合、デフォルトでは、ターミナルはコンテナで実行されているプロセスのSTDOUTストリームに接続されます。したがってdocker run
、ターミナルでコマンドを実行している間、すべての出力ストリームが表示されます。しかし、コンテナーで実行中のプロセスに入力を提供する場合は、プロセスのSTDINチャネルに接続する必要があります。これはデフォルトではなく、docker run -i
コマンド。
-t
インタラクティブ/フォーマットされた入力操作に使用されます。
の -it
容器内のインタラクティブbashシェルを作成、コンテナの標準入力に接続された擬似TTYを割り当てるドッカーを指示します。
--interactive
、 -i
false
取り付けられていなくてもSTDINを開いたままにします
--tty
、 -t
false
疑似TTYを割り当てる
-it
フラグの基本的な動作を説明しています。