91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

docker-compose命令介紹和使用

發布時間:2020-06-10 17:43:02 來源:億速云 閱讀:258 作者:元一 欄目:云計算

docker-compose 的概述

docker-compose技術,就是通過一個 .yml 配置文件,將所有的容器的部署方法、文件映射、容器連接等等一系列的配置寫在一個配置文件里,最后只需要執行docker-compose up命令就會像執行腳本一樣的去一個個安裝容器并自動部署他們,極大的便利了復雜服務的部署。

docker-compose 的工作流程

1、用一個定義應用程序的環境,Dockerfile這樣它就可以在任何地方再現。
2、定義組成應用程序的服務,docker-compose.yml 以便它們可以在隔離的環境中一起運行。
3、運行docker-compose up和撰寫啟動并運行整個應用程序。

一、命令對象與格式

對于Compose來說,大部分命令的對象既可以是項目本身,也可以指定為項目中的服務或者容器。如果沒有特別的說明,命令對象將是項目,這意味著項目中所有的服務都會受到命令影響。

docker-compose命令的基本的使用格式是:

docker-compose [-f <arg>...] [options] [COMMAND] [ARGS...]

二、命令選項

  • -f:指定使用的compose模板文件,默認為當前目錄下的docker-compose.yaml文件,可以多次指定。
  • -p:指定項目的名稱,默認將使用所在目錄名稱作為項目名。
  • --verbose:輸出更多調試信息。
  • -v:打印版本信息并退出。

三、命令使用說明

1、build——構建(重新構建)項目中的服務容器

命令格式為:docker-compose build [options] [SERVICE...]。

服務容器一旦構建后,將會帶上一個標記名,例如對于web項目中的一個db容器,可能是web_db。

可以隨時在項目目錄下運行docker-compose build 來重新構建服務。

上述命令選項包括:

  • --force-rm:刪除構建過程中的臨時容器。
  • --no-cache:構建鏡像過程中不使用cache(這會加長構建過程)。
  • --pull:始終嘗試通過pull來獲取更新版本的鏡像。

2、config——檢測compose文件的錯誤

驗證Compose文件格式是否正確,若正確則顯示配置,若格式錯誤顯示錯誤原因。

命令格式如下:

$ docker-compose config

3、up——啟動服務

格式為:docker-compose up [options] [SERVICE...]。

該命令十分強大,它將嘗試自動完成包括構建鏡像,(重新)創建服務,啟動服務,并關聯服務相關容器的一系列操作。

鏈接的服務都將會被自動啟動,除非已經處于運行狀態。

可以說,大部分時候都可以直接通過該命令來啟動一個項目。

默認情況,docker-compose up 啟動的容器都在前臺,控制臺將會同時打印所有容器的輸出信息,可以很方便進行調試。

當通過 Ctrl-C 停止命令時,所有容器將會停止。

如果使用 docker-compose up -d,將會在后臺啟動并運行所有的容器。一般推薦生產環境下使用該選項。

默認情況,如果服務容器已經存在,docker-compose up 將會嘗試停止容器,然后重新創建(保持使用 volumes-from 掛載的卷),以保證新啟動的服務匹配 docker-compose.yml 文件的最新內容。如果用戶不希望容器被停止并重新創建,可以使用 docker-compose up --no-recreate。這樣將只會啟動處于停止狀態的容器,而忽略已經運行的服務。如果用戶只想重新部署某個服務,可以使用 docker-compose up --no-deps -d <SERVICE_NAME> 來重新創建服務并后臺停止舊服務,啟動新服務,并不會影響到其所依賴的服務。

選項:

  • -d:在后臺運行服務容器。
  • --no-color:不使用顏色來區分不同的服務的控制臺輸出。
  • --no-deps:不啟動服務所鏈接的容器。
  • --force-recreate:強制重新創建容器,不能與 --no-recreate 同時使用。
  • --no-recreate:如果容器已經存在了,則不重新創建,不能與 --force-recreate 同時使用。
  • --no-build:不自動構建缺失的服務鏡像。
  • -t:停止容器時候的超時(默認為 10 秒)。

3、down——停止容器

此命令將會停止up命令所啟動的容器,并移除網絡。

4、images——列出項目中所包含的鏡像

$ docker-compose images    # 列出項目中所包含的鏡像
$ docker-compose -p tt images      # 若不是默認的項目名稱,則需要指定項目名稱

5、logs——查看服務容器的日志

格式為:docker-compose logs [options] [SERVICE...]。

默認情況下,docker-compose 將對不同的服務輸出使用不同的顏色來區分。可以通過 --no-color 來關閉顏色。

該命令在調試問題的時候十分有用。

$ cat docker-compose.yml           # compose文件如下
version: '3'
services:
  web:
    build: .
    ports:
      - "5001:5000"
  redis:
    image: "redis:alpine"

$ docker-compose logs        #不加服務名稱則會顯示項目中所有服務的日志,不同服務之間的日志以不同的顏色區分
$ docker-compose logs web      #也可以指定項目中的服務名稱,查看指定服務的日志
$ docker-compose logs redis     #同上

6、kill——發送 SIGKILL 信號來強制停止服務容器

格式為 docker-compose kill [options] [SERVICE...]。

支持通過 -s 參數來指定發送的信號,例如通過如下指令發送 SIGINT 信號。

