亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2023年11月23日 09:04:12   作者:Jiahao_Lin  
這篇文章主要介紹了docker-compose.yml參數(shù)的用法(配置文件),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

docker-compose.yml參數(shù)的用法

簡單易懂

利用淳樸的配置文件風格介紹docker-compose.yml

#系統(tǒng)變量
$PWD : 當前目錄

#注意:YAML布爾值(true,false,yes,no,on,off)必須用引號括起來,以便解析器將它們解釋為字符串。
#字典時
environment:
  SHOW: 'true'
 數(shù)組時   
environment:
  - SHOW=true
#版本號
version: "2.1"
# 指定創(chuàng)建的虛擬網(wǎng)絡(luò)數(shù)量 
# 作用:通過不同的虛擬網(wǎng)絡(luò)實現(xiàn)了容器網(wǎng)絡(luò)之間的隔離,從而在最大程度上去保護后端網(wǎng)絡(luò)的安全。
#networks:
#  mynet:
#    driver: bridge
#  mynet1:


# 重用的代碼模板
# 模板的定義必須以 x- 開頭
x-logging:
	# 以 & 開頭的字符串為模板命名
	# 以 * 加上模板的名稱引用模板
  &default-logging
  driver: json-file
  options:
    max-size: "200k"
    max-file: "10"
    
# 定義全局掛載卷 
volumes:
  test_1.thinking.com:
  test_2.thinking.com:

