国产成人精品18p,天天干成人网,无码专区狠狠躁天天躁,美女脱精光隐私扒开免费观看

Docker搭建部署Node項目的方法步驟

發(fā)布時(shí)間:2021-08-15 18:37 來(lái)源: 閱讀:0 作者:Jeff.Zhong 欄目: 服務(wù)器 歡迎投稿:712375056

目錄

        前段時(shí)間做了個(gè)node全棧項目,服務(wù)端技術(shù)棧是 nginx + koa + postgresql。其中在centos上搭建環(huán)境和部署都挺費周折,部署測試服務(wù)器,接著(zhù)上線(xiàn)的時(shí)候又部署生產(chǎn)環(huán)境服務(wù)器。這中間就有很多既無(wú)聊又費精力,吃力不討好的"體力活"。所以就開(kāi)始思考怎么自動(dòng)化這部分搭建部署的工作,也就引出了Docker。

        什么是Docker

        Docker 是比虛擬機還要輕量級的虛擬化技術(shù),它虛擬化的實(shí)體就叫做容器。容器本身就是一個(gè)隔離了作用域的sandbox,同時(shí)它只包含了基礎庫和本身承載的服務(wù),非常精簡(jiǎn)。容器運行起來(lái)后就只是宿主機中的一個(gè)進(jìn)程而已,占用的資源是非常小的,這就為操作系統上運行容器集群創(chuàng )造了條件,可操作性和靈活性極佳。

        鏡像和容器又是什么關(guān)系呢?可以把鏡像看成是類(lèi)(class),容器看成對象(object),容器是由鏡像實(shí)例化產(chǎn)生出來(lái)的,當然一個(gè)鏡像可以生成多個(gè)容器。

        客戶(hù)端Docker

        如果不在服務(wù)器,我們在客戶(hù)端要怎么使用 Docker呢?在 Windows 和 OSX 上可以使用 Docker Desktop,再加上Kitematic,這兩個(gè)都是桌面管理工具,常規的操作方面非常便利。Docker Desktop 和 Kitematic 只是可視化了部分操作,命令行還是必備的,因為很多操作也只能命令行才行。

        Docker基本操作

        鏡像名稱(chēng)

        關(guān)于鏡像標簽,比如nginx:1.19.0-alpine,1.19.0是 nginx 的版本號,alpine是os的代號。

        • Jessie: debian 8
        • Stretch: debian 9
        • Buster: debian 10
        • Alpine: Alpine,推薦使用,因為體積非常小

        Alpine 是體積最小的一個(gè)版本,有些甚至是其他版本的四分之一。這意味著(zhù)構建鏡像更快,運行效率更高,因為加載的組件更加少,無(wú)形中也意味著(zhù)漏洞更少更安全。

        拉取鏡像

        docker pull nginx:1.19.0-alpine
        

        啟動(dòng)容器

        • --name web:指定容器名稱(chēng)為web
        • -p 8080:80: 容器nginx監聽(tīng)端口為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,隨時(shí)可以構建鏡像。如下就是構建一個(gè)非常簡(jiǎn)單的nginx鏡像,from就是構建時(shí)使用的基礎鏡像:

        FROM nginx
        COPY nginx.conf /etc/nginx/nginx.conf
        

        Docker-compose

        當我們的項目不僅只有單個(gè)容器,而是需要運行多個(gè)容器,而且容器之間還需要互相通信的時(shí)候,就需要更強大的管理工具了。比如k8s,但我們目前的小項目使用官方自帶的Docker-compose已經(jīng)足矣。

        首先需要docker-compose.yml配置文件,比如下面就是兩個(gè)容器的模板,image表示使用的鏡像,ports則表示端口映射,volumes則是需要映射的數據卷:

        version: "3"
        
        services:
          webapp:
            image: web
            ports:
              - "8080:80"
            volumes:
              - "/data"
          redis:
            image: "redis:alpine"
        
        

        接著(zhù)可以使用以下命令行進(jìn)行操作:

        docker-compose build [options] [SERVICE...] #構建(重新構建)項目中的服務(wù)容器
        docker-compose up -d # 運行 compose 項目,后臺執行
        

        docker-compose up 是個(gè)非常強大的命令,它將嘗試自動(dòng)完成包括構建鏡像,(重新)創(chuàng )建服務(wù),啟動(dòng)服務(wù),并關(guān)聯(lián)服務(wù)相關(guān)容器的一系列操作。鏈接的服務(wù)都將會(huì )被自動(dòng)啟動(dòng),除非已經(jīng)處于運行狀態(tài)??梢哉f(shuō),大部分時(shí)候都可以直接通過(guò)該命令來(lái)啟動(dòng)一個(gè)項目。

        構建nginx-node-postgres項目

        有了上面的基礎,接著(zhù)就可以構建我們自己的項目了,首先是node服務(wù)的dockerfile,主要做了如下步驟

        • 創(chuàng )建容器工作目錄
        • 復制相關(guān)配置文件到容器
        • 在容器安裝npm包
        • 運行pm2啟動(dòng)容器
        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
        

        接著(zhù)配置 docker-compose.yml

        • db配置的是數據庫postgres,其中數據卷 volumes 映射了數據庫目錄和初始化腳步
        • 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í)配置轉發(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的轉發(fā)
              - app
            expose:
              - 8080

        配置完我們的項目之后,接著(zhù)就是運行起來(lái)

        docker-compose up
        

        在我們的本地開(kāi)發(fā)機是如此,部署到服務(wù)器也是如此,你想要部署幾臺服務(wù)器就部署幾臺,只要裝了docker,都是一句命令行就能解決的事情。

        要啟動(dòng)幾個(gè)容器,修改下docker-compose.yml的配置,再次docker-compose up,so easy !

        到此這篇關(guān)于Docker搭建部署Node項目的方法步驟的文章就介紹到這了,更多相關(guān)Docker搭建部署Node 內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

        免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。

        国产亚洲精AA在线看| 日本熟妇人妻XXXXX| 国产精品原创巨作AV女教师| 精品人妻少妇一区二区三区不卡| 亚洲爆乳精品无码一区二区| 国产线播放免费人成视频播放|