国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

docker-compose.yml配置文件參數(shù)

這篇具有很好參考價值的文章主要介紹了docker-compose.yml配置文件參數(shù)。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

1. image

services:
  web:
    image: bitnami/mysql:5.7

在 services 標(biāo)簽下的第二級標(biāo)簽是 web,這個名字是用戶自己自定義,它就是服務(wù)名稱。
image 則是指定服務(wù)的鏡像名稱或鏡像 ID。如果鏡像在本地不存在,Compose 將會嘗試?yán)∵@個鏡像。


2. environment
環(huán)境變量,這個標(biāo)簽的作用是設(shè)置鏡像變量,它可以保存變量到鏡像里面,也就是說啟動的容器也會包含這些變量設(shè)置。
environment 和 Dockerfile 中的 ENV 指令一樣會把變量一直保存在鏡像、容器中,類似 docker run -e 的效果。

environment:
  RACK_ENV: development
  SHOW: 'true'
  SESSION_SECRET:

environment:
  - RACK_ENV=development
  - SHOW=true
  - SESSION_SECRET

3. networks
加入指定網(wǎng)絡(luò),格式如下:

services:
  some-service:
    networks:
     - some-network
     - other-network

關(guān)于這個標(biāo)簽還有一個特別的子標(biāo)簽aliases,這是一個用來設(shè)置服務(wù)別名的標(biāo)簽,例如:

services:
  some-service:
    networks:
      some-network:
        aliases:
         - alias1
         - alias3
      other-network:
        aliases:
         - alias2

相同的服務(wù)可以在不同的網(wǎng)絡(luò)有不同的別名。


4. expose
與dockerfile中的expose一樣,用來暴露指定的端口號

expose:
 - "80"
 - "8080"

5. ports
端口映射,把docker內(nèi)部的端口暴露出來
使用HOST:CONTAINER格式或者只是指定容器的端口,宿主機會隨機映射端口。

ports:
 - "3000"
 - "8000:8000"
 - "49100:22"
 - "127.0.0.1:8001:8001"

注意:當(dāng)使用HOST:CONTAINER格式來映射端口時,如果你使用的容器端口小于60你可能會得到錯誤得結(jié)果,因為YAML將會解析xx:yy這種數(shù)字格式為60進制。所以建議采用字符串格式。


6.restart
重啟操作

restart: "no"
restart: always
restart: on-failure
restart: unless-stopped

7. build
服務(wù)除了可以基于指定的鏡像,還可以基于一份 Dockerfile,在使用 up 啟動之時執(zhí)行構(gòu)建任務(wù),這個構(gòu)建標(biāo)簽就是 build,它可以指定 Dockerfile 所在文件夾的路徑。Compose 將會利用它自動構(gòu)建這個鏡像,然后使用這個鏡像啟動服務(wù)容器。

build: /path/to/build/dir

也可以是相對路徑,只要上下文確定就可以讀取到 Dockerfile。

build: ./dir

設(shè)定上下文根目錄,然后以該目錄為準(zhǔn)指定 Dockerfile。

build:   
    context: .   
    dockerfile: name.dockerfile

注意 build 都是一個目錄,如果你要指定 Dockerfile 文件需要在 build 標(biāo)簽的子級標(biāo)簽中使用 dockerfile 標(biāo)簽指定,如上面的例子。
如果你同時指定了 image 和 build 兩個標(biāo)簽,那么 Compose 會構(gòu)建鏡像并且把鏡像命名為 image 后面的那個名字。

build: ./dir 
image: webapp:tag

8.depends_on

在使用 Compose 時,最大的好處就是少打啟動命令,但是一般項目容器啟動的順序是有要求的,如果直接從上到下啟動容器,必然會因為容器依賴問題而啟動失敗。
例如在沒啟動數(shù)據(jù)庫容器的時候啟動了應(yīng)用容器,這時候應(yīng)用容器會因為找不到數(shù)據(jù)庫而退出,為了避免這種情況我們需要加入一個標(biāo)簽,就是 depends_on,這個標(biāo)簽解決了容器的依賴、啟動先后的問題。
例如下面容器會先啟動 redis 和 db 兩個服務(wù),最后才啟動 web 服務(wù):

version: '2'
services:
  web:
    build: .
    depends_on:
      - db
      - redis
  redis:
    image: redis
  db:
    image: postgres

注意的是,默認(rèn)情況下使用 docker-compose up web 這樣的方式啟動 web 服務(wù)時,也會啟動 redis 和 db 兩個服務(wù),因為在配置文件中定義了依賴關(guān)系。


