自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

IT工程師都需要掌握的容器技術(shù)之DockerCompose

開發(fā) 前端
今天我們繼續(xù)來(lái)學(xué)習(xí)Docker技術(shù)之Docker Compose,本篇文章將是我們?nèi)萜骷夹g(shù)系列的最后一篇文章,讀過(guò)我們?nèi)萜骷夹g(shù)全系列文章的小伙伴肯定有疑問,整個(gè)系列文章容器集群技術(shù)還沒講,我們?cè)谶@邊先做個(gè)預(yù)告容器集群我們將在后面K8S系列教程中進(jìn)行詳細(xì)講解,請(qǐng)大家拭目以待。

今天我們繼續(xù)來(lái)學(xué)習(xí)Docker技術(shù)之Docker Compose,本篇文章將是我們?nèi)萜骷夹g(shù)系列的最后一篇文章,讀過(guò)我們?nèi)萜骷夹g(shù)全系列文章的小伙伴肯定有疑問,整個(gè)系列文章容器集群技術(shù)還沒講,我們?cè)谶@邊先做個(gè)預(yù)告容器集群我們將在后面K8S系列教程中進(jìn)行詳細(xì)講解,請(qǐng)大家拭目以待,好了今天就開始我們今天的課程吧!

[[353968]]

01 Docker Compose簡(jiǎn)介

Docker Compose是用于創(chuàng)建和運(yùn)行多容器應(yīng)用程序的工具,通過(guò)Compose可以使用YAML配置文件來(lái)設(shè)置應(yīng)用程序的服務(wù),通過(guò)YAML配置文件來(lái)描述多個(gè)容器服務(wù)以及之間的關(guān)聯(lián),然后通過(guò)命令根據(jù)配置啟動(dòng)所有的容器。Compose與Dockerfile的區(qū)別在于Dockerfile 可以定義一個(gè)容器,而一個(gè) Compose 的模板文件(YAML 格式)可以定義一個(gè)包含多個(gè)相互關(guān)聯(lián)容器的應(yīng)用。Compose 項(xiàng)目是使用python編寫的,如果對(duì)其源碼感興趣的朋友可以到github搜索Compose項(xiàng)目。

02 Docker Compose使用步驟

使用Docker Compose具有如下三個(gè)基本步驟:

1)定義容器應(yīng)用的Dockerfile文件

2)定義組成應(yīng)用程序的服務(wù),一般為定義 docker-compose.yml 文件

3)通過(guò)docker-compose啟動(dòng)所有應(yīng)用

docker-compose.yml的配置格式如下所示:

 

  1. 1. # 指定本compose文件依從的compose哪個(gè)版本制定的   
  2. 2. version: "3.8"   
  3. 3. # 指定包含的服務(wù)   
  4. 4. services:   
  5. 5.   web: # 指定web服務(wù)名稱   
  6. 6.     build: .   # 從當(dāng)前目錄的dockerfile文件build鏡像   
  7. 7.     ports:  # 指定端口映射   
  8. 8.       - "5000:5000"   
  9. 9.     volumes: # 指定卷的掛載   
  10. 10.       - .:/code   
  11. 11.       - logvolume01:/var/log   
  12. 12.     links: # 將指定容器連接到當(dāng)前連接可以設(shè)置別名,避免ip方式導(dǎo)致的容器重啟動(dòng)態(tài)改變的無(wú)法連接情況   
  13. 13.       - redis   
  14. 14.   redis: # 指定redis服務(wù)名稱   
  15. 15.     image: redis # 指定redis服務(wù)的鏡像名稱   
  16. 16. volumes:   
  17. 17.   logvolume01: {}   

 

目前有三種版本的Compose文件格式,分別為version1、version2及version3,每個(gè)compose版本支持的docker版本如下:

 

IT工程師都需要掌握的容器技術(shù)之DockerCompose

 

03 Docker Compose安裝

Compose 需要單獨(dú)安裝,我們需要從GitHub上下載 Docker Compose 二進(jìn)制文件具體操作如下,從GitHub下載慢的可以通過(guò)阿里云進(jìn)行下載。

 

IT工程師都需要掌握的容器技術(shù)之DockerCompose

 

下載成功后,為了能夠直接使用該可執(zhí)行文件執(zhí)行命令,一般將其放入 $PATH 的環(huán)境變量支持的路徑中,并添加可執(zhí)行權(quán)限,因?yàn)槲覀兿螺d的時(shí)候已經(jīng)指定了環(huán)境變量所以不需要再指定,具體操作如下。

 

 

添加完權(quán)限后就可以執(zhí)行docker-compose命令了,如果執(zhí)行報(bào)錯(cuò)可以在自己的環(huán)境變量中添加docker-compose路徑。

 

IT工程師都需要掌握的容器技術(shù)之DockerCompose

 

04 Docker Compose使用示例

我們使用Docker Compose創(chuàng)建一個(gè)web應(yīng)用程序,應(yīng)用程序包含兩個(gè)容器,一個(gè)是web容器一個(gè)是redis容器,web容器提供web服務(wù),redis容器用于記錄Web被訪問的次數(shù),構(gòu)建web應(yīng)用程序目錄如下:

 

IT工程師都需要掌握的容器技術(shù)之DockerCompose

 

