Docker學習筆記(五)堆

文中內容摘自Docker官網

提醒:請務必使用root帳號,以免在後面應用系統部署時,發生權限問題。

    這裏,你可以學會在多臺計算機部署相互關聯的多個服務。

添加新服務及重新部署

    添加服務可以通過配置 docker-compose.yml 文件來實現。首先,讓我們添加一個免費的可視化服務,讓我們看看我們的蜂羣是如何調度容器的。

    1、代開 docker-compose.yml 調整爲如下內容,並確保更新 username/repo:tag 映像。

version: "3"
services:
  web:
    # replace username/repo:tag with your name and image details
    image: username/repo:tag
    deploy:
      replicas: 5
      restart_policy:
        condition: on-failure
      resources:
        limits:
          cpus: "0.1"
          memory: 50M
    ports:
      - "80:80"
    networks:
      - webnet
  visualizer:
    image: dockersamples/visualizer:stable
    ports:
      - "8080:8080"
    volumes:
      - "/var/run/docker.sock:/var/run/docker.sock"
    deploy:
      placement:
        constraints: [node.role == manager]
    networks:
      - webnet
networks:
  webnet:

    這裏新增的內容是Visualizer節點。請注意兩項內容:volumes——給出可視化工具訪問主機的 docker 套接字文件,placement——確認僅以蜂羣管理員方式運行,而非工蜂。後面我們將會詳細談談這兩個參數。

    2. 激活 shell 的當前環境爲 myvm1 。

        運行 docker-machine ls 命令,列出所有計算機,並且確認 myvm1 虛擬機一行的 ACTIVE 列有個星號。若沒有星號,則可以參考我的另一篇博客中關於激活管理員一節內容 https://mp.csdn.net/postedit/85262481

    3. 在管理員上重新運行 docker stack deploy 命令更新服務。

docker stack deploy -c docker-compose.yml getstartedlab

    提示:執行上述命令時,當前目錄一定是docker-compose.yml所在目錄,該目錄不是虛擬機中的目錄,而是當前物理機的目錄。當然,如果你的虛擬機是嵌套虛擬機,那該目錄是頂級虛擬機的目錄。

    4. 查看可視化工具

    通過瀏覽器,可以查看:192.168.99.100:8080

    也可以通過下列命令查看所有的任務

docker stack ps getstartedlab

保存數據

    讓我們用相同的方式添加一個Redis數據庫用以保存應用的數據。

    1. 更新 docker-compose.yml ,添加Redis節點內容,具體如下:

version: "3"
services:
  web:
    # replace username/repo:tag with your name and image details
    image: username/repo:tag
    deploy:
      replicas: 5
      restart_policy:
        condition: on-failure
      resources:
        limits:
          cpus: "0.1"
          memory: 50M
    ports:
      - "80:80"
    networks:
      - webnet
  visualizer:
    image: dockersamples/visualizer:stable
    ports:
      - "8080:8080"
    volumes:
      - "/var/run/docker.sock:/var/run/docker.sock"
    deploy:
      placement:
        constraints: [node.role == manager]
    networks:
      - webnet
  redis:
    image: redis
    ports:
      - "6379:6379"
    volumes:
      - "/home/docker/data:/data"
    deploy:
      placement:
        constraints: [node.role == manager]
    command: redis-server --appendonly yes
    networks:
      - webnet
networks:
  webnet:

    2. 在 myvm1 虛擬機中創建保存數據用的data目錄

docker-machine ssh myvm1 "mkdir ./data"

    3. 執行 docker stack 命令更新服務

docker stack deploy -c docker-compose.yml getstartedlab

    4. 執行 docker service ls 命令,查看服務列表

root@ONE:/usr/local/docker# docker service ls
ID                  NAME                       MODE                REPLICAS            IMAGE                             PORTS
zsmhd7dpwgqs        getstartedlab_redis        replicated          1/1                 redis:latest                      *:6379->6379/tcp
uf6zm2skb2i2        getstartedlab_visualizer   replicated          1/1                 dockersamples/visualizer:stable   *:8080->8080/tcp
k68ah4kp4qft        getstartedlab_web          replicated          7/7                 mymole/test:part1                 *:4000->80/tcp

    5. 通過 192.168.99.100:4000查看網站,192.168.99.100:8080查看可視化工具

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章