目錄
創(chuàng)新互聯(lián)專(zhuān)注于尚義企業(yè)網(wǎng)站建設(shè),自適應(yīng)網(wǎng)站建設(shè),商城網(wǎng)站制作。尚義網(wǎng)站建設(shè)公司,為尚義等地區(qū)提供建站服務(wù)。全流程按需搭建網(wǎng)站,專(zhuān)業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)專(zhuān)業(yè)和態(tài)度為您提供的服務(wù)
前段時(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)系呢?可以把鏡像看成是類(lèi)(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)楹芏嗖僮饕仓荒苊钚胁判小?br />Docker基本操作鏡像名稱(chēng)
關(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)容器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 nginxCOPY nginx.conf /etc/nginx/nginx.confDocker-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)??梢哉f(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.ymldb配置的是數(shù)據(jù)庫(kù)postgres,其中數(shù)據(jù)卷 volumes 映射了數(shù)據(jù)庫(kù)目錄和初始化腳步 app配置的是node服務(wù),其中的build是映射上面dockerfile所在的目錄;depends_on表示依賴(lài)的容器、啟動(dòng)先后,這里先啟動(dòng)db再啟動(dòng)node;links表示將db的名稱(chēng)映射到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 !
到此這篇關(guān)于Docker搭建部署Node項(xiàng)目的方法步驟的文章就介紹到這了,更多相關(guān)Docker搭建部署Node 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
本文名稱(chēng):Docker搭建部署Node項(xiàng)目的方法步驟
網(wǎng)站網(wǎng)址:http://chinadenli.net/article18/dojggp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、網(wǎng)站收錄、云服務(wù)器、商城網(wǎng)站、標(biāo)簽優(yōu)化、面包屑導(dǎo)航
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容