1. 程式人生 > >阿里雲+docker搭建簡單node.js服務

阿里雲+docker搭建簡單node.js服務

前提概要

實習的時候接觸到docker,當時對其理解比較模糊。現在回學校做畢設,正好伺服器這一塊沒人寫,於是稍微複習了一下nodejs,買了個阿里雲,擺弄了一下docker,搭建了個簡單的伺服器。

最終效果

主要步驟

1、配置阿里雲(此點筆者自己選擇,不多描述了)
2、nodejs服務程式碼
3、拷貝程式碼到伺服器
4、使用dockerfile建立image並且搭建服務

nodejs服務程式碼

1、主要express提供伺服器
2、資料庫使用sqlite
3、圖片上傳伺服器使用到connect-multiparty

主要目錄如下:
這裡寫圖片描述
主要檔案只有server.js,程式碼在下方:

var express = require('express');
var fs = require("fs");
var sqlite3 = require('sqlite3');
var multiparty = require('connect-multiparty');
var app = express();

app.use(express.static('public'));
app.use(multiparty({uploadDir: './public/img'}));

app.get('/', function (req, res) {
    res.send('Hello World'
); }); app.get('/device', function (req, res) { var db = new sqlite3.Database("server.db"); db.all("SELECT * FROM device", function (err, row) { res.send(row); db.close(); }); }); app.get('/device_data', function (req, res) { var db = new sqlite3.Database("server.db"); db.all("SELECT * FROM device_data"
, function (err, row) { res.send(row); db.close(); }); }); app.get('/point_info', function (req, res) { var db = new sqlite3.Database("server.db"); db.all("SELECT * FROM point_info", function (err, row) { res.send(row); db.close(); }); }); var multipartMiddleware = multiparty(); app.post('/info_post', multipartMiddleware, function (req, res) { console.log(req.body, req.files); var body = req.body; var name = body.upload_name; var type = body.upload_type; var longitude = body.longitude; var latitude = body.latitude; var address = body.upload_address; var time = body.upload_time; var description = body.upload_description; var status = body.approval_status; var fileName = req.files.file.path.substring(11); var resource = "http://" + req.headers.host + "/img/" + fileName; console.log(resource); var db = new sqlite3.Database("server.db"); var add = db.prepare("INSERT OR REPLACE INTO point_info " + "(ID,upload_name, upload_type,longitude,latitude,upload_address,upload_time,upload_description," + "approval_status,upload_resource) VALUES (?,?,?,?,?,?,?,?,?,?)"); add.run(null, name, type, longitude, latitude, address, time, description, status, resource); add.finalize(); db.close(); res.end(JSON.stringify("success")); }); app.get('/change_status', function (req, res) { console.log(req.query); var query = req.query; var id = query.id; var status = query.status; var db = new sqlite3.Database("server.db"); var modify = db.prepare("UPDATE point_info set approval_status=? where id =?"); modify.run(status, id); res.send("success"); modify.finalize(); db.close(); }); var server = app.listen(80, function () { var host = server.address().address; var port = server.address().port; console.log("應用例項,訪問地址為 http://%s:%s", host, port); var db = new sqlite3.Database("server.db"); setInterval(function () { console.log("change device_data"); for (var i = 0; i < 30; i++) { const modify = db.prepare("UPDATE device_data " + "set rain_time = ?," + "rain_fall = ?," + "rain_level = ?," + "water_speed = ?," + "water_level = ?," + "wind_speed = ?," + "gas_warn = ?," + "general_level = ? " + "where id = ? "); modify.run(Math.random() * 10,Math.random() * 10,Math.random() * 10,Math.random() * 10, Math.random() * 10,Math.random() * 10,Math.random() * 10,Math.random() * 10,i); modify.finalize(); } },3000) });

拷貝程式碼到伺服器

筆者使用xshell模擬終端,直接通過圖形化介面操作,截圖如下:
這裡寫圖片描述
這裡寫圖片描述

通過dockefile建立image並且搭建服務

dockerfile內容如下:

FROM node
COPY ./project /home
WORKDIR /home/FloodServer
EXPOSE 80
CMD npm install

含義如下:

FROM node:該 image 檔案繼承官方的 node image。
COPY ./project /home:將當前目錄下的project資料夾中所有檔案(除了.dockerignore排除的路徑),都拷貝進入 image 檔案的/home目錄。
WORKDIR /home/FloodServer:指定接下來的工作路徑為/home/FloodServer。
EXPOSE 80:將容器 80 埠暴露出來, 允許外部連線這個埠。
CMD npm install:在容器啟動後執行npm install安裝依賴。

此時當前目錄下有dockerfile檔案和之前寫的nodejs的服務程式碼。
寫完dockerfile檔案後,執行如下程式碼構建image:

docker image -t build my_node .

-t引數用來指定 image 檔案的名字,後面還可以用冒號指定標籤。
構建完畢後,我們可以用docker image ls指令檢視image。
這裡寫圖片描述

image構建完畢,直接通過image建立container,指令如下:

docker run -p 80:80 -it my_node /bin/bash

各個引數意義如下:

-p引數:容器的 80埠對映到本機的 80埠。
-it引數:容器的 Shell 對映到當前的 Shell,然後你在本機視窗輸入的命令,就會傳入容器。
my_node:image 檔案的名字(如果有標籤,還需要提供標籤,預設是 latest 標籤)。
/bin/bash:容器啟動以後,內部第一個執行的命令。這裡是啟動 Bash,保證使用者可以使用 Shell。

構建完container之後,容器的Shell對映到了當前的Shell,直接通過node server.js執行服務,服務搭建成功。
這裡寫圖片描述