容器化應用程序在當今世界愈來愈流行,由於它們可以解決幾乎每一個項目團隊都面臨的一些主要問題。node
在本文中,我將告訴你如何使用Docker容器化你的node.js應用程序。在繼續以前,請確保你的計算機中已安裝Docker。docker
Docker:https://www.docker.com/products/docker-desktopexpress
完成安裝過程後,打開Docker Desktop(保持此後臺運行)和運行 docker version,驗證安裝是否完成。npm
在本教程中,我使用的是具備較少依賴關係的基本node.js應用程序,但在你的項目中,你可能有一個高級的node.js應用,其依賴性比個人更多。json
首先,讓咱們看一下咱們的 app.js 文件。瀏覽器
const express = require('express'); const app = express();app.listen(3000, () => { console.log('listening for request on port 3000'); });app.get('/', (req, res) => { console.log('request made'); res.send('Hello World!'); });
這裏,我所作的基本上是,我用express建立了一個簡單的node.js服務器。但你也能夠選擇不使用express的node.js服務器,以下:服務器
const http = require('http'); const server = http.createServer(req, res) => { console.log('request made'); // setting the response here res.setHeader('Content-Type', 'text/plain'); res.write('Hello World!'); res.end();});server.listen(3000, '0.0.0.0', () => { console.log('listening for requests on port 3000'); });
你的 package.json 可能以下所示,因爲這是基本的package.json文件,所以它不包含更多依賴項。可是在你的狀況下,你能夠擁有比我更多的依賴項。app
好了,如今該建立 Dockerfile 了。很簡單,在文件夾內打開一個新文件,並將其命名爲Dockerfile。你可使用任何喜歡的文本編輯器來建立它。看看下面我用於該項目的Dockerfile,你能夠根據須要進行編輯。tcp
FROM node:10 // 咱們爲項目指定所需的鏡像名稱 WORKDIR /usr/src/app // 設置工做目錄的路徑 COPY package*.json// 同時複製package.json和package-lock.json RUN npm install // 安裝全部依賴項 COPY . . // 複製咱們項目中的全部其餘文件 EXPOSE 3000 // 公開應用程序運行所在的端口 CMD ["node", "app.js" ] // 在這裏,你能夠輸入用於運行應用程序的命令
如今一切就緒,接下來咱們要使用 Dockerfile 構建Docker鏡像。打開你的終端並運行如下命令以構建你的docker鏡像,確保你的路徑設置爲終端中的項目文件夾。編輯器
docker build . -t hello-world
注意:hello-world 是咱們的docker鏡像的名稱
這可能須要一些時間,由於它須要從 Docker Hub 中提取Node 鏡像,而且須要完成你在Dockerfile中提到的全部步驟。流程完成後,就能夠從這個docker鏡像中構建一個容器了。運行如下命令,並確保正確進行端口映射。
docker run -p 8080:3000 --name c1 hello-world
注意:你能夠選擇本身喜歡的端口。8080端口屬於咱們的本地機器,咱們的應用運行在3000端口上,c1是容器的名稱,一樣hello-world是docker的鏡像
如今你的容器將開始運行,你能夠在瀏覽器上查看你的應用程序。在此以前,在你的終端中運行 docker ps,並驗證你的容器已經開始運行。驗證後,你還能夠經過在終端上發出 docker port c1(此處,c1 是你的容器的名稱)命令來檢查端口。
docker port c1 >> 3000/tcp -> 0.0.0.0:8080
如今打開瀏覽器並輸入 localhost:8080,而後你將在瀏覽器中看到node.js應用響應。
總結
恭喜你!你已經使用Docker完成了對Node.js應用程序的容器化。
最好熟悉這些概念,而且不要忘記嘗試使用Docker容器化你的應用程序。
【責任編輯:趙寧寧 TEL:(010)68476606】