最近、日々のテストで docker を手動で起動または停止する必要があることが多くなったため、手動操作を置き換えるためにシェル スクリプトを作成することにしました。また、次に示すように、スクリプトは Python スクリプトを介してリモートで呼び出すこともできます。 現在、スクリプトはコンテナ ID をスクリプト内にハードコードしています。もちろん、スクリプトにパラメータを渡すことで制御することもできます。変更することもできます。 Dockerを起動する起動スクリプトは次のとおりです。 #!/bin/bash コンテナID="ad3e4d7fc407 a228730a915f ad3e4d7fc4099" statusLived="ライブ" statusdead="死亡" notExistContainer="なし" 再試行回数=3 関数 GetContainerStatus(){ コンテナが存在する場合=$(sudo docker ps -a | grep -i $1 | wc -l ) [ ${containerExist} -gt 0 ]の場合 それから pid=$(sudo docker stats --format "{{.PIDs}}" --no-stream $1 ) [ "${pid}" != "0" の場合 それから エコー「${statusLived}」 それ以外 echo "${statusdead}" フィ それ以外 echo "${notExistContainer}" フィ } 関数StartContainer(){ sudo docker 再起動 $1 } ${containerIDs} のコンテナID する ((i=1;i<=${再試行回数};i++)) の場合 する ステータス=$(GetContainerStatus ${containerID}) echo "コンテナ ${containerID} のステータスは ${status} です" [ "${status}" == ${statusLived} ] の場合 それから echo "コンテナ ${containerID} はすでに実行中です" 壊す フィ [ "${status}" == ${notExistContainer} ] の場合 それから echo "コンテナ ${containerID} は存在しませんでした" 壊す フィ [ "${status}" == ${statusdead} ] の場合 それから echo "コンテナ ${containerID} が停止しました、コンテナを起動してください" コンテナの開始 ${containerID} 検証ステータス=$(GetContainerStatus ${containerID}) [ "${verifyStatus}" == ${statusLived} ] の場合 それから echo "コンテナ ${containerID} の起動に成功しました" 壊す それ以外 echo "${i} コンテナの起動を再試行します" コンテナの開始 ${containerID} フィ フィ 終わり 終わり Dockerを停止する停止スクリプトは次のとおりです。 #!/bin/bash コンテナID="589bda1309cd ad3e4d7fc407 a228730a915f ad3e4d7fc4099" statusLived="ライブ" statusdead="死亡" notExistContainer="なし" 再試行回数=3 関数 GetContainerStatus(){ コンテナが存在する場合=$(sudo docker ps -a | grep -i $1 | wc -l ) [ ${containerExist} -gt 0 ]の場合 それから pid=$(sudo docker stats --format "{{.PIDs}}" --no-stream $1 ) [ "${pid}" != "0" の場合 それから エコー「${statusLived}」 それ以外 echo "${statusdead}" フィ それ以外 echo "${notExistContainer}" フィ } 関数StopContainer(){ sudo docker stop $1 } ${containerIDs} のコンテナID する ((i=1;i<=${retryCount};i++)) の場合 する ステータス=$(GetContainerStatus ${containerID}) echo "コンテナ ${containerID} のステータスは ${status} です" [ "${status}" == ${statusdead} ] の場合 それから echo "コンテナ ${containerID} はすでに停止しています" 壊す フィ [ "${status}" == ${notExistContainer} ] の場合 それから echo "コンテナ ${containerID} は存在しませんでした" 壊す フィ [ "${status}" == ${statusLived} ] の場合 それから echo "コンテナ ${containerID} は稼働中です。コンテナを停止してください" コンテナを停止 ${containerID} 検証ステータス=$(GetContainerStatus ${containerID}) [ "${verifyStatus}" == ${statusdead} ] の場合 それから echo "コンテナ ${containerID} の停止に成功しました" 壊す それ以外 echo "${i} コンテナの停止を再試行します" コンテナを停止 ${containerID} フィ フィ 終わり 終わり Python 呼び出しスクリプトPython サンプル スクリプトは次のとおりです。 パラミコをインポートする def StartContainer(svr,port,user,pwd): クライアント = paramiko.SSHClient() クライアントがホストキーポリシーを欠落しているかどうかを設定します。 client.connect(svr、ポート=port、ユーザー名=user、パスワード=pwd、タイムアウト=5) client.exec_command("cd /home/TestCode/ && bash startContainer.sh") def StopContainer(svr,port,user,pwd): クライアント = paramiko.SSHClient() クライアントがホストキーポリシーを欠落しているかどうかを設定します。 client.connect(svr、ポート=port、ユーザー名=user、パスワード=pwd、タイムアウト=5) client.exec_command("cd /home/TestCode/ && bash stopContainer.sh ") 要約する 以上、シェルスクリプトを使用して Docker サービスを一括起動・停止する方法についてご紹介しました。お役に立てれば幸いです。 以下もご興味があるかもしれません:
|
<<: TypeScript の Enum が問題となる理由
>>: MySQL インデックスのカーディナリティの概念と使用例
目次1. MySQL の時刻型2. タイムゾーンを確認する3. 不正な時間値4. 厳密モード5. 事...
1. コンテナに入るdocker run [オプション] イメージ名 [起動コンテナに渡されるコマン...
1. 環境要件1. Docker 17以上がインストールされている2. コンテナ操作docker r...
1. 質問:最近、挿入操作を行っています。MySQLのバージョンは5.7です。挿入は成功しますが、エ...
目次データブローカーとイベントObject.defineProperty メソッドのレビューデータブ...
目次1. マップ方式2. 応用背景:需要開発プロセス中に、一部のインターフェースは、ページに表示する...
背景AWS EC2 を使用するプロジェクトサービスがあります。セキュリティとパフォーマンスを考慮して...
最近、shake.jsを使用して、shakeに似た機能を作成しました。ただし、shake機能はios...
親ディレクトリを指定する方法../ はソース ファイルの親ディレクトリを表し、../../ はソース...
MySQL のデフォルトの動作モードは自動コミット モードです。つまり、明示的にトランザクションを開...
目次問題の原因:解決:解決:私は Centos7 を使用しています (理論的にはこの方法は Cent...
目次1. 型2. インスタンス3. コンストラクター4.toString() この記事では、4 つの...
データベース SQL の最適化はよくある問題です。何百万ものデータ ボリュームに対してページング ク...
序文クエリの最適化は一夜にして達成できるものではありません。対応するツールの使い方を学び、他の人の経...
1. MySQLに接続するフォーマット: mysql -h ホストアドレス -u ユーザー名 -p ...