# 服務(wù)
services: 

 #服務(wù)名稱
 todo:
	# 構(gòu)建鏡像
     build:
     	 # 指定dockerfile的上下文路徑(相對當前docker-compose.yml的位置)
     	 # 包含Dockerfile文件的目錄路徑,或者是git倉庫的URL。 
     	 # 當提供的值是相對路徑時,它被解釋為相對于當前compose文件的位置。 
     	 # 該目錄也是發(fā)送到Docker守護程序構(gòu)建鏡像的上下文。
       context: . 
       # Dockerfile的文件名稱
       dockerfile: Dockerfile-todo
       args:							
       	# 變量
        buildno: 1
        password: secret
       #  Dockerfile里面可使用的參數(shù)變量			
       #  Dockerfile:
       #	ARG buildno 
       #	ARG password
	   #	RUN echo "Build number: $buildno"
	   #	RUN script-requiring-password.sh "$password"
	  
     # 鏡像名 : 倉庫/標簽:版本
     image: zhanyang/todo-demo:1.0.0   
       
     # 依賴(以指定順序啟動)
     depends_on:  
       mysql:
         condition: service_healthy
         
     # 指定一個自定義容器名稱,而不是生成的默認名稱。
     # 由于Docker容器名稱必須是唯一的,因此如果指定了自定義名稱,則無法將服務(wù)擴展到多個容器。
     container_name: todo
     
     # 卷掛載路徑設(shè)置。
     # 可以設(shè)置宿主機路徑 (HOST:CONTAINER) 或加上訪問模式 (HOST:CONTAINER:ro)
     # 掛載數(shù)據(jù)卷的默認權(quán)限是讀寫(rw),可以通過ro指定為只讀。 
     volumes:
			 	# 只需指定一個路徑,讓引擎創(chuàng)建一個卷
			  - /var/lib/mysql
			 
			  # 指定絕對路徑映射
			  - /opt/data:/var/lib/mysql
			 
			  # 相對于當前compose文件的相對路徑
			  - ./cache:/tmp/cache
			 
			  # 用戶家目錄相對路徑
			  - ~/configs:/etc/configs/:ro
			 
			  # 命名卷
			  - datavolume:/var/lib/mysql
			  
			  # 使用全局掛載卷
			  - test_1.thinking.com:/test:rw
			  
		 # 指定日志驅(qū)動為 json-file,存儲日志的最大文件 size 為 200k,最多存儲 10 這樣大的文件。
		 # logging支持很多driver,而每一個driver對應(yīng)的options都不一樣
		 # docker inspect -f {{.HostConfig.LogConfig}} lnmp-nginx
		 # result:{json-file map[max-file:10 max-size:2000k]}
		 # docker info |grep 'Logging Driver'
		 # result:Logging Driver: json-file
		 # 其他:https://docs.docker.com/engine/admin/logging/overview/
 	logging:
      driver: "json-file"
      options:
        max-size: "200k"
        max-file: "10"
        
		# 指定使用的虛擬網(wǎng)絡(luò)
    networks: 
    #   - mynet
    
    # 覆蓋容器啟動后默認執(zhí)行的命令。 
    # 該命令也可以是一個類似于dockerfile的列表:command: ["bundle", "exec", "thin", "-p", "3000"]
    command: bundle exec thin -p 3000
    # may
    command: ["/usr/local/nginx/sbin/nginx"]
	
		# 鏈接到另一個服務(wù)中的容器。 請指定服務(wù)名稱和鏈接別名(SERVICE:ALIAS),或者僅指定服務(wù)名稱。
		# 實際是通過設(shè)置/etc/hosts的域名解析,從而實現(xiàn)容器間的通信。
		# 故可以像在應(yīng)用中使用localhost一樣使用服務(wù)的別名鏈接其他容器的服務(wù),前提是多個服務(wù)容器在一個網(wǎng)絡(luò)中可路由聯(lián)通
		# links也可以起到和depends_on相似的功能,即定義服務(wù)之間的依賴關(guān)系,從而確定服務(wù)啟動的順序
	links:
	   - db
	   - db:database
	   - redis
	   
	  # 鏈接到docker-compose.yml 外部的容器,甚至并非 Compose 管理的容器。參數(shù)格式跟 links 類似。
	 external
		 - redis_1
		 - project_db_1:mysql
		 - project_db_1:postgresql
		 
		# 暴露端口,但不映射到宿主機,只被連接的服務(wù)訪問。 僅可以指定內(nèi)部端口為參數(shù)
	 expose:
		 - "3000"
		 - "8000"
		 
		# 暴露端口信息。使用宿主:容器 (HOST:CONTAINER)格式或者僅僅指定容器的端口(宿主將會隨機選擇端口)都可以。
	 ports:
		 - "3000"
		 - "3000-3005"
		 - "8000:8000"
		 - "9090-9091:8080-8081"
		 - "49100:22"
		 - "127.0.0.1:8001:8001"
		 - "127.0.0.1:5000-5010:5000-5010"
		 - "6060:6060/udp"
		# v3.2中ports的長格式的語法允許配置不能用短格式表示的附加字段。
	 ports:
		  - target: 80 #容器內(nèi)的端口 
		    published: 8080 #物理主機的端口 
		    protocol: tcp #端口協(xié)議(tcp或udp) 
		    mode: host #host 和ingress 兩總模式,host用于在每個節(jié)點上發(fā)布主機端口,ingress 用于被負載平衡的swarm模式端口。
		
	# no是默認的重啟策略,在任何情況下都不會重啟容器。  
	restart: "no"
	# 指定為always時,容器總是重新啟動。
	restart: always 
	# 如果退出代碼指示出現(xiàn)故障錯誤,則on-failure將重新啟動容器。
	restart: on-failure
	restart: unless-stopped
	
	  
	# pid 將PID模式設(shè)置為主機PID模式。
	# 這就打開了容器與主機操作系統(tǒng)之間的共享PID地址空間。 
	# 使用此標志啟動的容器將能夠訪問和操作裸機的命名空間中的其他容器,反之亦然。
	# 即打開該選項的容器可以相互通過進程 ID 來訪問和操作。
	pid: "host"
	
	# 配置 DNS 服務(wù)器??梢允且粋€值,也可以是一個列表。
	dns: 8.8.8.8
	dns:
	  - 8.8.8.8
	  - 9.9.9.9
	  
	# 自定義搜索域
	dns_search: example.com
	dns_search:
	  - dc1.example.com
	  - dc2.example.com
	  
	# 覆蓋Dockerfile中的entrypoint,用法同Dockerfile中的用法
	entrypoint: ["/usr/local/nginx/sbin/nginx","-g","daemon off;"]
	
	# 添加環(huán)境變量。 你可以使用數(shù)組或字典兩種形式。
	# 任何布爾值; true,false,yes,no需要用引號括起來,以確保它們不被YML解析器轉(zhuǎn)換為True或False。 
	environment:
	  RACK_ENV: development
	  SHOW: 'true'
	  SESSION_SECRET:
	# 【注意】:如果你的服務(wù)指定了build選項,那么在構(gòu)建過程中通過environment定義的環(huán)境變量將不會起作用。
	# 將使用build的args子選項來定義構(gòu)建時的環(huán)境變量。

	environment:
	  - RACK_ENV=development
	  - SHOW=true
	  - SESSION_SECRE
	  
	# 1>將定義的變量編寫在文件中,然后在yml文件中進行添加 
	env_file: .env
	env_file:
	  - ./common.env
	  - ./apps/web.env
	  - /opt/secrets.env
		  
	# 2>例如:
	# old:
		db:
	    image: mysql
	    ports:
	      - "3306:3306"
	    environment:
	      MYSQL_ROOT_PASSWORD: redhat
	      MYSQL_DATABASE: wordpress
	      MYSQL_USER: wordpress
	      MYSQL_PASSWORD: wordpress
	      
    # new:
		db:
		   image: mysql
		   ports:
		      - "3306:3306"
		   env_file: ./mysql_env
    
	  # 創(chuàng)建env_file文件在當前目錄mysql_env
		 MYSQL_ROOT_PASSWORD=redhat
		 MYSQL_DATABASE=wordpress
		 MYSQL_USER=wordpress
		 MYSQL_PASSWORD=wordpress3
		
    # 添加hostname映射,類似于docker cli下面的--add-host
	extra_hosts:
     - "www.hcstart.com:192.168.101.14"
 
    # 配置一個檢查去測試服務(wù)中的容器是否運行正常  
    # 具體: https://docs.docker.com/engine/reference/builder/#healthcheck
    # 查看healthcheck的狀態(tài)輸出 : docker inspect lnmp-nginx
    healthcheck:
      test: ["CMD", "curl", "-f", "http://localhost"]
      interval: 1m30s
      timeout: 10s
      retries: 3
	
    #  labels:添加元數(shù)據(jù)到container中,查看現(xiàn)有容器的labels:
	#  docker inspect -f {{.Config.Labels}} lnmp-nginx # lnmp-nginx :容器名
	labels:
	  com.example.description: "Accounting webapp"
	  com.example.department: "Finance"
	  com.example.label-with-empty-value: ""
	labels:
	  - "com.example.description=Accounting webapp"
	  - "com.example.department=Finance"
	  - "com.example.label-with-empty-value"
	
	# 在容器中設(shè)置內(nèi)核參數(shù)
    sysctls:
	     net.core.somaxconn: 1024
	     net.ipv4.tcp_syncookies: 0

	sysctls:
	    - net.core.somaxconn=1024
	    - net.ipv4.tcp_syncookies=0
	    
	    
mysql:
     environment:
       MYSQL_ROOT_PASSWORD: password
       MYSQL_DATABASE: tododb
       MYSQL_USER: user
       MYSQL_PASSWORD: pass
     build:
       context: .
       dockerfile: Dockerfile-mysql
     image: zhanyang/mysql:5.6
     container_name: mysql
     # 以 * 加上模板的名稱引用模板     使用全局自定義模板
     logging: *default-logging
 	 # 指定使用的虛擬網(wǎng)絡(luò)
     networks: 
     #  - mynet1

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論