Docker Compose:定義和運(yùn)行多個容器,批量容器編排
Dockerfile:讓程序在任何地方運(yùn)行
下載安裝
//下載
curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.5/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
//授權(quán)
sudo chmod +x /usr/local/bin/docker-compose
初體驗(yàn)
1.自己的應(yīng)用
2.Dockerfile 將自己的應(yīng)用打包成鏡像
3.Docker-compose.yml文件,(定義整個服務(wù),需要的環(huán)境,web,redis)堪夭,完整的上線服務(wù)
4.啟動compose項(xiàng)目(docker-compose up)
mkdir composetest
cd composetest
//黃健一個python應(yīng)用
vim app.py
//文件內(nèi)容
import time
import redis
from flask import Flask
app = Flask(__name__)
cache = redis.Redis(host='redis', port=6379)
def get_hit_count():
retries = 5
while True:
try:
return cache.incr('hits')
except redis.exceptions.ConnectionError as exc:
if retries == 0:
raise exc
retries -= 1
time.sleep(0.5)
@app.route('/')
def hello():
count = get_hit_count()
return 'Hello World! I have been seen {} times.\n'.format(count)
//創(chuàng)建依賴文件
vim requirements.txt
//文件內(nèi)容
flask
redis
//創(chuàng)建Dockerfile
//文件內(nèi)容
# syntax=docker/dockerfile:1
FROM python:3.7-alpine
WORKDIR /code
ENV FLASK_APP=app.py
ENV FLASK_RUN_HOST=0.0.0.0
RUN apk add --no-cache gcc musl-dev linux-headers
COPY requirements.txt requirements.txt
RUN pip install -r requirements.txt
EXPOSE 5000
COPY . .
CMD ["flask", "run"]
//創(chuàng)建docker-compose.yml文件
docker-compose.yml
//文件內(nèi)容
version: "3.9"
services:
web:
build: .
ports:
- "5000:5000"
redis:
image: "redis:alpine"
會發(fā)現(xiàn)這里啟動了docker-compose.yml里面的兩個服務(wù)
默認(rèn)的容器名(number是一個副本,服務(wù)不可能只有一個運(yùn)行實(shí)例,彈性马昙,高并發(fā),刹悴,):文件名服務(wù)名_number
網(wǎng)絡(luò)規(guī)則:通過compose創(chuàng)建的服務(wù)都在同一個網(wǎng)絡(luò)下面行楞,
mysql(ip):3306
redis(ip):6379
//兩處一致
docker-compose down || ctrl + c
docker-compose-yml 配置文件編寫
知道地址:
https://docs.docker.com/compose/compose-file/#compose-file-structure-and-examples
version: ' ' #版本
services: #服務(wù)
service1: web
images
build
network
service2: redis
network:
networks:
configs:
一鍵部署開源項(xiàng)目
1.mkdir my_wordpress
2.cd my_wordpress/
3.vim docker-compose.yml
version: "3.9"
services:
db:
image: mysql:5.7
volumes:
- db_data:/var/lib/mysql
restart: always
environment:
MYSQL_ROOT_PASSWORD: somewordpress
MYSQL_DATABASE: wordpress
MYSQL_USER: wordpress
MYSQL_PASSWORD: wordpress
wordpress:
depends_on:
- db
image: wordpress:latest
volumes:
- wordpress_data:/var/www/html
ports:
- "8000:80"
restart: always
environment:
WORDPRESS_DB_HOST: db
WORDPRESS_DB_USER: wordpress
WORDPRESS_DB_PASSWORD: wordpress
WORDPRESS_DB_NAME: wordpress
volumes:
db_data: {}
wordpress_data: {}
4.docker-compose up -d
編寫自己的為服務(wù)上線
編寫自己的為服務(wù)
編寫Dockerfile構(gòu)建鏡像
編寫docker-compose.yml
打包
//Dockerfile
FROM java:8
COPY *.jar /app.jar
CMD ["--server.port=8080"]
EXPOSE 8080
ENTRYPOINT ["java","-jar","/app.jar"]
//docker-compose.yml
version: '3.3'
services:
kuangapp:
build: .
image: kuangapp
depends_on:
- redis
redis:
image: "library/redis:alpine"
docker swarm
1.首先購買四太服務(wù)器,然后連接
2.然后右鍵命令發(fā)布到所有會話
3.安裝docker
4.啟動docker
https://docs.docker.com/engine/swarm/
docker swarm --help
//初始化一個節(jié)點(diǎn),會得到遺傳命令土匀,可以讓其他節(jié)點(diǎn)加入這個集群里面
docker swarm init --advertise-addr self_ip
//生成加入集群的命令
docker swarm join-token worker
docker swarm join-token manager
//其他節(jié)點(diǎn)使用上面的命令添加進(jìn)去
docker node ls
Raft(一致性協(xié)議)
雙主雙從:假設(shè)一個節(jié)點(diǎn)掛了子房,其他節(jié)點(diǎn)是否可以用
Raft協(xié)議:保證大多數(shù)節(jié)點(diǎn)存活才可以用,只要》1就轧,集群至少大于3臺
實(shí)驗(yàn):將一臺主節(jié)點(diǎn)停掉证杭,會發(fā)現(xiàn)另一臺主節(jié)點(diǎn)也不可用了
將一臺節(jié)點(diǎn)離開,再從其他節(jié)點(diǎn)查看節(jié)點(diǎn)狀態(tài)(需要一定時間)妒御,