前段時(shí)間做了個(gè)node
全棧項(xiàng)目级及,服務(wù)端技術(shù)棧是 nginx
+ koa
+ postgresql
粘拾。其中在centos
上搭建環(huán)境和部署都挺費(fèi)周折,部署測(cè)試服務(wù)器创千,接著上線的時(shí)候又部署生產(chǎn)環(huán)境服務(wù)器缰雇。這中間就有很多既無(wú)聊又費(fèi)精力,吃力不討好的"體力活"追驴。所以就開(kāi)始思考怎么自動(dòng)化這部分搭建部署的工作械哟,也就引出了Docker
。
什么是Docker
Docker
是比虛擬機(jī)還要輕量級(jí)的虛擬化技術(shù)殿雪,它虛擬化的實(shí)體就叫做容器暇咆。容器本身就是一個(gè)隔離了作用域的sandbox
,同時(shí)它只包含了基礎(chǔ)庫(kù)和本身承載的服務(wù)丙曙,非常精簡(jiǎn)爸业。容器運(yùn)行起來(lái)后就只是宿主機(jī)中的一個(gè)進(jìn)程而已,占用的資源是非常小的亏镰,這就為操作系統(tǒng)上運(yùn)行容器集群創(chuàng)造了條件扯旷,可操作性和靈活性極佳。
鏡像和容器又是什么關(guān)系呢索抓?可以把鏡像看成是類(class
)钧忽,容器看成對(duì)象(object
),容器是由鏡像實(shí)例化產(chǎn)生出來(lái)的逼肯,當(dāng)然一個(gè)鏡像可以生成多個(gè)容器耸黑。
客戶端Docker
如果不在服務(wù)器,我們?cè)诳蛻舳艘趺词褂?Docker
呢篮幢?在 Windows
和 OSX
上可以使用 Docker Desktop
大刊,再加上Kitematic
,這兩個(gè)都是桌面管理工具三椿,常規(guī)的操作方面非常便利缺菌。Docker Desktop
和 Kitematic
只是可視化了部分操作曲尸,命令行還是必備的,因?yàn)楹芏嗖僮饕仓荒苊钚胁判小?/p>
Docker基本操作
鏡像名稱
關(guān)于鏡像標(biāo)簽男翰,比如nginx:1.19.0-alpine
另患,1.19.0是 nginx
的版本號(hào),alpine
是os的代號(hào)蛾绎。
Jessie: debian 8
Stretch: debian 9
Buster: debian 10
Alpine: alpine昆箕,推薦使用,因?yàn)轶w積非常小
Alpine
是體積最小的一個(gè)版本租冠,有些甚至是其他版本的四分之一鹏倘。這意味著構(gòu)建鏡像更快,運(yùn)行效率更高顽爹,因?yàn)榧虞d的組件更加少纤泵,無(wú)形中也意味著漏洞更少更安全。
拉取鏡像
docker pull nginx:1.19.0-alpine
啟動(dòng)容器
--name web:指定容器名稱為web
-p 8080:80: 容器nginx監(jiān)聽(tīng)端口為80镜粤,映射到本地端口8080
-v xxxx:xxxx:這里是用本地配置文件映射到容器nginx配置文件
-d:后臺(tái)運(yùn)行
nginx:1.19.0-alpine:使用的鏡像
docker run --name web -p 8080:80 -v /usr/etc/nginx/nginx.conf:/etc/nginx/nginx.conf:ro -d nginx:1.19.0-alpine
其他操作
docker images #顯示鏡像
docker rmi xxx #刪除鏡像
docker ps #顯示運(yùn)行的容器
docker rm xxx #刪除容器
Dockerfile
構(gòu)建鏡像比較方便的是使用Dockerfile
捏题,它就是鏡像的配置文件,只要有Dockerfile
肉渴,隨時(shí)可以構(gòu)建鏡像公荧。如下就是構(gòu)建一個(gè)非常簡(jiǎn)單的nginx
鏡像,from
就是構(gòu)建時(shí)使用的基礎(chǔ)鏡像:
FROM nginx
COPY nginx.conf /etc/nginx/nginx.conf
Docker-compose
當(dāng)我們的項(xiàng)目不僅只有單個(gè)容器同规,而是需要運(yùn)行多個(gè)容器循狰,而且容器之間還需要互相通信的時(shí)候,就需要更強(qiáng)大的管理工具了券勺。比如k8s
绪钥,但我們目前的小項(xiàng)目使用官方自帶的Docker-compose
已經(jīng)足矣。
首先需要docker-compose.yml
配置文件关炼,比如下面就是兩個(gè)容器的模板程腹,image
表示使用的鏡像,ports
則表示端口映射盗扒,volumes
則是需要映射的數(shù)據(jù)卷:
version: "3"
services:
webapp:
image: web
ports:
- "8080:80"
volumes:
- "/data"
redis:
image: "redis:alpine"
接著可以使用以下命令行進(jìn)行操作:
docker-compose build [options] [SERVICE...] #構(gòu)建(重新構(gòu)建)項(xiàng)目中的服務(wù)容器
docker-compose up -d # 運(yùn)行 compose 項(xiàng)目,后臺(tái)執(zhí)行
docker-compose up
是個(gè)非常強(qiáng)大的命令跪楞,它將嘗試自動(dòng)完成包括構(gòu)建鏡像缀去,(重新)創(chuàng)建服務(wù)侣灶,啟動(dòng)服務(wù),并關(guān)聯(lián)服務(wù)相關(guān)容器的一系列操作缕碎。鏈接的服務(wù)都將會(huì)被自動(dòng)啟動(dòng)褥影,除非已經(jīng)處于運(yùn)行狀態(tài)∮酱疲可以說(shuō)凡怎,大部分時(shí)候都可以直接通過(guò)該命令來(lái)啟動(dòng)一個(gè)項(xiàng)目校焦。
構(gòu)建nginx-node-postgres項(xiàng)目
有了上面的基礎(chǔ),接著就可以構(gòu)建我們自己的項(xiàng)目了统倒,首先是node
服務(wù)的dockerfile
寨典,主要做了如下步驟
- 創(chuàng)建容器工作目錄
- 復(fù)制相關(guān)配置文件到容器
- 在容器安裝
npm
包 - 運(yùn)行
pm2
啟動(dòng)容器
FROM node:14.5.0-alpine3.12
# 工作目錄
WORKDIR /usr/src/app
# 復(fù)制配置文件
COPY package*.json ./
COPY process.yml ./
RUN npm set registry https://registry.npm.taobao.org/ \
&& npm install pm2 -g \
&& npm install
# 使用pm2管理
CMD ["pm2-runtime", "process.yml", "--only", "app", "--env", "production"]
EXPOSE 3010
接著配置 docker-compose.yml
- db配置的是數(shù)據(jù)庫(kù)
postgres
,其中數(shù)據(jù)卷volumes
映射了數(shù)據(jù)庫(kù)目錄和初始化腳步 - app配置的是
node
服務(wù)房匆,其中的build
是映射上面dockerfile
所在的目錄耸成;depends_on
表示依賴的容器、啟動(dòng)先后浴鸿,這里先啟動(dòng)db再啟動(dòng)node
井氢;links
表示將db的名稱映射到app容器 - nginx容器
depend_on
于app容器,同時(shí)配置轉(zhuǎn)發(fā)node
的服務(wù)
version: '3'
services:
db:
image: postgres:12.3-alpine
container_name: postgres
environment:
- TZ=Asia/Shanghai
- POSTGRES_PASSWORD=xxxx
volumes:
- ./postgres/data:/var/lib/postgresql/data
- ./postgres/init:/docker-entrypoint-initdb.d
ports:
- 5432:5432
restart: always #始終重啟,生產(chǎn)環(huán)境中推薦配置為 always
expose:
- 5432
app:
image: koa-pg
container_name: koa
volumes:
- ./dist:/usr/src/app/dist
- ./logs:/usr/src/app/logs
build: ./
environment:
- TZ=Asia/Shanghai
restart: always
depends_on:
- db
links:
- db
expose:
- 3010
nginx:
image: nginx:1.19.0-alpine
container_name: nginx
volumes:
- ./nginx.conf:/etc/nginx/nginx.conf
ports:
- 8080:80
environment:
- TZ=Asia/Shanghai
restart: always
depends_on:
- app
links: # host名代替ip配置nginx的轉(zhuǎn)發(fā)
- app
expose:
- 8080
配置完我們的項(xiàng)目之后岳链,接著就是運(yùn)行起來(lái)
docker-compose up
在我們的本地開(kāi)發(fā)機(jī)是如此花竞,部署到服務(wù)器也是如此,你想要部署幾臺(tái)服務(wù)器就部署幾臺(tái)掸哑,只要裝了docker
约急,都是一句命令行就能解決的事情。
要啟動(dòng)幾個(gè)容器苗分,修改下docker-compose.yml
的配置烤宙,再次docker-compose up
,so easy !