9. volumes
掛載一個目錄或者一個已存在的數(shù)據(jù)卷容器,可以直接使用 [HOST:CONTAINER] 這樣的格式,或者使用 [HOST:CONTAINER:ro] 這樣的格式,后者對于容器來說,數(shù)據(jù)卷是只讀的,這樣可以有效保護宿主機的文件系統(tǒng)。
Compose的數(shù)據(jù)卷指定路徑可以是相對路徑,使用 . 或者 … 來指定相對目錄。
數(shù)據(jù)卷的格式可以是下面多種形式:

volumes:
  # 只是指定一個路徑,Docker 會自動在創(chuàng)建一個數(shù)據(jù)卷(這個路徑是容器內(nèi)部的)。
  - /var/lib/mysql

  # 使用絕對路徑掛載數(shù)據(jù)卷
  - /opt/data:/var/lib/mysql

  # 以 Compose 配置文件為中心的相對路徑作為數(shù)據(jù)卷掛載到容器。
  - ./cache:/tmp/cache

  # 使用用戶的相對路徑(~/ 表示的目錄是 /home/<用戶目錄>/ 或者 /root/)。
  - ~/configs:/etc/configs/:ro

  # 已經(jīng)存在的命名的數(shù)據(jù)卷。
  - datavolume:/var/lib/mysql

#如果不使用宿主機的路徑,可以指定一個volume_driver。
volume_driver: mydriver

示例:

volumes:
  - './nginx-config/party.conf:/etc/nginx/conf.d/party.conf'
  - './dist:/usr/share/nginx/party'
  - './party-static/:/usr/share/nginx/party-static/'
  - /etc/timezone:/etc/timezone             #配置時區(qū)        
  - /etc/localtime:/etc/localtime           #配置時區(qū)

docker-compose.yml文件:文章來源地址http://www.zghlxwxcb.cn/news/detail-498444.html

services:
  mysql:
    image: 'bitnami/mysql:5.7'
    environment:
      - ALLOW_EMPTY_PASSWORD=no
      - MYSQL_ROOT_USER=root
      - MYSQL_ROOT_PASSWORD=123
      - MYSQL_DATABASE=web
      - MYSQL_USER=root
      - MYSQL_PASSWORD=123
      - MYSQL_AUTHENTICATION_PLUGIN=mysql_native_password
      - MYSQL_CHARACTER_SET=utf8mb4
      - MYSQL_COLLATE=utf8mb4_unicode_ci
    networks:
      - web_net
    expose:
      - '3306'
#    ports:
#      - '1433:1433'
    volumes:
      - 'mysql_data:/bitnami/mysql/data'
      - 'mysql_conf:/opt/bitnami/mysql/conf'
    restart: always
  web-backend:
    build:
      context: .
      dockerfile: web-backend.dockerfile
    image: 'web/web-backend'
     expose:
       - '8081'
    # environment:
    #   - TZ=Asia/Shanghai
#    ports:
#      - '8081:8081'
    depends_on:
      - mysql
    volumes:
      - /etc/timezone:/etc/timezone
      - /etc/localtime:/etc/localtime
      - './web-files:/web-files'
      - './web-folder:/web-folder'
    networks:
      - web_net
    restart: always
  web-front:
    image: 'nginx:stable-alpine'
    # environment:
    #   - TZ="Asia/Shanghai"
    ports:
      - '8083:81'
    depends_on:
      - web-backend
    volumes:
      - './nginx-config/web.conf:/etc/nginx/conf.d/web.conf'
      - './dist:/usr/share/nginx/web'
      - './web-static/:/usr/share/nginx/web-static/'
      - /etc/timezone:/etc/timezone
      - /etc/localtime:/etc/localtime
    networks:
      - web_net
    restart: always
networks:
  web_net:
    ipam:
      driver: default
      config:
        - subnet: "192.168.2.0/24"
volumes:
  mysql_data:
    driver: local
  mysql_conf:
    driver: local
  phpmyadmin_data:
    driver: local
  inet_user_data:
    driver: local

