Asp.Net Core Web Api内存泄漏问题

背景

使用Asp.Net Core Web Api框架开发网站中使用到了tcp socket通信,网站作为服务端开始tcp server,其他的客户端不断高速给它传输信息时,tcp server中读取信息每次申请的byte[]没有得到及时的释放,导致内存浪费越来越多,最终内存溢出,系统崩溃。

示例代码

cs 复制代码
Socket server = new Socket(SocketType.Stream, ProtocolType.Tcp);
IPAddress iPAddress = IPAddress.Parse("127.0.0.1");
IPEndPoint iPEndPoint = new IPEndPoint(iPAddress, 8080);
server.Bind(iPEndPoint);
server.Listen(3);
Task.Run(() =>
{
    Task.Run(() =>
    {
        while (true)
        {
            Socket client = server.Accept();
            while (true)
            {
                byte[] buffer = new byte[client.ReceiveBufferSize];
                int length = client.Receive(buffer);
                if (length > 0)
                {
                    string str = Encoding.ASCII.GetString(buffer, 0, length);
                    Console.WriteLine(str);
                }
                else
                {
                    client.Shutdown(SocketShutdown.Both);
                    client.Close();
                    client.Dispose();
                    break;
                }
            }
        }
    });
});

Console.ReadLine();

客户端使用网络调试助手进行模拟

结论

同样的代码,使用纯控制台项目框架搭建,则正常引发GC,每次申请的buffer数组都得到及时的释放。

而使用Asp.Net Core Web Api框架搭建的项目中跑这个服务端代码,则是这样的,很少引发GC,没有及时回收buffer数组的无效内存空间

解决方案

右键项目文件->编辑它

PropertyGroup属性中添加一个子属性,保存,重新启动项目

XML 复制代码
<ServerGarbageCollection>false</ServerGarbageCollection>

再次观察GC引发的频率和内存使用状况,可以发现内存没有继续暴增了

GC模式

已经有大佬总结,再次不多赘述

讨论.NET Core 配置对GC 工作模式与内存的影响 - YOYOFx - 博客园 (cnblogs.com)

相关推荐
NineData1 分钟前
AI时代的数据对比:DBA还需要盯着屏幕看差异吗?
运维·数据库
jyfool12 分钟前
Ubuntu 远程桌面配置踩坑实录:从 TightVNC 到 x11vnc 的折腾之旅
linux·运维·ubuntu
网硕互联的小客服28 分钟前
服务器防火墙是如何区分正常流量和攻击流量?
运维·服务器·网络
安当加密36 分钟前
基于 RADIUS 的 Linux 服务器双因子认证:从 FreeRADIUS 到轻量级 ASP 方案的演进
linux·运维·服务器
A-刘晨阳1 小时前
【Prometheus】Alertmanager配置钉钉告警
运维·云原生·钉钉·prometheus·监控
西西学代码2 小时前
Flutter---路由与导航
服务器·前端·javascript
wangqiaowq2 小时前
llama.cpp 启动命令优化
运维·服务器
勇敢牛牛_2 小时前
【conreg-client】在Rust中使用向Feign一样的远程调用
网络·rust·feign
double2li2 小时前
linux/unix 段错误捕获【续】
linux·运维·服务器·网络·unix
allway22 小时前
Linux / Unix last Command Examples
linux·运维·unix