首先我們編寫我們的web app應(yīng)用,我們通過(guò)python的tornado框架構(gòu)建我們的應(yīng)用,上圖中的tornado_web.py就是我們構(gòu)建好的tornado應(yīng)用,內(nèi)如具體如下

 

  1. 1. #!/usr/bin/env python   
  2. 2. # -*- coding:utf-8 -*-   
  3. 3.    
  4. 4. # 引入redis與tornado模塊   
  5. 5. import redis   
  6. 6. import tornado.ioloop   
  7. 7. import tornado.web   
  8. 8.    
  9. 9. # 定義redis操作類   
  10. 10. class RdisOperate():   
  11. 11.   
  12. 12.     @staticmethod   
  13. 13.     def get_value():   
  14. 14.         redis_ins = redis.Redis(host='redis', port=6379)   
  15. 15.         # 對(duì)total之進(jìn)行+1操作   
  16. 16.         redis_ins.incr("total")   
  17. 17.         return redis_ins.get("total")   
  18. 18.    
  19. 19.    
  20. 20. class MainHandler(tornado.web.RequestHandler):   
  21. 21.     def get(self):   
  22. 22.         self.write("登錄成功,本頁(yè)面已被訪問{}次".format(RdisOperate.get_value()))   
  23. 23.    
  24. 24.    
  25. 25. def make_app():   
  26. 26.     return tornado.web.Application([   
  27. 27.         (r"/", MainHandler),   
  28. 28.     ])   
  29. 29.    
  30. 30.    
  31. 31. if __name__ == "__main__":   
  32. 32.     app = make_app()   
  33. 33.     # 讓app監(jiān)聽在8000端口   
  34. 34.     app.listen(8000)   
  35. 35.     tornado.ioloop.IOLoop.current().start()   

 

然后我們創(chuàng)建requirements.txt文件,通過(guò)該文件安裝python的依賴包,具體如下

 

IT工程師都需要掌握的容器技術(shù)之DockerCompose

 

接著我們創(chuàng)建web app鏡像構(gòu)建的dockerfile文件,文件內(nèi)容具體如下

 

  1. 1. # 拉取python3.7的鏡像   
  2. 2. FROM python:3.7   
  3. 3. # 設(shè)置工作目錄   
  4. 4. WORKDIR /web   
  5. 5. # 將web目錄的文件拷貝到容器web目錄   
  6. 6. COPY ./ /web/   
  7. 7. # 安裝python依賴包   
  8. 8. RUN pip install -r requirements.txt   
  9. 9. # 運(yùn)行web app   
  10. 10. CMD python tornado_web.py   

 

最后我們編寫docker-compose.yml文件用來(lái)構(gòu)建web應(yīng)用

 

  1. 1. version: '3.8'   
  2. 2.    
  3. 3. services:   
  4. 4.   redis:   
  5. 5.     image: redis   
  6. 6.   web:   
  7. 7.     build:   
  8. 8.       context: /root/docker_compose_app/web_app/web   
  9. 9.     depends_on:   
  10. 10.     - redis   
  11. 11.     ports:   
  12. 12.     - 8888:8000/tcp   
  13. 13.     volumes:   
  14. 14.     - /root/docker_compose_app/web_app/web:/web:rw   

 

現(xiàn)在我們通過(guò)docker-compose來(lái)運(yùn)行web應(yīng)用程序,同時(shí)看看頁(yè)面是否可以訪問,具體如下:

 

IT工程師都需要掌握的容器技術(shù)之DockerCompose

 

 

IT工程師都需要掌握的容器技術(shù)之DockerCompose

 

 

IT工程師都需要掌握的容器技術(shù)之DockerCompose

 

責(zé)任編輯:華軒 來(lái)源: 今日頭條
相關(guān)推薦

2020-11-03 16:42:46

容器Dockerfile技術(shù)

2020-10-26 15:11:50

Docker容器IT

2020-10-19 09:32:49

容器Docker管理

2020-10-27 10:52:37

Docker容器存儲(chǔ)

2010-08-10 13:22:41

2020-03-17 15:15:49

Python工程師面試題

2020-07-22 14:50:35

Python數(shù)據(jù)分析庫(kù)

2022-08-12 09:21:43

前端JavaScript代碼

2020-08-05 08:25:58

大數(shù)據(jù)Java技術(shù)

2021-03-31 22:25:46

運(yùn)維工程師技能

2017-09-22 08:33:34

機(jī)器學(xué)習(xí)Web設(shè)計(jì)UI

2013-08-15 09:47:27

企業(yè)網(wǎng)絡(luò)簡(jiǎn)化網(wǎng)絡(luò)工程師

2010-08-10 13:29:58

軟件工程師

2012-03-31 16:57:52

工程師創(chuàng)業(yè)團(tuán)隊(duì)

2021-03-09 10:47:56

系統(tǒng)架構(gòu)師算法工程師人工智能工程師

2009-12-18 10:08:47

路由器協(xié)議

2017-03-30 16:03:06

Linux運(yùn)維工程師技能

2013-12-23 09:09:29

網(wǎng)絡(luò)工程師技術(shù)愿望2014

2021-03-24 15:15:34

數(shù)據(jù)工程師開發(fā)工具

2021-03-09 10:24:46

數(shù)學(xué)計(jì)算機(jī)系統(tǒng)架構(gòu)師
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)