前言
創(chuàng)新互聯(lián)為客戶提供專業(yè)的成都網(wǎng)站制作、做網(wǎng)站、程序、域名、空間一條龍服務(wù),提供基于WEB的系統(tǒng)開發(fā). 服務(wù)項目涵蓋了網(wǎng)頁設(shè)計、網(wǎng)站程序開發(fā)、WEB系統(tǒng)開發(fā)、微信二次開發(fā)、手機網(wǎng)站制作等網(wǎng)站方面業(yè)務(wù)。
docker是一個開源的應(yīng)用容器引擎,可以為我們提供安全、可移植、可重復(fù)的自動化部署的方式。docker采用虛擬化的技術(shù)來虛擬化出應(yīng)用程序的運行環(huán)境。如上圖一樣。docker就像一艘輪船。而輪船上面的每個小箱子可以看成我們需要部署的一個個應(yīng)用。使用docker可以充分利用服務(wù)器的系統(tǒng)資源,簡化了自動化部署和運維的繁瑣流程,減少很多因為開發(fā)環(huán)境中和生產(chǎn)環(huán)境中的不同引發(fā)的異常問題。從而提高生產(chǎn)力。
docker三個核心概念如下:
本文主要是教大家了解如何在Docker容器中設(shè)置Node JS:
有一個可運行工作的NodeJS應(yīng)用程序
通過確保進程在出錯時不退出,使節(jié)點應(yīng)用程序具有彈性
通過在代碼更改時自動重新啟動服務(wù)器,使Node應(yīng)用程序易于使用
利用Docker:
先決條件
Docker已經(jīng)安裝好了
至少入門級節(jié)點知識和NPM
1.獲取一個簡單的Node應(yīng)用程序
我們將使用Express,因為它的設(shè)置是容易的。
在一個干凈的目錄中,讓我們從初始化NPM開始,繼續(xù)運行此命令并按照提示進行操作:
npm init
安裝Express:
npm install --save-prod express
編制代碼src/index.js
<b>const</b> express = require('express') <b>const</b> app = express() <b>const</b> port = 3000 app.get('/', (req, res) => res.send('Hello World!')) app.listen(port, () => {console.log(`Example app listening on port ${port}!`))
啟動一個偵聽端口3000并使用Hello World響應(yīng)的"/"這個URL路由。
2.設(shè)置Docker以運行我們的Node應(yīng)用程序
我們將使用docker-compose.yml文件來啟動和停止我們的Docker容器,而不是鍵入長長的Docker命令。您可以將此文件視為多個Docker容器的配置文件。
docker-compose.yml:
version: "3" services: app: container_name: app # How the container will appear when listing containers from the CLI image: node:10 # The <container-name>:<tag-version> of the container, in this case the tag version aligns with the version of node user: node # The user to run as in the container working_dir: "/app" # Where to container will assume it should run commands and where you will start out if you go inside the container networks: - app # Networking can get complex, but for all intents and purposes just know that containers on the same network can speak to each other ports: - "3000:3000" # <host-port>:<container-port> to listen to, so anything running on port 3000 of the container will map to port 3000 on our localhost volumes: - ./:/app # <host-directory>:<container-directory> this says map the current directory from your system to the /app directory in the docker container command: "node src/index.js" # The command docker will execute when starting the container, this command is not allowed to exit, if it does your container will stop networks: app:
讓我們用這個命令啟動docker容器。在后臺運行(-d)
docker-compose up -d
在瀏覽器中訪問http://localhost:3000并看到 Hello World!
3. 使得應(yīng)用變得彈性
如果您之前使用過Node,那么您可能知道如果應(yīng)用程序中發(fā)生錯誤(如未捕獲的異常),那么它將關(guān)閉該Node進程。這對我們來說真的是個壞消息,因為我們的代碼中肯定會有一個錯誤,并且無法保證我們的代碼100%無錯誤。此問題的解決方案通常是另一個監(jiān)視我們的Node應(yīng)用程序并在其退出時重新啟動它的過程。有這么多的解決方案,比如linux的supervisord,NPM包永遠(yuǎn)和PM2等......我們只需要為本指南選擇一個。
將專注于 PM2, 因為我最熟悉它,除了進程管理之外還有一些其他功能,例如文件監(jiān)視,這將在下一節(jié)中派上用場。
安裝PM2
npm install --save-prod pm2
PM2可以通過命令行使用,但我們將設(shè)置一個簡單的配置文件,就像我們使用docker-compose.yml文件一樣,以防止我們重復(fù)輸入長命令
ecosystem.config.js:
const path = require('path') module.exports = { apps: [{ name: 'app', script: 'src/index.js', // Your entry point instances: 1, autorestart: true, // THIS is the important part, this will tell PM2 to restart your app if it falls over max_memory_restart: '1G' }] }
現(xiàn)在我們應(yīng)該更改docker-compose.yml文件以使用PM2啟動我們的應(yīng)用程序,而不是直接從index.js啟動它。
docker-compose.yml(僅更改了的選項)
version: "3" services: app: container_name: app # How the container will appear when listing containers from the CLI image: node:10 # The <container-name>:<tag-version> of the container, in this case the tag version aligns with the version of node user: node # The user to run as in the container working_dir: "/app" # Where to container will assume it should run commands and where you will start out if you go inside the container networks: - app # Networking can get complex, but for all intents and purposes just know that containers on the same network can speak to each other ports: - "3000:3000" # <host-port>:<container-port> to listen to, so anything running on port 3000 of the container will map to port 3000 on our localhost volumes: - ./:/app # <host-directory>:<container-directory> this says map the current directory from your system to the /app directory in the docker container command: "npx pm2 start ecosystem.config.js --no-daemon" # The command docker will execute when starting the container, this command is not allowed to exit, if it does your container will stop networks: app:
更改docker-compose.yml文件不會影響已經(jīng)運行的容器。為了進行更改,您應(yīng)該重新啟動容器:
docker-compose restart
4.使我們的應(yīng)用程序易于開發(fā)
您可能已經(jīng)注意到,一旦Node進程啟動,那么在重新啟動Node進程之前,更改代碼實際上并沒有做任何事情,對于我們而言,每次都會涉及重新啟動Docker容器以激活我們做出的改變。如果我們在進行代碼更改時自動為我們重新啟動Node進程,那將是理想的選擇。
在過去,我已經(jīng)完成了諸如引入文件監(jiān)視實用程序和使用該文件監(jiān)視實用程序來重新啟動Docker進行文件更改之類的操作,或者我會使用Nodemon但是在使用Docker時會有一些警告。
最近,當(dāng)文件發(fā)生變化時,我一直在使用PM2來重新啟動我的Node進程,而且由于我們已經(jīng)從上一步中獲取了它,因此我們不必安裝另一個依賴項。
ecosystem.config.js(僅添加了watch選項):
const path = require('path')
module.exports = { apps: [{ name: 'app', script: 'src/index.js', instances: 1, autorestart: true, watch: process.env.NODE_ENV !== 'production' ? path.resolve(__dirname, 'src') : false, max_memory_restart: '1G' }] }
如果我們沒有將NODE_ENV環(huán)境變量設(shè)置為production,則上面的配置文件現(xiàn)在將監(jiān)視src目錄。您可以通過更改index.js文件來測試它,除了Hello World之外還可以將其他內(nèi)容打印到瀏覽器中!。在此之前,您需要重新啟動Docker容器,因為您更改了PM2運行容器的方式:
docker-compose restart
重新啟動Node進程可能需要一秒鐘才能完成,如果你想觀察它何時完成,你可以看到你的Docker日志告訴PM2何時完成重啟你的Node Process:
docker-compose logs -f
總結(jié)
docker run --rm -i -v <absolute-path-to-your-project-locally>:/app -w /app node:10 npm install
docker exec -it app bash
上面的命令將把你放到容器中,這樣你就可以繼續(xù)從里面運行命令,即npm run start或npm run test
如果您不想進入容器內(nèi)部,可以運行這樣的命令
docker exec -t app bash -c "npm run start"
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對創(chuàng)新互聯(lián)的支持。
網(wǎng)站題目:一步步教你利用Docker設(shè)置Node.js
文章來源:http://aaarwkj.com/article38/jjgssp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App設(shè)計、手機網(wǎng)站建設(shè)、品牌網(wǎng)站制作、網(wǎng)站維護、網(wǎng)站收錄、網(wǎng)站改版
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)