1.装 nodejs 环境然后 build 完直接服务器 node
2.宝塔面板直接用 node 模块功能
3.pm2 直接跑
4.docker 跑 nodejs 镜像
5.k8s 集群部署 nodejs 镜像
6.服务器上直接 npm run dev

综合评论,基本上 4 最优解,3 和 5 次之

5

4 3

4,5 都有,看具体情况

3 6

435目前是 4 5

牛啊老哥

6 也太秀了

1 为啥没人用?

因为版本不好控制

纯好奇,6 不会崩么,日志怎么打,出现错误怎么查呢

直接 node 多进程不容易控制

GitHub Actions

3 4 我都在用. 现在几乎都是 4 了, 之前的人留的配置, 日志不自动删, 也没有文档关于手动清理的, 服务器硬盘占用暴涨, 后来我给改成 docker 跑镜像了

3 4 5 按顺序用过来的,现在基本上都是 5 了

感觉 4 已经取代 3 了,不过现在身边很多大佬都用 5 取代 4 了

6 是真的 6

在 4 或 5 里用 3 跑🐶

只能重启

应该是没那么方便的原因

45 不是已经解决了 3 所解决的问题了吗

k8s 需要运维, 很多中小公司没有这个实力, 尤其是那些业务驱动型的小公司

6

docker 更占空间吧,日志文件我也映射出来。

主要用的还是部署服务,特性功能用的比较少

3 是 最快的

一方面是为了用 pm2 的日志和启动多个服务方便,还有就是随时可以从容器切换到非容器环境

serverless deploy

这是什么神仙部署?类似云开发吗?

docker 只是镜像大, 但是每次更新会删掉旧的. pm2 以前的人留下来的配置, 谁敢碰呀, 日志每天爆炸性增长, 我接手的时候, 8 个 G....

强力推荐一下Tars

pm2 的日志确实比较坑,默认没有启用日志轮转。会占满硬盘

类似 3 ,我用 forever ,然后外面加 nginx 。

PM2

能容器尽量容器

4/5 优先。但是要吃满多核 cpu 需要前面有 gateway lb所以有时候还用 pm2 cluster mode ,简单

流水线+集群,生产环境 pm2 作用不大。

本地 build 打包通过脚本传上服务器。服务器用 systemd 管理各个进程,有多进程需求的用的是第三方 npm 包(就是简单包装了下 node 内置的 cluster 功能)。

6

pkg 打包可执行文件,然后 systemd 运行

以前 Windows 服务器的时候用过 6 ,哈哈哈哈哈哈

上述是公司项目的做法,自己的没什么正经项目,都是 tmux 直接运行。

4+3 ,通过 docker 脚本起 pm2 ,pm2 再起服务脚本

为啥这么说?可以看日志和性能啊,还有进程保护、集群模式,总的来说还是挺方便。难道还有其他代替方案吗?

3 ,4

之前 3 ,现在 4 (什么日志不日志的,我从来不看日志)

3 ,想用 docker 跑一直没空搞顺便问问大家怎么和 CI 工具配合的,我现在是把服务器作为 jenkins 的从节点,直接在节点上编译然后 pm2 启动如果构建再 copy 过去太大了,包括用 docker 镜像,node_modules 打不打在里面

没人用 swarm 吗

egg 或者 nestjs 是可以直接 npm start 的不是说真 npm run dev

新手,第一个 nodejs 项目.3.

一般静态服务直接用serve 然后 nohup serve -s -n -l 8080 ./web > web.log 2>&1 &

Lambda整个项目 zip 打包后传上去就行,太大的话 webpack 之类的 bundle 一下

OP 分的有点乱,宝塔是什么鬼,1 、6 应该属于同一类按部署方式来说 1 、CI/CD ( Jeknins/GitLab CI/TeamCity/...)2 、DevOps/Pipeline ( AWS Pipeline/阿里云 Devops/腾讯 Coding )3 、手撸 按运行环境来说1 、VM/PM 2 、Docker 3 、Kubernetes 按运行方式来说 1 、PM2 2 、Supervisor 3 、直接运行

这个 6 可太 6 了

没有 serverless?

6 有点 6

非容器化的传统部署,至少要写好 systemd unit ,配好日志定时切分轮替。初始部署以及做过基础设施配置变更后至少要 reboot 一次服务器看能否自动启动完毕且运行正常。

3 & 4

  1. systemctl 做成服务跑

我比较担心 docker 的性能损耗和稳定性,我亲身经历过我直接用 nginx 启动的服务没出过问题,docker (所有容器)崩过好几次

我曾经通过 pm2 守护 npm run dev ,完全不会挂的

