网站首页 > 教程文章 正文
如何在单台服务器上实现百万级长连接,以下是实现该目标进行的一些优化:
1.首先需要准备一台大内存的服务器,装上linux系统,比如rehat、centos(内核版本在2.6.25之上)等。
为什么需要大内存,因为每个连接都需要有读写缓存,具体看第二部内容;
为什么内核版本要在2.6.25之上,因为2.6.25内核之前有个 宏定义,定义了最大文件描述符大小为1024*1024,正好是100万。可以通过/proc/sys/fs /nr_open来设置该值。
2.装好系统后,调整一下系统的参数,在/etc/sysctl.conf中
#定义了系统中每一个端口最大的监听队列的长度,这是个全局的参数,默认值为128 net.core.somaxconn = 2048
#系统读写缓存,默认值
net.core.rmem_default = 262144
net.core.wmem_default = 262144
#系统读写缓存
net.core.rmem_max = 16777216
net.core.wmem_max = 16777216
net.ipv4.tcp_rmem = 4096 4096 16777216
net.ipv4.tcp_wmem = 4096 4096 16777216
net.ipv4.tcp_mem = 786432 3145728 4194304
net.ipv4.tcp_max_syn_backlog = 16384
net.core.netdev_max_backlog = 20000
net.ipv4.tcp_fin_timeout = 15
net.ipv4.tcp_max_syn_backlog = 16384
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_tw_recycle = 1
net.ipv4.tcp_rmem用来配置tcp读缓冲的大小,第一个4096是这个读缓冲的最小值,第三个是最大值,中间的是默认值。zhe在程序中修改读缓冲的大小,但不能超过最小与最大。为了使每个socket所使用的内存数最小,我这里设置默认值为4096。
net.ipv4.tcp_wmem用来配置写缓冲的大小。读缓冲与写缓冲在大小,直接影响到socket在内核中内存的占用,这就是第一条里说的为什么需要大内存。
而net.ipv4.tcp_mem则是配置tcp的内存大小,其单位是页,而不是字节。当超过第二个值时,TCP进入 pressure模式,此时TCP尝试稳定其内存的使用,当小于第一个值时,就退出pressure模式。当内存占用超过第三个值时,TCP就拒绝分配 socket了,查看dmesg,会打出很多的日志“TCP: too many of orphaned sockets”。
另外,服务端需要打开大量的文件描述符,比如200万个,配置如下:
设置nofile为200万(2.6.25内核及其之后版本),这个值是可以通过/proc/sys/fs /nr_open来设置。
现在再设置nofile就可以了:
admin soft nofile 2000000
admin hard nofile 2000000
- 上一篇: Mysql-服务端-扩展配置
- 下一篇: Linux网络性能优化相关策略
猜你喜欢
- 2025-01-18 Nginx-性能优化
- 2025-01-18 SYN洪水攻击的原理,syn洪水攻击的解决办法
- 2025-01-18 C++网络编程之最简单的服务端和客户端
- 2025-01-18 Centos7系统内核优化脚本
- 2025-01-18 OpenStack 计算节点 ARP表 溢出导致批量宕机案例分析
- 2025-01-18 高流量大并发Linux TCP性能调优
- 2025-01-18 TCP之面向连接
- 2025-01-18 CentOS8服务器搭建L2TP服务器(over IPsec)操作指南
- 2025-01-18 网络性能debug参数整理
- 2025-01-18 高并发/高io下,设置linux下文件打开数限制
- 05-11阿里开源MySQL中间件Canal快速入门
- 05-11MyBatis插件开发实战:手写一个分页插件
- 05-11Flask数据库——SQLAlchemy
- 05-11MySQL 到 Hazelcast Cloud 实时数据同步实操分享
- 05-11sqlmap 详解
- 05-11一篇文章让你学会Elasticsearch中的查询
- 05-11Mysql性能优化这5点你知道吗?简单却容易被初学者忽略!
- 05-11Spring Boot 实现 MySQL 读写分离技术
- 最近发表
- 标签列表
-
- location.href (44)
- document.ready (36)
- git checkout -b (34)
- 跃点数 (35)
- 阿里云镜像地址 (33)
- qt qmessagebox (36)
- md5 sha1 (32)
- mybatis plus page (35)
- semaphore 使用详解 (32)
- update from 语句 (32)
- vue @scroll (38)
- 堆栈区别 (33)
- 在线子域名爆破 (32)
- 什么是容器 (33)
- sha1 md5 (33)
- navicat导出数据 (34)
- 阿里云acp考试 (33)
- 阿里云 nacos (34)
- redhat官网下载镜像 (36)
- srs服务器 (33)
- pico开发者 (33)
- https的端口号 (34)
- vscode更改主题 (35)
- 阿里云资源池 (34)
- os.path.join (33)