看了一遍文章,想做个记录和总结
正常的支付系统的流程
假如每天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也是容易发生程序卡顿的现象