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

溫馨提示×

溫馨提示×

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

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

【1小時記住Docker常用命令】Docker學以致用

發布時間:2020-08-05 17:04:09 來源:網絡 閱讀:2587 作者:wx5b3c0a4298f7b 欄目:云計算

Docker是一個開源的應用容器引擎,將應用以及依賴打包到一個可移植的鏡像中,然后發布到服務器上,并且可以實現虛擬化,有助于快捷高效的交付應用。


Docker三個核心概念:

l?鏡像Image,應用和依賴打包生成的文件,類似安裝包。

l?容器Container,鏡像創建運行應用的示例。

l?倉庫Repository,Docker存放鏡像文件的地方。


資源編排Docker-compose定義和運行多個容器組成的應用系統,通過docker-compose.yml文件聲明各個服務,作為一個整體來完成應用的創建和啟動。


Swarm是Docker官方提供的集群管理工具,將Docker節點統一管理組織,以服務為調度單元,支持動態擴容等特性,和Kubernetes(k8s)相比,更加輕量。


內容目錄:

l?Docker常用命令:鏡像、容器、網絡、數據卷

l?Dockerfile示例和常用指令

l?資源編排docker-compose常用命令

l?docker-compose.yml示例和常用指令

l?集群部署Swarm常用命令

l?使用技巧

n?logs命令結合grep格式化日志信息

n?prune命令清理Docker系統垃圾

l?部署實例

n?Docker啟動nginx

n?資源編排Web服務

n?集群部署Web服務


Docker安裝:

https://docs.docker.com/install/linux/docker-ce/ubuntu/

https://docs.docker.com/docker-for-windows/install/


代碼下載:

https://github.com/rickding/HelloDocker

https://github.com/jextop/StarterDeploy


Docker常用命令:鏡像、容器、網絡、數據卷

【1小時記住Docker常用命令】Docker學以致用

【1小時記住Docker常用命令】Docker學以致用


Dockerfile示例:

Dockerfile是鏡像描述文件,包含了一條條的指令,每一條指令構建一層,因此每一條指令的內容,就是描述該層應當如何構建。Dockerfile基本結構:

- 基礎鏡像

- 維護者信息

- 鏡像構建指令

- 容器啟動時執行指令

FROM node:8

LABEL maintainer="Jext Community, https://github.com/rickding/HelloDocker"

# copy files
COPY . /usr/node/
WORKDIR /usr/node/

# launch service
CMD ["node", "hello.js"]

EXPOSE 8010


Dockerfile常用指令:

【1小時記住Docker常用命令】Docker學以致用?


Docker-compose資源編排常用命令:

【1小時記住Docker常用命令】Docker學以致用

docker-compose.yml示例:

資源編排文件定義了版本信息、services服務配置、networks網絡信息、volumes卷信息,包含每個服務啟動的容器配置

version: '3'
services:
????db:
????????hostname: db
????????
image: mysql:5
????????
command: --default-authentication-plugin=mysql_native_password
????????ports:
????????????- 3306:3306
????????
environment:
????????????MYSQL_DATABASE: starter
????????????
MYSQL_ROOT_PASSWORD: root

????
api:
????????
image: starter_api:latest
????????
build: .
????????ports:
????????????- 8011:8011
????????
depends_on:
????????????- db


docker-compose.yml常用指令:

【1小時記住Docker常用命令】Docker學以致用

【1小時記住Docker常用命令】Docker學以致用

【1小時記住Docker常用命令】Docker學以致用

Swarm集群部署常用命令:

【1小時記住Docker常用命令】Docker學以致用


logs日志查看技巧

日志在系統運行中至關重要,開發測試以及運維通過系統日志分析查找故障原因。logs命令結合grep格式化日志信息:

docker-compose logs -ft |?grep --color -i -e error -e warn -e version -e exception

【1小時記住Docker常用命令】Docker學以致用

Docker三劍客logs命令整理如下:

【1小時記住Docker常用命令】Docker學以致用

【1小時記住Docker常用命令】Docker學以致用


Docker prune清理系統垃圾

Docker基于Linux內核通過操作系統和虛擬容器調用CGroup, Namespace等系統接口完成資源的分配與相互隔離,基本架構如下:

【1小時記住Docker常用命令】Docker學以致用

Docker依賴系統資源運行,分配回收過程中會產生一些垃圾,比如docker stop容器后沒有執行docker rm刪除運行docker system df查看資源信息,RECLAIMABLE是可回收比例:

?【1小時記住Docker常用命令】Docker學以致用

增加選項-v將顯示詳情:docker system df -v

?【1小時記住Docker常用命令】Docker學以致用

使用技巧:運行prune命令清理垃圾并釋放資源

docker system prune?--volumes

【1小時記住Docker常用命令】Docker學以致用

Docker提供的prune命令整理如下:

【1小時記住Docker常用命令】Docker學以致用

【1小時記住Docker常用命令】Docker學以致用