3 & 43 、功能不多我一般直接挂 PM2 ;4 、一般是做 web 的中间件,或者是拿去写接口

4 ,用 docker-compose 的 scale 语法实现 zero downtime 平滑重启 www.tines.com/blog/simple-zero-downtime-deploys-with-nginx-and-docker-compose

3 毫无疑问...

3 多个项目都用

6 有其合理性,现在很多前端用 Vite 开发,众所周知用 Vite 开发但是打包用的是其他的工具,可能打包有问题,所以

用 docker ,版本号更新能 rollback ,心安

1 & 3

以前用 pm2 跑,后来更新的时候老是翻车(多数是包更新问题);后来就改成 docker 镜像了。

我只有开发的时候用 nodejs ,部署的时候根本用不上它,直接导出纯静态文件了。

上家公司 pm2 ,自己的项目 nohup ,现在 k8s

nvm 用来控制版本,直接跑

还有就是加个 3

类似这样,感觉很轻很方便···jsmodule.exports = { apps: [{ name: 'app-node-12', script: 'app.js', exec_interpreter: '/home/.nvm/versions/node/v12.18.3/bin/node' },{ name: 'app-node-14', script: 'app.js', exec_interpreter: '/home/.nvm/versions/node/v14.15.0/bin/node' }]};···

6 这个 开发环境暴露出来的东西有点多啊

主要是 3公司租的小机器,没必要强上 docker 。。

怕啥,直接 git clone 然后 install ,yarn start:dev 我司根本不怕的

3

#68 docker 镜像,每次的项目更新,package 是重新下载 node_module 吗,打包的 node 的 app ,是放镜像里面还是放外面

7 包里自带 node 二进制文件

AWS + Serverless

这个怎么玩?直接写云函数?那些类似 koa 的框架 api 怎么搞

666666

对 用函数 lambda 满足要求 koa 可用可不用 我们选择 graphql

就是因为 npm 包的问题,所以每次 release 都是放到镜像里面;如果是拉单个 images 完整包肯定很大吗,但是通过 docker push 往镜像管理上传的时候,node 与 os 本体部分是公共抽离的,只有 node_modules 和程序的大小;

感觉有点超前,周边没有用这个的...

响应不会特别快 国内我估计接受不了

dist 放在 nginx 里的是哪种

原来是 2+5 k8s 里面跑 pm2 镜像

原来是 3+5 k8s 里面跑 pm2 镜像

#28 serverless ,方便个人感觉第二,目前能排第一的只能是 Vercel

使用 pm2 ,就像使用 supervisorD 那么错正确的做法应该是 systemd/docker 直接运行你的应用程序入口

pm2 我不光跑 node ,python 什么的也用,实在是太好用了

pm2

自己的项目 4

使用 systemd 呢?

用的 docker ,但是一直觉得 docker 镜像太大了,起步几百兆,同样的 java 项目就才几十兆

#27 方便交流下平常是怎么使用 serverless 的么?会用到它的哪些能力?我最近也在做一个 Serverless 领域的项目,希望能给开发者带来更好的开发体验:开发者只需要写 TS ,就能够部署到自己的 AWS 、阿里云 等云账户,云间迁移不需要修改代码。所以,想了解下现有 serverless 工具的用户是怎么用的,以及会不会遇到什么问题~ github.com/pluto-lang/pluto

终于发现国内使用 Lambda 的人了,我想问一下,你会用到 AWS 的 BaaS 组件么,例如 DynamoDB 之类的,然后在 Lambda 调用? 你在开发这类应用的时候,有没有感觉开发过程很繁琐,需要在各个地方点来点去,有没有感觉权限配置之类的很复杂?想了解一下你的使用感受。我最近在做一个 Serverless 领域的项目,开发者只需要写 TS ,自动推导代码依赖的 BaaS 组件,自动创建 BaaS 组件,和 FaaS 函数,并且自动配置好权限。所以,我想了解下开发者需不需要这类工具。 github.com/pluto-lang/pluto

#80 方便交流下平常是怎么使用 serverless 的么?会用到它的哪些能力?我最近也在做一个 Serverless 领域的项目,希望能给开发者带来更好的开发体验:开发者只需要写 TS ,就能够部署到自己的 AWS 、阿里云 等云账户,云间迁移不需要修改代码。所以,想了解下现有 serverless 工具的用户是怎么用的,以及会不会遇到什么问题~ github.com/pluto-lang/pluto

目前我用的是 systemd 运行,但感觉不是很舒服。用的 nest.js 然后 build 后上传服务器 需要在服务端 npm install ,这里感觉装依赖有点麻烦,不知道有没有办法打包的时候将用到的依赖一起打包