阿里雲+docker搭建簡單node.js服務
前提概要
實習的時候接觸到docker,當時對其理解比較模糊。現在回學校做畢設,正好伺服器這一塊沒人寫,於是稍微複習了一下nodejs,買了個阿里雲,擺弄了一下docker,搭建了個簡單的伺服器。
最終效果
主要是提供HTTP伺服器,直接通過IP訪問,提供兩個示例:(已停用)
http://120.77.148.92/point_info
http://120.77.148.92/img/mice.png
主要步驟
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執行服務,服務搭建成功。
相關文章
- 阿里雲簡訊服務阿里
- Laravel 阿里雲簡訊服務包Laravel阿里
- 基於ECS搭建FTP服務(阿里雲)FTP阿里
- Node.js搭建Https服務Node.jsHTTP
- docker搭建vsftpd服務DockerFTP
- 為何選擇阿里雲 簡訊服務阿里
- 阿里雲簡訊服務使用代理的坑阿里
- [Rust]使用Rocket框架搭建簡單Web服務Rust框架Web
- 下載docker映象並推送至阿里雲映象服務Docker阿里
- Docker容器服務搭建(一)Docker
- 阿里雲提供哪些建站服務,如何搭建公司網站?阿里網站
- Docker 公司與阿里雲達成合作,在中國提供 Docker Hub 服務Docker阿里
- 2020最新 使用阿里雲的簡訊服務傳送簡訊阿里
- docker-compose搭建gitlab服務DockerGitlab
- 阿里雲簡訊服務的使用-----獲取簡訊驗證碼阿里
- 阿里雲釋出 Elasticsearch 雲服務阿里Elasticsearch
- 使用 Docker 和 Nginx 實現簡單目錄索引服務DockerNginx索引
- Jave Web阿里雲簡訊服務傳送驗證碼Web阿里
- CentOS 配置阿里雲 NTP 服務CentOS阿里
- Docker學習之搭建MySql容器服務DockerMySql
- 阿里雲簡訊服務實現網站手機簡訊驗證碼阿里網站
- 活動預約|阿里雲如何搭建雲服務 SRE 與可觀測體系阿里
- 基於阿里雲日誌服務快速打造簡版業務監控看板阿里
- 使用SpringBoot+Dubbo搭建一個簡單的分散式服務Spring Boot分散式
- 阿里雲訊息服務使用教程阿里
- 阿里雲智慧對話分析服務阿里
- Docker 搭建多容器組合服務 (nginx + PHP)DockerNginxPHP
- Docker學習之搭建ActiveMQ訊息服務DockerMQ
- 簡單優化容器服務優化
- go-zero docker-compose 搭建課件服務(五):完善user服務GoDocker
- 阿里雲安全管家服務重磅釋出!阿里
- 阿里雲伺服器部署Mongodb服務阿里伺服器MongoDB
- 如何解決公網無法訪問阿里雲ECS搭建的MongoDB服務阿里MongoDB
- PHP 擴充套件包教程學習分享 -- 阿里雲簡訊服務 SDKPHP套件阿里
- .Net Core 3.1簡單搭建微服務微服務
- 使用Docker搭建自己的Bitwarden密碼管理服務Docker密碼
- Spring Cloud雲服務架構 - commonservice-config配置服務搭建SpringCloud架構
- go-zero之阿里發簡訊服務Go阿里