V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
cs3230524
V2EX  ›  Java

JVM、运维大佬过来看看这个问题

  •  
  •   cs3230524 · 2022-10-05 22:17:47 +08:00 · 2928 次点击
    这是一个创建于 766 天前的主题,其中的信息可能已经有所发展或是发生改变。

    普通的 java web 项目,在一个多核心的服务器上部署多个实例有意义吗?

    假如环境: 服务器:32c64g 容器:tomcat

    在这样的情况下: 1 个 tomcat1 个应用 1 个 tomcat10 个相同应用 10 个 tomcat1 个应用

    这 3 个效果是差不多的吗?运维层面需要针对这种多核部署多个应用有意义吗?

    11 条回复    2022-10-08 10:42:31 +08:00
    night98
        1
    night98  
       2022-10-06 01:42:41 +08:00
    1 个 tomcat1 个应用
    1 个 tomcat10 个相同应用
    10 个 tomcat1 个应用

    非要选的话,最后一个吧
    第一种其实还行,最简单,无非是如果要求最佳性能的情况下,需要对 tomcat 默认参数进行调整
    第二个,没啥意义,徒增复杂度
    第三种,理解了半天,应该意思是部署 10 个 tomcat ,里面部署相同的应用吧
    这种冗余程度最高,只要主机不挂基本能保持对外服务,但是你 32C64G 应该用不到部署这么多实例吧

    没啥高可用的要求的情况下,选第一种就行了,大概率你们服务也不会有太高的并发,调下 jvm 最大堆大小基本上就没啥要调整的了,实在要调整的话改下 tomcat 默认线程数基本上就完事了
    rrfeng
        2
    rrfeng  
       2022-10-06 04:31:10 +08:00 via Android
    单机多实例也就平滑升级有点用。jvm 又不是只能用单核的。
    wangritian
        3
    wangritian  
       2022-10-06 04:48:31 +08:00
    如果 web 程序是多线程或线程+协程混合工作,启动 1 个进程即可
    如果是纯协程或全异步事件驱动工作,启动多个进程可以提高性能,数字以压测为准
    xuanbg
        4
    xuanbg  
       2022-10-06 08:42:45 +08:00
    一般情况下,在同一台物理主机上部署多个相同应用的实例没什么意义。因为 tomcat 又不是单线程的,有并发的请求进来,tomcat 也会并发处理。

    如果是为了充分利用机器的性能,可以部署多个不同的应用。如果是为了容灾,那就多部署几台物理主机。
    Jiajin
        5
    Jiajin  
       2022-10-06 10:40:23 +08:00
    应用不中断升级角度来说有用,其他基本无用
    lmshl
        6
    lmshl  
       2022-10-06 10:56:42 +08:00 via iPhone
    理论上来说应该是“ 1 个 tomcat1 个应用”性能最好,线程池会探查操作系统核数的,如果应用是协程开发的话更应该这样了。

    实际上部署 2-3 个都是可以接受的,但更多属实没必要
    DonaldY
        7
    DonaldY  
       2022-10-06 11:29:53 +08:00
    了解到,是在一个大的物理机上划分虚拟机,然后分配给开发。
    paranoiagu
        8
    paranoiagu  
       2022-10-06 15:57:40 +08:00 via Android
    第二种方案绝对不可以。
    ledkk
        9
    ledkk  
       2022-10-07 00:55:30 +08:00
    一、1 个 tomcat1 个应用
    二、1 个 tomcat10 个相同应用
    三、10 个 tomcat1 个应用
    ======================
    方案三比较合适,但具体是 10 个 tomcat 还是 8 个 tomcat 需要实际数据验证。 运维层面考虑后续的升级、部署上都需要对业务无感。性能层面一、二、三需要做对比验证,这个和程序业务实现、tomcat 的运行参数有很大的关系。同一个 JVM 虽然能共享一些数据,减少性能开销,但更多的线程也会带来更剧烈的资源争抢。多个 JVM ,内存会存在一定的浪费,高版本的 JDK ,这块可以尝试 ACDS 。
    bthulu
        10
    bthulu  
       2022-10-07 16:31:36 +08:00
    我选择 1 个 tomcat10 个不同应用, 省钱啊, 要问挂掉了怎么办, 重启啊, 几秒钟到十几秒钟的不可用时间也等不了么?
    Aresxue
        11
    Aresxue  
       2022-10-08 10:42:31 +08:00
    说一下他们的差别好了, 有没有意义自己见仁见智吧
    1.服务器上只有一个 jvm ,code cache 什么的只有一份,内存回收的效率比较依赖 gc ,g1 和 zgc 对大内存比较友好,如果是比较老的 jvm 可能会比较拉胯,值得注意的是超过 32G 以后 jvm 的指针压缩会失效导致内存利用率下降;
    2.1 个 tomcat 启动 10 个 jvm 进程,这种我认为和第三种区别不大,唯一的区别是所以应用的配置比较容易保持一致,但你本身暴露端口之类的配置还是要在启动一个实例后修改(不然会端口冲突),个人角度认为没必要;
    3.这种算是目前比较主流的方式,优点就是可以滚动升级服务没有不可用时间,同时如果代码有内存泄露等问题,能够先局部重启保证服务可用再保留部分应用慢慢排查问题,很多问题的影响范围可以被缩小,它的缺点是同样的 code cache 会有重复的多份比较浪费内存,一些内存级的缓存也都会被缓存多份,还有就是一些单 jvm 没有问题的代码可能会出现一些问题(这个属于代码的问题可以避免和修复)
    题外话:一般的 java web 都是 io 型项目,其实 cpu 都是利用不充分的,32c 和 64g 基本上两者的利用率是对不齐的,可以再多请求一些内存资源
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2697 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 06:47 · PVG 14:47 · LAX 22:47 · JFK 01:47
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.