$ docker-compose  kill -s SIGINT web     #  kill掉指定的服務
$ docker-compose -p tt kill -s SIGINT web   #若不是默認的項目名稱,則需要-p指定項目名稱

8、port——查看某個容器端口所映射的公共端口

格式為:docker-compose port [options] SERVICE PRIVATE_PORT。

選項:

  • --protocol=proto 指定端口協議,tcp(默認值)或者 udp。
  • --index=index 如果同一服務存在多個容器,指定命令對象容器的序號(默認為 1)。
[root@node02 test]# docker-compose port web 5000
0.0.0.0:5001
#上面的結果表示將web服務的5000端口映射到了宿主機的5001端口

9、ps——列出項目中目前的所有容器

格式為:docker-compose ps [options] [SERVICE...]。

$ docker-compose ps -q web    #查看某一個服務的ID
$ docker-compose ps       #查看項目中所有服務的容器信息

選項:

  • -q:只打印容器的 ID 信息。

10、restart——重啟項目中的服務

格式為:docker-compose restart [options] [SERVICE...]。

選項:

  • -t, --timeout TIMEOUT 指定重啟前停止容器的超時(默認為 10 秒)。

舉個栗子:

$ docker-compose restart        #重啟當前項目中的所有服務
$ docker-compose restart web     #重啟當前項目中的web服務

11、rm——刪除所有停止狀態的服務容器

格式為 docker-compose rm [options] [SERVICE...]。

選項:

  • -f:不要求確認移除。
  • -s:在刪除前停止項目中的所有容器。
  • -v:刪除任何附加到容器的匿名卷。

12、run——在指定服務上運行一個命令

格式為:docker-compose run [options] [-p PORT...] [-e KEY=VAL...] SERVICE [COMMAND] [ARGS...]。

例如:

$ docker-compose run web ping www.baidu.com

上面的指令將啟動項目中的web服務容器,并執行ping www.baidu.com 命令。

默認情況下,如果存在關聯,則所有關聯的服務將會自動被啟動,除非這些服務已經在運行中。

如果不希望自動啟動關聯的容器,可以使用 --no-deps 選項,例如

$ docker-compose run --no-deps web ping www.baidu.com

選項:

  • -d:后臺運行容器。
  • --name:為容器指定一個名字。
  • --entrypoint :覆蓋默認的容器啟動指令。
  • -e KEY=VAL :設置環境變量值,可多次使用選項來設置多個環境變量。
  • -u:指定運行容器的用戶名或者 uid。
  • --no-deps :不自動啟動關聯的服務容器。
  • --rm:運行命令后自動刪除容器,d 模式下將忽略。
  • -p:映射容器端口到本地主機。
  • --service-ports:配置服務端口并映射到本地主機。
  • -T:不分配偽 tty,意味著依賴 tty 的指令將無法運行。

13、scale——設置指定服務運行的容器個數

格式為:docker-compose scale [options] [SERVICE=NUM...]。

通過 service=num 的參數來設置數量。例如:

$ docker-compose scale web=3 redis=2

將啟動 3 個容器運行 web 服務,2 個容器運行redis服務,但是需要注意的是,docker-compose中定義ports字段時,就不可以指定映射到宿主機的端口了,否則只可以啟動一個。

一般的,當指定數目多于該服務當前實際運行容器,將新創建并啟動容器;反之,將停止容器。

選項:
-t:停止容器時候的超時(默認為 10 秒)。

14、stop——停止處于運行狀態的容器

格式為 docker-compose stop [options] [SERVICE...]。

停止已經處于運行狀態的容器,但不刪除它。通過 docker-compose start 可以再次啟動這些容器。

栗子:

$ docker-compose stop web     #停止當前項目中的web服務
$ docker-compose stop         #停止當前項目中所有服務

選項:

  • -t:停止容器時候的超時(默認為10秒)

15、start——啟動被stop的服務容器

格式為:docker-compose start [SERVICE...]。

栗子:

$ docker-compose start

16、top——查看各個服務容器內運行的進程

$ docker-compose top    #查看項目中所有服務的進程
$ docker-compose top web   #查看項目中web服務的進程

17、pause——暫停一個服務容器

格式為:docker-compose pause [SERVICE...]。

暫停一個服務容器。

如下:

$ docker-compose -p tt pause redis    # -p選項是指定項目名稱
#若是默認的項目名稱,則可以忽略-p選項
$ docker-compose pause        #暫停項目中的所有服務

18、unpause——恢復處于暫停狀態中的服務

格式為 docker-compose unpause [SERVICE...]。

栗子:

$ docker-compose unpause

———————— 本文至此結束,感謝閱讀 ————————

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

镇原县| 武胜县| 禹州市| 集贤县| 九龙县| 广平县| 富源县| 阜城县| 临西县| 喜德县| 手游| 安乡县| 阿巴嘎旗| 成安县| 浠水县| 衡水市| 安福县| 新源县| 广饶县| 大竹县| 高邑县| 绍兴市| 吴川市| 永平县| 东至县| 汝州市| 光泽县| 大石桥市| 来凤县| 北海市| 醴陵市| 红河县| 普定县| 伊川县| 平陆县| 盐池县| 榆社县| 六盘水市| 随州市| 乳山市| 娱乐|