Spring Boot 新手。正在学习中,新项目用到 Spring Boot,但在 0 宕机发布这个问题上有疑惑。
由于之前使用 PHP,发布流程中使用新版代码替换原有代码即可。
了解到 java 可以使用源代码、jar、war+tomcat 这几种方式运行。了解到有 spring-loaded 和 devtools 与热部署有关。(闻其名总感觉像类似像 webpack 中的 hot-reload...,仅限开发使用,用在生存环境会不会有性能问题?)
目前我使用的是 jar 包,每次发布需要中断约 15s 的时间(单机 1G+1Core)。我怀疑是我姿势不对,请不吝赐教。
1
mind3x 2019-04-16 00:23:39 +08:00 2
你没有 load balancer 和冗余节点,单机谈什么热部署……
|
2
misaka19000 2019-04-16 00:29:05 +08:00 via Android 1
多负载 + 优雅停机
|
3
zjp 2019-04-16 01:06:02 +08:00 via Android
有再加一层代理的可以用单机多实例,启动完切代理端口。不过 1G 内存有点悬…
|
4
hyperbin 2019-04-16 01:07:54 +08:00 via Android
Java 还能源码部署?
|
5
WordTian 2019-04-16 02:16:18 +08:00 via Android
多节点加负载均衡吧
|
6
yuikns 2019-04-16 02:52:28 +08:00 via iPhone 1
试试 docker ?
|
7
petercui 2019-04-16 06:30:21 +08:00
凌晨停机部署
|
8
jbiao520 2019-04-16 06:50:07 +08:00 via Android
滚动部署
|
9
Cbdy 2019-04-16 07:03:59 +08:00 via Android
lb 了解一下
|
10
xuanbg 2019-04-16 07:55:35 +08:00 1
idea 有热部署功能,但仅限于在 idea 里面运行或调试。生产环境就只能做双机热备或分布式才能实现不停机更新了。其实不停机热更也只适用于版本兼容的情况,不兼容的时候,热更是要出大问题的!
|
11
hangszhang 2019-04-16 08:08:01 +08:00
生产环境的热部署没有多大意义
|
12
lhx2008 2019-04-16 08:10:32 +08:00 via Android 1
你需要前端再带一个 nginx,然后旧的不要停,直接起一个新的 jar,然后 nginx 改端口,平滑重启,把旧 jar 包的 kill 掉
|
13
gramyang 2019-04-16 08:25:57 +08:00
不是都说 Java 对热部署的支持不友好,最好不要热部署的吗?
|
14
Sharuru 2019-04-16 08:32:29 +08:00 via Android
单机谈什么热部署...
你 PHP 上传代码不要时间吗...顶多说是线上修 bug 的时候方便点( doge ) |
15
daryu 2019-04-16 09:09:40 +08:00
用 docker swarm 的 stack destory,弄多个实例做灰度发布或者金丝雀发布
|
16
mritd 2019-04-16 09:13:18 +08:00 via iPhone
Kubernetes 了解一下
|
17
cominghome 2019-04-16 09:14:58 +08:00
直接覆盖代码你怕是没死过...
|
18
kaneg 2019-04-16 09:15:04 +08:00 via iPhone 3
能接受 1G1 核的配置,还接受不了 15s 的停机时间?
|
19
lawler 2019-04-16 09:22:01 +08:00 1
所以,你知道了为什么 PHP 是世界上最好的语言,而 Java 不是了吧?
|
20
whp1473 2019-04-16 09:47:49 +08:00
if(机器数>=2){ while(关闭一台旧的,启动一台新的) }
|
21
huijiewei 2019-04-16 09:54:01 +08:00 1
nginx 后面跑 2 个 jar 实例 热切换
|
22
allanzhuo 2019-04-16 09:55:59 +08:00
生产环境热部署,真的是不怕死啊
|
23
keymao 2019-04-16 10:38:05 +08:00
单机热部署啥... 多个负载 切换一个 更新一个呗... 轮换着来 业务就不会停了...
|
24
chendy 2019-04-16 10:42:54 +08:00
前面放一个反代,启动新节点,启动之后把流量切过去就行了
不过 1c1g 的配置也没多大的量吧,停一会就停一会吧… |
25
zifangsky 2019-04-16 11:13:58 +08:00
不要问,问就是:PHP 是世界上最好的语言!
|
26
hantsy 2019-04-16 11:24:43 +08:00
You should consider applying blue-green pipelines with DevOps.
It is an issue of the languages/frameworks you are using, you have to envolve your development progress. |
27
LokiSharp 2019-04-16 11:46:41 +08:00
多节点负载均衡
|
28
gscoder 2019-04-16 11:50:32 +08:00
集群部署呗。。开发模式下那种热更新浪费性能,没有用在生产环境的。你说的这种只有脚本型语言才做得到,比如 php
|
29
loveCoding 2019-04-16 11:52:10 +08:00
nginx 反代两个 jar 实例端口就行
|
30
abcbuzhiming 2019-04-16 11:57:27 +08:00
我就说很多人误以为 PHP 不需要编译,所以就能热部署了。实际上你们这种玩法就是错的。根本达不到真的热部署的要求
|
31
hahaayaoyaoyao 2019-04-16 12:31:26 +08:00 via Android
@abcbuzhiming 是的
|
32
luozic 2019-04-16 13:00:25 +08:00
冗餘 (網關 app 容器 數據庫)+ 分佈式并發控制架構才有 不停機更新,其他的估計是’自以爲“的不停機更新。
|
33
ala2008 2019-04-16 16:35:29 +08:00
负载均衡
|
34
yc8332 2019-04-16 16:50:32 +08:00 1
其实楼主的意思就是不停机部署。。。单机应该是不可能,不然就是单机起两个,不同端口,启完了再切过去新端口
|
35
coolzilj 2019-04-16 17:58:47 +08:00 via Android 1
你们吓得楼主都不敢出来说话了
|
37
freedomshi 2019-04-16 19:38:26 +08:00
还是 php 最好。。。
|
38
a663 2019-04-16 19:49:25 +08:00 via Android
k8s
|
39
hillMonkey 2019-04-16 19:53:26 +08:00
Portainer + Swarm
|
40
rffan 2019-04-16 21:26:54 +08:00
没办法单节点热部署,无论如何都得重启 tomcat 等容器。
|
41
xfriday 2019-04-16 21:46:25 +08:00
k8s 单节点也可以滚动更新的,更新过程中旧副本集继续提供服务,更新完成并成功才切换到新副本集,如果失败自动回滚
|
42
Infernalzero 2019-04-16 23:26:50 +08:00
你想就靠单机解决这个问题的话就只能不用 spring 这套了,micronaut 那套就是为了优化这个问题,在编译时完成了依赖注入
|
43
qiyuey 2019-04-17 09:29:52 +08:00
集群的事情,不要靠单机解决
|
44
ricwang 2019-04-17 15:47:43 +08:00
docker 部署,nginx 做负载,起一个新版本的容器,正常后再 kill 原本旧版本的容器
我的处理方式 |
45
wizzer 2019-04-22 11:22:42 +08:00
自带运维中心,演示地址 https://nutzwk.wizzer.cn
|
46
zhaoxueqin248 2020-05-06 16:03:12 +08:00
@mind3x 单纯请教,就是以前看过 Nginx 就是单机 直接更换 sbin/nginx 二进制执行文件,新老 NGINX 进程替换, 来进行的 Nginx 升级。讲道理 ,Spring-Boot 应该从技术上也是是可行的吧?
|