到了這里,關(guān)于docker-compose.yml配置文件參數(shù)的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • 在docker編排文件docker-compose.yml中,指定容器的ip地址

    在docker-compose的yaml文件中,可以使用networks來指定容器的ip地址。具體來說,可以在services下面的某個service中添加networks字段,然后在該字段下面添加ipv4_address字段來指定該容器的ip地址。例如: 以上我們定義了一個名為back-tier的網(wǎng)絡(luò),然后在web服務(wù)中使用了該網(wǎng)絡(luò),并指定了

    2024年02月08日
    瀏覽(29)
  • docker-compose.yml

    cat docker-compose.yml? version: \\\'2\\\' services: # ?docker run -tid --name baota -p 80:80 -p 443:443 -p 8888:8888 -p 888:888? # --privileged=true --shm-size=1g? # --restart always? # -v ~/wwwroot:/www/wwwroot pch18/baota ? coinbank_baota: ? ? image: pch18/baota ? ? container_name: coinbank_baota ? ? restart: always ? ? environment: ? ? ? - pri

    2024年02月05日
    瀏覽(35)
  • 【docker】docker-compose.yml 語法詳解

    前面講過Docker Compose的概念,如何安裝、以及常用指令等。 這里重點介紹Docker Compose的語法,如何寫一個正確的docker-compose.yml文件。 我們知道 docker-compose 指令(比如 docker-compose up 等)是運行它的腳本文件docker-compose.yml,那么docker-compose.yml內(nèi)部到底有哪些語法要求呢! 【doc

    2024年01月21日
    瀏覽(33)
  • docker-compose.yml報錯問題

    docker-compose.yml報錯問題

    ERROR: The Compose file \\\'./docker-compose.yml\\\' is invalid because: Invalid top-level property \\\"True\\\". Valid top-level sections for this Compose file are: version, services, networks, volumes, secrets, configs, and extensions starting with \\\"x-\\\". You might be seeing this error because you\\\'re using the wrong Compose file version. Either specify a supported vers

    2024年02月14日
    瀏覽(34)
  • docker-compose.yml 文件更改后想使之立刻生效,但是不想手動刪除已經(jīng)建立的 container 等信息可以運行下面命令

    docker-compose.yml 文件更改后想使之立刻生效,但是不想手動刪除已經(jīng)建立的 container 等信息可以運行下面命令 重新創(chuàng)建容器實現(xiàn)修改

    2024年02月16日
    瀏覽(18)
  • 使用docker-compose.yml快速搭建開發(fā)、部署環(huán)境(nginx、tomcat、mysql、jar包、各種程序)以及多容器通信和統(tǒng)一配置

    image 鏡像名稱,可去鏡像市場查找自己需要的 hostname 容器內(nèi)服務(wù)名 container_name 容器名 volumes 可以把自己電腦的路徑映射到容器中的文件夾中 networks 寫同一個網(wǎng)絡(luò)可以讓容器之間進行通信 啟動 在項目根目錄的命令行中輸入 docker-compose up 停止 在項目根目錄的命令行中輸入 d

    2024年02月12日
    瀏覽(27)
  • 如何使用docker-compose.yml構(gòu)建鏡像?

    使用 docker-compose.yml 文件來構(gòu)建鏡像,你需要在該文件中對你的服務(wù)進行定義,然后使用 docker-compose build 命令。 假設(shè)你有一個 docker-compose.yml 文件,它定義了一個名為 “web” 的服務(wù),并指定了構(gòu)建該服務(wù)所需的 Dockerfile 的路徑,如下所示: 在這個例子中, build: . 指出 Dock

    2024年02月12日
    瀏覽(68)
  • 使用docker-compose部署RocketMQ5.x 單機部署+配置參數(shù)詳解

    使用docker-compose部署RocketMQ5.x 單機部署+配置參數(shù)詳解

    提前先拉取需要的鏡像文件,避免后面部署的時候出現(xiàn)鏡像拉取失敗的問題。 鏡像地址: https://hub.docker.com/r/apache/rocketmq/tags 我在部署的時候最新發(fā)行版是5.1.0可以根據(jù)需求自行選擇一個5.x的版本,部署流程不會有太大改變。 拉取最新版即可 這里使用compose v2版本 1、下載(使

    2024年02月08日
    瀏覽(47)
  • ERROR: Version in “./docker-compose.yml“ is unsupported

    ERROR: Version in “./docker-compose.yml“ is unsupported

    錯誤原因:------? ? ? ? ? ? ? docker-compose版本過低 解決方式: 直接改成3.3? 或者你保存信息中提到的版本號 首先要查看docker-compose的路徑 根據(jù)上一步的 whereis 找到了docker-compose的路徑為: /usr/bin/docker-compose ,所以下面的腳本,路徑也替換為這個就可以了。 下載 授權(quán) 版本號

    2024年02月16日
    瀏覽(57)
  • Docker部署RocketMQ5.x (單機部署+配置參數(shù)詳解+不使用docker-compose直接部署)

    Docker部署RocketMQ5.x (單機部署+配置參數(shù)詳解+不使用docker-compose直接部署)

    官網(wǎng)地址:https://rocketmq.apache.org/ 鏡像地址: https://hub.docker.com/r/apache/rocketmq/tags 我在部署的時候最新發(fā)行版是5.1.0可以根據(jù)需求自行選擇一個5.x的版本,部署流程不會有太大改變。 NameServer是一個簡單的 Topic 路由注冊中心,支持 Topic、Broker 的動態(tài)注冊與發(fā)現(xiàn),幾乎無狀態(tài)節(jié)點

    2024年02月06日
    瀏覽(28)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包