社区
网络通信/分布式开发
帖子详情
最近用对完成端口做的服务器程序做压力测试,发现服务器的内存慢慢减少:(
LittleStar
2006-04-23 09:49:22
客户端用asynselect,一收到服务器的消息就立即发送数据给服务器。中间没有暂停,此时服务器的内存会慢慢减少。如果客户端暂停发送与接收,服务器的内存又会慢慢增加,再接着发送数据服务器的内存又慢慢减少。
请问为什么服务器会产生这样的问题?该如何解决。
...全文
639
11
打赏
收藏
最近用对完成端口做的服务器程序做压力测试,发现服务器的内存慢慢减少:(
客户端用asynselect,一收到服务器的消息就立即发送数据给服务器。中间没有暂停,此时服务器的内存会慢慢减少。如果客户端暂停发送与接收,服务器的内存又会慢慢增加,再接着发送数据服务器的内存又慢慢减少。 请问为什么服务器会产生这样的问题?该如何解决。
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
11 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
leaber
2006-04-29
打赏
举报
回复
竟然写错了,异步每次投递一个请求都是要分配新的内存的 应该是每一个新的连接都是要分配新的内存块。
leaber
2006-04-29
打赏
举报
回复
CPU占用率高吗? 异步每次投递一个请求都是要分配新的内存的,如果没及时发送还会发生内存锁定的情况。查一下,只要没有内存泄露就好了。
另,不知道你是否开内存池?频繁的创建内存块会产生内存碎片的,然后稳定性就是个问题了。
constantine
2006-04-29
打赏
举报
回复
学习一下,不太会,只看过一下
LittleStar
2006-04-25
打赏
举报
回复
哎,不清楚怎么写。
昨晚又做了一个简单的wasAsynSelect的客户端进行测试。服务器端是最简单的iocp server。发现连续不断的测试,并没有导致服务器端的内存减少。看来要好好调试一下原来的服务器端程序了。
客户端用send recv连续发送和接收,过一段时间就会堆栈溢出。后来换成wsasend wsarecv就再也不会出现堆栈溢出。
飞天揽月
2006-04-24
打赏
举报
回复
不错,学习!!!
bluesky23
2006-04-24
打赏
举报
回复
UP
shadowfish
2006-04-24
打赏
举报
回复
关注中,最近也在研究完成端口
clasj
2006-04-24
打赏
举报
回复
我觉得你找到的那篇文章说的已经很清楚了,你试过没有啊?
LittleStar
2006-04-24
打赏
举报
回复
没人做iocp吗?
深宇
2006-04-23
打赏
举报
回复
能否贴一些关键性的代码上来,不然别人怎么帮你解决问题呢?
LittleStar
2006-04-23
打赏
举报
回复
搜了一下,发现有文章可能会有帮助,可是我对完成端口粗通皮毛。实在搞不清楚具体的实现方式。
(引自flashboy (爱写程序的小绵羊) )
一、 WSAENOBUFS 错误问题。
这个问题通常很难靠直觉发现,因为当你第一次看见的时候你或许认为是一个内存泄露错误。假定已经开发完成了你的完成端口服务器并且运行的一切良好,但是当你对其进行压力测试的时候突然发现服务器被中止而不处理任何请求了,如果你运气好的话你会很快发现是因为WSAENOBUFS 错误而影响了这一切。
每当我们重叠提交一个send或receive操作的时候,其中指定的发送或接收缓冲区就被锁定了。当内存缓冲区被锁定后,将不能从物理内存进行分页。操作系统有一个锁定最大数的限制,一旦超过这个锁定的限制,那么就会产生WSAENOBUFS 错误了。
如果一个服务器提交了非常多的重叠的receive在每一个连接上,那么限制会随着连接数的增长而变化。如果一个服务器能够预先估计可能会产生的最大并发连接数,服务器可以投递一个使用零缓冲区的receive在每一个连接上。因为当你提交操作没有缓冲区时,那么也不会存在内存被锁定了。使用这种办法后,当你的receive操作事件完成返回时,该socket底层缓冲区的数据会原封不动的还在其中而没有被读取到receive操作的缓冲区来。此时,服务器可以简单的调用非阻塞式的recv将存在socket缓冲区中的数据全部读出来,一直到recv返回 WSAEWOULDBLOCK 为止。
这种设计非常适合那些可以牺牲数据吞吐量而换取巨大并发连接数的服务器。当然,你也需要意识到如何让客户端的行为尽量避免对服务器造成影响。在上一个例子中,当一个零缓冲区的receive操作被返回后使用一个非阻塞的recv去读取socket缓冲区中的数据,如果服务器此时可预计到将会有爆发的数据流,那么可以考虑此时投递一个或者多个receive来取代非阻塞的recv来进行数据接收。(这比你使用1个缺省的8K缓冲区来接收要好的多。)
总结:
解决方法一:
投递使用空缓冲区的 recevie操作,当操作返回后,使用非阻塞的recv来进行真实数据的读取。因此在完成端口的每一个连接中需要使用一个循环的操作来不断的来提交空缓冲区的receive操作。
解决方法二:
在投递几个普通含有缓冲区的recevie操作后,进接着开始循环投递一个空缓冲区的recevie操作。这样保证它们按照投递顺序依次返回,这样我们就总能对被锁定的内存进行解锁。
接口
压力测试
:Jmeter【专门
做
接口
压力测试
】
Postman是一个很方便的测试工具,但是比起Jmeter来,它在性能测试和
压力测试
方面的功能要少很多。Jmeter功能非常强大,虽然我感觉不太简约,但是它可以作为专业的性能测试工具使用。 QPS/Throughput极限测试: 安装Jmeter:http://jmeter.apache.org/download_jmeter.cgi 参考资料: 接口
压力测试
工具(推荐) 如何用Jmeter
做
接口测试 [JM_03]JMeter性能测试基础实战之QPS检测过程解析 【jmeter】jmeter测试网
JMeter接口
压力测试
实战教程
章节一
压力测试
课程介绍 1、2018年亿级流量压测系列之Jmeter4.0课程介绍和效果演示 简介: 讲解课程安排,使用的Jmeter版本 讲课风格:涉及的组件,操作配置多,不会一次性讲解,会先讲部分,然后在后续操作中
慢慢
补充,更容易消化和理解 2、常用
压力测试
工具对比 简介:目前...
谷粒商城--性能调优与
压力测试
--高级篇笔记五
谷粒商城–性能调优与
压力测试
–高级篇笔记五 1.
压力测试
压力测试
考察当前软硬件环境下系统所能承受的最大负荷并帮助找出系统瓶颈所在。 压测都是为了系统在线上的处理能力和稳定性维持在一个标准范围内,
做
到心中有数。 使用
压力测试
, 我们有希望找到很多种用其他测试方法更难
发现
的错误。 有两种错误类型是:
内存
泄漏, 并发与同步。 有效的
压力测试
系统将应用以下这些关键条件:重复, 并发, 量级, 随机变化。 1.1 性能指标 响应时间(Response Time:RT) 响应时间指用户从客户端发起一个请求开始,
select epoll
完成
端口
select、poll、epoll之间的区别总结[整理] select,poll,epoll都是IO多路复用的机制。I/O多路复用就通过一种机制,可以监视多个描述符,一旦某个描述符就绪(一般是读就绪或者写就绪),能够通知程序进行相应的读写操作。但select,poll,epoll本质上都是同步I/O,因为他们都需要在读写事件就绪后自己负责进行读写,也就是说这个读写过程是阻塞的,而异步I/
从刷抖音说起:你每天都在 “用”
服务器
,却可能不认识它
写了这么多,其实想告诉大家:
服务器
工程师不是 “修电脑的”,而是数字世界的 “隐形守护者”—— 我们搭建的
服务器
集群,是支撑微信、抖音、淘宝这些 APP 运行的 “基建”;我们
做
的运维和优化,是保证你刷视频不卡、下单不崩的 “后盾”。这个岗位不轻松 —— 要熬夜处理故障,要不断学习新技术,要承受业务中断的压力;但也很有成就感 —— 当你看到自己搭建的
服务器
集群扛住了双 11 的流量,当你快速解决故障让业务恢复正常,当你用自动化工具解放了重复劳动,你会觉得所有的辛苦都值得。
网络通信/分布式开发
1,594
社区成员
32,947
社区内容
发帖
与我相关
我的任务
网络通信/分布式开发
Delphi 网络通信/分布式开发
复制链接
扫一扫
分享
社区描述
Delphi 网络通信/分布式开发
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章