Docker搭建部署Node項目的方法步驟
前段時間做瞭個node全棧項目,服務端技術棧是 nginx + koa + postgresql。其中在centos上搭建環境和部署都挺費周折,部署測試服務器,接著上線的時候又部署生產環境服務器。這中間就有很多既無聊又費精力,吃力不討好的”體力活”。所以就開始思考怎麼自動化這部分搭建部署的工作,也就引出瞭Docker。
什麼是Docker
Docker 是比虛擬機還要輕量級的虛擬化技術,它虛擬化的實體就叫做容器。容器本身就是一個隔離瞭作用域的sandbox,同時它隻包含瞭基礎庫和本身承載的服務,非常精簡。容器運行起來後就隻是宿主機中的一個進程而已,占用的資源是非常小的,這就為操作系統上運行容器集群創造瞭條件,可操作性和靈活性極佳。
鏡像和容器又是什麼關系呢?可以把鏡像看成是類(class),容器看成對象(object),容器是由鏡像實例化產生出來的,當然一個鏡像可以生成多個容器。
客戶端Docker
如果不在服務器,我們在客戶端要怎麼使用 Docker呢?在 Windows 和 OSX 上可以使用 Docker Desktop,再加上Kitematic,這兩個都是桌面管理工具,常規的操作方面非常便利。Docker Desktop 和 Kitematic 隻是可視化瞭部分操作,命令行還是必備的,因為很多操作也隻能命令行才行。
Docker基本操作
鏡像名稱
關於鏡像標簽,比如nginx:1.19.0-alpine,1.19.0是 nginx 的版本號,alpine是os的代號。
- Jessie: debian 8
- Stretch: debian 9
- Buster: debian 10
- Alpine: Alpine,推薦使用,因為體積非常小
Alpine 是體積最小的一個版本,有些甚至是其他版本的四分之一。這意味著構建鏡像更快,運行效率更高,因為加載的組件更加少,無形中也意味著漏洞更少更安全。
拉取鏡像
docker pull nginx:1.19.0-alpine
啟動容器
- –name web:指定容器名稱為web
- -p 8080:80: 容器nginx監聽端口為80,映射到本地端口8080
- -v xxxx:xxxx:這裡是用本地配置文件映射到容器nginx配置文件
- -d:後臺運行
- 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 #顯示運行的容器
- docker rm xxx #刪除容器
Dockerfile
構建鏡像比較方便的是使用Dockerfile,它就是鏡像的配置文件,隻要有Dockerfile,隨時可以構建鏡像。如下就是構建一個非常簡單的nginx鏡像,from就是構建時使用的基礎鏡像:
FROM nginx COPY nginx.conf /etc/nginx/nginx.conf
Docker-compose
當我們的項目不僅隻有單個容器,而是需要運行多個容器,而且容器之間還需要互相通信的時候,就需要更強大的管理工具瞭。比如k8s,但我們目前的小項目使用官方自帶的Docker-compose已經足矣。
首先需要docker-compose.yml配置文件,比如下面就是兩個容器的模板,image表示使用的鏡像,ports則表示端口映射,volumes則是需要映射的數據卷:
version: "3" services: webapp: image: web ports: - "8080:80" volumes: - "/data" redis: image: "redis:alpine"
接著可以使用以下命令行進行操作:
docker-compose build [options] [SERVICE...] #構建(重新構建)項目中的服務容器 docker-compose up -d # 運行 compose 項目,後臺執行
docker-compose up 是個非常強大的命令,它將嘗試自動完成包括構建鏡像,(重新)創建服務,啟動服務,並關聯服務相關容器的一系列操作。鏈接的服務都將會被自動啟動,除非已經處於運行狀態。可以說,大部分時候都可以直接通過該命令來啟動一個項目。
構建nginx-node-postgres項目
有瞭上面的基礎,接著就可以構建我們自己的項目瞭,首先是node服務的dockerfile,主要做瞭如下步驟
- 創建容器工作目錄
- 復制相關配置文件到容器
- 在容器安裝npm包
- 運行pm2啟動容器
FROM node:14.5.0-alpine3.12 # 工作目錄 WORKDIR /usr/src/app # 復制配置文件 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配置的是數據庫postgres,其中數據卷 volumes 映射瞭數據庫目錄和初始化腳步
- app配置的是node服務,其中的build是映射上面dockerfile所在的目錄;depends_on表示依賴的容器、啟動先後,這裡先啟動db再啟動node;links表示將db的名稱映射到app容器
- nginx容器depend_on於app容器,同時配置轉發node的服務
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 #始終重啟,生產環境中推薦配置為 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的轉發 - app expose: - 8080
配置完我們的項目之後,接著就是運行起來
docker-compose up
在我們的本地開發機是如此,部署到服務器也是如此,你想要部署幾臺服務器就部署幾臺,隻要裝瞭docker,都是一句命令行就能解決的事情。
要啟動幾個容器,修改下docker-compose.yml的配置,再次docker-compose up,so easy !
到此這篇關於Docker搭建部署Node項目的方法步驟的文章就介紹到這瞭,更多相關Docker搭建部署Node 內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- docker-compose安裝yml文件配置方式
- Docker Alpine鏡像時區問題完美解決方案
- Docker部署Nuxt.js項目的實現
- docker-compose教程之安裝使用和快速入門
- 解決使用Docker Compose管理容器的問題