线程池优化
admin
2024-02-08 11:20:04

文章目录

  • Socket 连接数足够,但是 并没有全部被用上!!
  • 线程池优化
  • 问题
    • 使用线程池时需要注意

Socket 连接数足够,但是 并没有全部被用上!!

每次 请求过后,TCP 连接 并没有立即被释放,导致 Socket 无法重用

TCP 连接在 经过 四次握手结束连接后并不会立即释放,而是处于 timewait 状态

会 等待一段时间,以 防止 客户端后续的数据未被接收

调整 TCP 连接结束后 等待时间。但是 Linux 并没有提供这一内核参数的调整,如果 要改必须要自己重新编译内核。幸好还有另一个参数

net.ipv4.tcp_max_tw_bucketstimewait 的数量。默认是 180000。我们调整为6000。然后打开 timewait 快速回收和开启重用

完整的参数优化如下:

# timewait 的数量,默认是 180000。
net.ipv4.tcp_max_tw_buckets = 6000
net.ipv4.ip_local_port_range = 1024 65000# 启用 timewait 快速回收。
net.ipv4.tcp_tw_recycle = 1# 开启重用
# 允许将 TIME-WAIT sockets 重新用于新的 TCP 连接。
net.ipv4.tcp_tw_reuse = 1

线程池优化

计算公式: 每秒 高峰访问次数 * 访问延时 + bufferThread
timeout设为 200ms, 每秒100个请求---->计算结果:100*0.2+10=30 个线程,两台虚拟机 可以解决

如果每秒 访问次数30000怎么办?

30000 * 0.2 + 100 =6100 个线程
6100 / 20 =305 台虚拟机 也可以搞定
虚拟机: 4 个cpu core ,4G内存
物理机 : 十几个cpu core ,几十个G的内存,5~8 个虚拟机,这里 1台物理机=6台虚拟机
305 台虚拟机 = 51 台物理机~搞定

对于线程池大小,一般控制在 10个 左右,20个 以内,最少5个

不同的业务使用不同的线程池,起到线程池隔离!!!

问题

使用线程池时需要注意

子线程的异常,如果 没有被捕获就会丢失 ,可能会 导致后期 根据 日志调试时无法找到原因

相关内容

热门资讯

赤水性价比粮食酒推荐:2025... 赤水性价比粮食酒推荐:2025年酱香酒选购全攻略 一、开篇背景与市场痛点 2025年的赤水河流域酒类...
非白酒板块11月19日跌0.3... 证券之星消息,11月19日非白酒板块较上一交易日下跌0.33%,*ST椰岛领跌。当日上证指数报收于3...
以运河文化赋能产业发展|古贝春... 11月17日至19日,以“新质开新局,聚力创未来”为主题的2025年第六届中国白酒黄淮核心产区高质量...
深夜小酌的灵魂搭档:油炝脆骨,... 油炝脆骨是一道充满锅气与烟火气息的家常菜,以其爽脆的口感和浓郁的香辣风味深受许多人喜爱。这道菜的制作...
初中毕业新征程:为什么西点烘焙... 站在初中毕业的人生路口,许多女孩都在思考:哪条路能通往一个既美好又独立的未来?如果有一条道路,能将女...