你们是怎么部署 nodejs 的?
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....
强力推荐一下
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
- 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 ,这里感觉装依赖有点麻烦,不知道有没有办法打包的时候将用到的依赖一起打包
不同安卓手机啊,求问大家,这款手机咋样,想给老婆换个手机。 目前,手持华为 mate30 ,存储不够了主要。 需求:旗舰机,不打游戏,拍照多,512g 存储,支持 5G 。 感…
对我来说,一个好的程序员应该是努力去追求尽可能无错的高质量的符合需求的代码实现。 一些人也许认为好的程序员是那些懂得多门编程语言,懂得很牛技术的程序员,是的,这在某些情况下是对…
波士顿大学的Howard Straubing做了这么一个动画来展示AES加密算法的演示,挺不错的。 点击这里看全屏 转载于酷壳CoolShell 无删改 仅以此纪念陈皓(左…