實例1:Docker啟動nginx

l?代碼:https://github.com/rickding/HelloDocker/tree/master/nginx

配置和腳本文件:

├── docker-compose.yml

├── build.sh

├── run.sh

├── stop.sh

l?Dockerfile基于nginx鏡像添加網頁和配置文件:

FROM nginx:stable

# web files
COPY ./web/ /usr/share/nginx/html

# config
COPY ./conf/nginx.conf /etc/nginx/nginx.conf
COPY ./conf/conf.d /etc/nginx/conf.d

WORKDIR /etc/nginx

EXPOSE 80

l?構建鏡像執行腳本./build.sh或命令docker build -t nginx:latest .

l?啟動容器實例執行腳本./run.sh或命令docker run -it --name nginx -p 80:80 -d nginx:latest

l?訪問http://localhost:80/,看到頁面:

【1小時記住Docker常用命令】Docker學以致用?

l?停止刪除實例執行腳本./stop.sh或命令docker stop nginx && docker rm nginx


實例2:資源編排Web服務

l?代碼:https://github.com/jextop/StarterDeploy

配置和腳本文件:

├── docker-compose.yml

├── pull.sh

├── up.sh

├── logs.sh

├── down.sh

l?docker-compose.yml部署Web服務依賴的多個容器實例,數據庫、緩存、消息隊列、日志系統、API接口和Web管理后臺:

version: '3'
services:
????db:
????????hostname: db
????????image: mysql:5
????????command: --default-authentication-plugin=mysql_native_password
????????ports:
????????????- 3306:3306
????????environment:
???????????MYSQL_DATABASE: starter
???????????MYSQL_ROOT_PASSWORD: root

????cache:
????????hostname: cache
????????image: redis:4
????????command: redis-server --appendonly yes
????????ports:
????????????- 6379:6379

????mq:
????????hostname: mq
????????image: webcenter/activemq:latest
????????ports:
????????????- 61616:61616
????????????- 8161:8161

????elasticsearch:
????????hostname: elasticsearch
????????image: elasticsearch:latest
????????ports:
????????????- 9200:9200
????????????- 9300:9300

????log:
????????hostname: log
????????image: registry.cn-shanghai.aliyuncs.com/hellodock/logstash:7.5.2
????????ports:
????????????- 9600:9600
????????????- 9601:9601
????????depends_on:
????????????- elasticsearch

????db_admin:
????????image: adminer:latest
????????ports:
????????????- 3006:8080
????????depends_on:
????????????- db

????api:
????????image: registry.cn-shanghai.aliyuncs.com/jext/starter_api:latest
????????ports:
????????????- 8011:8011
????????depends_on:
????????????- db
????????????- cache
????????????- mq
????????????- log

????admin:
????????image: registry.cn-shanghai.aliyuncs.com/jext/starter_admin:latest
????????ports:
????????????- 8010:8010
????????depends_on:
????????????- api

l?啟動Web服務執行腳本./up.sh或命令:docker-compose up -d

l?查看運行實例:docker-compose ps

l?查看日志執行腳本./logs.sh或命令docker-compose logs -ft

l?http://127.0.0.1:8010/,看到頁面:

【1小時記住Docker常用命令】Docker學以致用?

l?停止和刪除服務執行腳本./down.sh或命令docker-compose down --remove-orphans


實例3:集群部署Web服務

l?代碼:https://github.com/jextop/StarterDeploy

配置和腳本文件:

├── docker-compose.yml

├── pull.sh

├── deploy.sh

├── rm.sh

l?docker-compose.yml增加deploy屬性,replicas指定副本數量,placement指定docker節點:

deploy:
????replicas: 1
????# placement:
????# ????constraints: [node.labels.group == api]

l?啟動Swarm加入節點構建集群,首個節點自動成為管理員:docker swarm init

l?部署Web服務:執行腳本./deploy.sh或命令:docker stack deploy -c docker-compose.yml starter

【1小時記住Docker常用命令】Docker學以致用?

l?查看Stack和服務:docker stack ls && docker service ls

【1小時記住Docker常用命令】Docker學以致用?

l 停止刪除服務:執行腳本./rm.sh或命令docker stack rm starter

【1小時記住Docker常用命令】Docker學以致用

向AI問一下細節

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

AI

阜康市| 吴川市| 洞口县| 临潭县| 西青区| 石泉县| 阳新县| 磐石市| 六枝特区| 卓尼县| 鸡泽县| 宣汉县| 阳城县| 临湘市| 巩留县| 阳谷县| 商城县| 石嘴山市| 阜城县| 西华县| 淮阳县| 株洲县| 沾益县| 绥德县| 响水县| 康保县| 金昌市| 壶关县| 霍城县| 长顺县| 江口县| 武山县| 旺苍县| 禹州市| 杨浦区| 克拉玛依市| 秦皇岛市| 无极县| 星座| 宜兰县| 桦南县|