你们是怎么部署 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 ,这里感觉装依赖有点麻烦,不知道有没有办法打包的时候将用到的依赖一起打包
现公司涨工资以职级提升为前提,另外,职级提升也不是一定会涨,还需要考虑其他因素,比如部门业绩等。 职级提升有严格的要求,比如,T7 以上必须会 JAVA 全家桶或者机器学习或者…
一、起因 春松客服公开抓取 GitHub 用户邮箱并发送垃圾邮件, 官方仓库反馈后遭到 PUA "受害者有罪论", 且项目管理者 hailiang-wang 认为 "在 Git…
下面是JDK中有关23个经典设计模式的示例,在stakeoverflow也有相应的讨论: http://stackoverflow.com/questions/1673841/…