一个合理并且高效的部署方案,不仅能够实现快速升级,平滑切换,负载均衡,应用隔离等部署特性,而且配有一套成熟稳定的监控。

 如何使用 Docker 高效部署 Node 应用(docker部署node服务) 应用 第1张

❝ 如何在生产环境部署一个 Node 应用?[1]❞

一个合理并且高效的部署方案,不仅能够实现快速升级,平滑切换,负载均衡,应用隔离等部署特性,而且配有一套成熟稳定的监控。

kubernetes 把 Node 应用视作一个服务端应用的黑盒子,完美匹配了以上条件,越来越多的团队把 Node 部署在 k8s 上。

但在此之前,需要先把 Node 应用跑在一个 Docker 容器上,这也是本章的主题。

一个简单的 Node 应用

「index.js」

一个 hello, world 版的 Node Web App

  1. consthttp=require('http')
  2. constapp=async(req,res)=>{
  3. res.end('hello,world')
  4. }
  5. http.createServer(app).listen(3000,()=>console.log(3000))

「package.json」

配置 npm start 来启动应用

  1. "scripts":{
  2. "start":"nodeindex.js"
  3. },

但这仅仅是最简单的 Node 应用,真实环境中还有各种数据存储及定时任务调度等,暂撇开不谈,这已经足够了。

再稍微复杂一点点的 Node 应用可以查看山月的项目 whoami[5]: 一个最简化的 serverless 与 Dockerize 示例。

NODE_ENV=production

在生产环境中,无需安装 devDependecies 中依赖,NODE_ENV 环境变量设置为 production 时将会跳过 devDep。

  1. #通过设置环境变量,只安装生产环境依赖
  2. $NODE_ENV=productionnpmci
  3. #通过显式指定flag,只安装生产环境依赖
  4. $npmci--production

另一方面,某些第三方模块会根据 NODE_ENV 环境变量做出一些意料不到的配置。因此在生产环境注意该环境变量的配置。

一个 Node 应用的简单部署

一个典型的、面向服务端的 Node 应用是这么跑起来的:

  1. npm install
  2. npm run config,从配置服务(consul/vault)拉取配置 ,如数据库与缓存的账号密码,此时构建服务器需要配置服务权限
  3. npm run migrate,数据库迁移脚本,执行数据库表列行更改操作,此时构建服务器需要数据库访问权限
  4. npm start,启动一个 Node 服务

把运行步骤翻译为 Dockerfile:

  1. #选择一个体积小的镜像(~5MB)
  2. FROMnode:12-alpine
  3. #环境变量设置为生产环境
  4. ENVNODE_ENVproduction
  5. WORKDIR/code
  6. #更好的根据ImageLayer利用缓存
  7. ADDpackage.jsonpackage-lock.json/code
  8. RUNnpmci
  9. ADD./code
  10. #配置服务及数据库迁移
  11. RUNnpmrunconfig--if-present&&npmrunmigrate--if-present
  12. EXPOSE3000
  13. CMDnpmstart

这对于大部分 Node 应用已经是足够了,如果精益求精,可以再走接下来的多阶段构建

node-gyp 与 Native Addon

在 Node 中有可能存在着一些 Native Addon,它们通过 node-gyp 进行编译,而它依赖于 python,make 与 g++。

  1. $apk--no-cacheaddpythonmakeg++

在带有编译过程的镜像构建中,源文件与构建工具都会造成空间的浪费。借助镜像的「多阶段构建」可以高效利用空间。Go App 与 FE App 的构建也遵循此规则。

  1. 多阶段构建 Go 应用[6]
  2. 多阶段构建前端应用[7]

在构建 Node 应用镜像时,第一层镜像用以构造 node_modules。

  1. #选择一个体积小的镜像(~5MB)
  2. FROMnode:12-alpineasbuilder
  3. #环境变量设置为生产环境
  4. ENVNODE_ENVproduction
  5. #更好的根据ImageLayer利用缓存
  6. ADDpackage.jsonpackage-lock.json./
  7. RUNnpmci
  8. #多阶段构建之第二阶段
  9. #多阶段构建之第二阶段
  10. #多阶段构建之第二阶段
  11. FROMnode:12-alpine
  12. WORKDIR/code
  13. ENVNODE_ENVproduction
  14. ADD..
  15. COPY--from=buildernode_modulesnode_modules
  16. #配置服务及数据库迁移
  17. RUNnpmrunconfig--if-present&&npmrunmigrate--if-present
  18. EXPOSE3000
  19. CMDnpmstart

相关文章

  • N-API and getting started with writing C addons for Node.js[8]
  • Using Docker for Node.js in Development and Production[9]

Reference

[1]如何在生产环境部署一个 Node 应用?:

https://github.com/shfshanyue/Daily-Question/issues/420

[2]如何在 docker 中部署前端:

https://shanyue.tech/frontend-engineering/docker.html

[3]前端部署 Prview 与 Production:

https://shanyue.tech/frontend-engineering/feature-deploy.html

[4]前端部署的发展过程:

https://shanyue.tech/frontend-engineering/deploy.html

[5]whoami:

https://github.com/shfshanyue/whoami

[6]多阶段构建 Go 应用:

https://docs.docker.com/develop/develop-images/multistage-build/#use-multi-stage-builds

[7]多阶段构建前端应用:

https://shanyue.tech/frontend-engineering/docker.html#%E5%A4%9A%E9%98%B6%E6%AE%B5%E6%9E%84%E5%BB%BA

[8]N-API and getting started with writing C addons for Node.js:

https://hackernoon.com/n-api-and-getting-started-with-writing-c-addons-for-node-js-cf061b3eae75

[9]Using Docker for Node.js in Development and Production:

https://dev.to/alex_barashkov/using-docker-for-nodejs-in-development-and-production-3cgp

本文转载自微信公众号「全栈成长之路」,可以通过以下二维码关注。转载本文请联系全栈成长之路公众号。

 如何使用 Docker 高效部署 Node 应用(docker部署node服务) 应用 第2张

转载请说明出处
知优网 » 如何使用 Docker 高效部署 Node 应用(docker部署node服务)

发表评论

您需要后才能发表评论