每日百万交易的支付系统如何设置堆大小

看了一遍文章,想做个记录和总结

正常的支付系统的流程

 假如每天100W个订单,然后主要是平均在几个小时内 100W/3600 大概是277个,假如三个小时下单100W个订单那么,差不多每秒100个订单,如果我们有三台服务器,那么每个服务器大概每秒处理30个订单。

int 4个字节

long 8个字节,假如Order类一共20个字段,差不多200多字节,我们可以算大点500字节 500*30=15000 差不多15KB,每秒生成15K的对象然后执行完之后,没有变量引用了就变成垃圾,就需要回收 方法中肯定还有其它对象,我们一般把它扩大10-20倍 那么每秒将会生成300kB-1MB的垃圾 按照1MB来算的话 如果我们是2C4G的服务器 出去安装软件所占的内存,JVM大概只有2G,

年轻代给1G的话大概差不多20分钟就要发生一次YongGC有点短了,建议是采用 4C8G,给年轻代配置2G差不多40分钟左右差不多发生一次YongGC,反正是GC发生的次数越少越好

在配置JVM的时候要尽量将年轻代配置大一点,因为如果年轻代内存不够会直接进入到老年代,老年代的对象执行完了,就没有引用了,就成了垃圾,如果这样的老年代对象存活得多的话,那么就容易发生old GC old GC 容易导致程序出现卡顿,还有YongGC也尽量少一点出现,因为YongGC也是容易发生程序卡顿的现象 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值