请问 Nginx+Tomcat 应该部署在物理机还是 Docker 下 性能差距大吗 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
zzzmh
V2EX    问与答

请问 Nginx+Tomcat 应该部署在物理机还是 Docker 下 性能差距大吗

  •  
  •   zzzmh 2024 年 5 月 7 日 1611 次点击
    这是一个创建于 637 天前的主题,其中的信息可能已经有所发展或是发生改变。

    如题
    我是小白,N 年前第一台服务器上我是跟着 CSDN 教程,物理机部署的 Nginx+Tomcat
    后来发现 Tomcat 运行一个月就会假死,进程还在,CPU100%,但是用户访问就会卡到 nginx 超时 504
    后来就用 shell 脚本去检查 Tomcat 端口,发现访问超时或者 http 状态码不是 0 或 200 ,自动重启 tomcat
    后来我发现用 Docker 部署是真的香,安装方便,更新方便,关键是意外终止可以自动重启,可以合理分配内存和交换区
    现在我发现用 Docker 会损失大约 20%的性能(没有实际测试,20%我纯盲猜的),我又想改回物理机直接部署,通过类似 Monit 来监控 Tomcat 状态,不知是否可行
    最主要问下各位前辈是如何部署服务器的,用物理机香还是 docker 香

    8 条回复    2024-05-13 17:07:07 +08:00
    zzzmh
        1
    zzzmh  
    OP
       2024 年 5 月 7 日
    我可能表达的还是不清楚,我的意思是,直接编译安装 Nginx+tomcat ,直接在 linux 执行,这样保全性能,自己写监控方案,还是在 docker 里直接一步到位,保全稳定性,哪个合适,各位前辈是如何部署的
    rsyjjsn
        2
    rsyjjsn  
       2024 年 5 月 7 日   1
    2024 很少有裸跑的,都是 docker 一把梭,反正服务器又不贵,预算有限就换个小众语言,不占内存不就好了
    cslive
        3
    cslive  
       2024 年 5 月 7 日
    你程序有问题,不是 tomcat 问题,估计你内存泄露了
    253874
        4
    253874  
       2024 年 5 月 7 日   1
    根据你的描述,应用场景应该比较简单或者说不是重要的生产环境,问题原因大概率是 bug 引起的计算资源未及时释放,彻底解决就是排查 bug ;临时解决,写个定时任务重启 tomcat
    zzzmh
        5
    zzzmh  
    OP
       2024 年 5 月 8 日
    我说 tomcat 一个月就要重启那个事情已经是 6 、7 年前了,当时代码是有问题,再加上服务器 1C2G1M 吃紧。拿这个举例子主要是因为从此以后我有 PTSD 了,24 小时总感觉他崩溃,总想肉眼检查一下。现在 docker 用久了又想还回去试试。。。感觉楼上说的对,性能不够就加配置
    julyclyde
        6
    julyclyde  
       2024 年 5 月 13 日
    你这个“用 shell 去检查端口”并不解决根本问题啊
    而且它自己也没有意外终止,所以 docker 提供的意外终止之后自动重启的功能其实对你没啥用,而且 docker 也不是独家提供意外终止自动重启

    再加上“直接编译安装”
    感觉你把能犯的错误全都凑齐了
    zzzmh
        7
    zzzmh  
    OP
       2024 年 5 月 13 日
    @julyclyde 请问正确的答案是什么,先不考虑 java 代码,只考虑运维的前提下,如何保证 tomcat 在物理机里稳定是最优解,另外“直接编译安装”我不理解这里有什么问题,我知道的 nginx 安装方式就 2 个,yum 安装和编译安装。
    julyclyde
        8
    julyclyde  
       2024 年 5 月 13 日
    @zzzmh 只考虑运维的情况下,用 systemd 管理 tomcat ,比 docker 少一层,并且 1 号进程天生比 docker 更神圣,因为 systemd 的死活不需要你考虑,但是 dockerD 和 containerD 的死活却无从保证

    自己编译无法保证多次执行为同一结果,多次之间如遇到版本变动,遇到 bug 的时候对他们进行行为方面的比较就没啥意义了
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     3945 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 30ms UTC 01:11 PVG 09:11 LAX 17:11 JFK 20:11
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86