zoukankan      html  css  js  c++  java
  • WebApi系列~HttpClient的性能隐患

    最近在进行开发过程中,基于都是接口开发,A站接口访问B接口接口来请求数据,而在这个过程中我们使用的是HttpClient这个框架,当然也是微软自己的框架,性能当前没有问题,但如果你直接使用官方的写法,在高并发时候,会有很大的性能隐患,因为它官方使用的是using的方式,而对于请求量比较大时,这种方法对TCP建立也会过高,即使用完马上释放也会有很多time_out的请求,所有决定把某个用到httpclient的组件做成静态化的!

    明细

    统计

    调用,中规中矩的写法

    复制代码
                    using (var http = new HttpClient())
                    {
                        var json = JsonConvert.SerializeObject(new
                        {
                            target_index = projectName,
                            timestamp = DateTime.Now.ToUniversalTime().ToString("yyyy-MM-ddTHH:mm:ss.fffZ"),
                            Level = level.ToString(),
                            Message = message
                        });
                        json = json.Replace("target_index", "@target_index").Replace("timestamp", "@timestamp");
                        var httpContent = new StringContent(json, Encoding.UTF8);
                        httpContent.Headers.ContentType = new MediaTypeHeaderValue("application/json");
                        var result = http.PostAsync(apiLoggerUri, httpContent).Result;
                    }
    复制代码

     优化它,做成TCP长链接,所以请求走一个通道

    复制代码
            private static readonly HttpClient _httpClient;
            private ApiLoggerOptions _config;
    
            static ApiLogger()
            {
                _httpClient = new HttpClient();
                _httpClient.Timeout = new TimeSpan(0, 0, 10);
                _httpClient.DefaultRequestHeaders.Connection.Add("keep-alive");
            }
    复制代码

    keep-alive关键字可以理解为一个长链接,超时时间也可以在上面进行设置,例如10秒的超时时间,当然并发量太大,这个10秒应该会抛弃很多请求

    发送请求的代码没有了using,即这个httpclient不会被手动dispose,而是由系统控制它,当然你的程序重启时,这也就被回收了。

    复制代码
                   var json = JsonConvert.SerializeObject(new
                    {
                        target_index = projectName,
                        timestamp = DateTime.Now.ToUniversalTime().ToString("yyyy-MM-ddTHH:mm:ss.fffZ"),
                        Level = level.ToString(),
                        Message = message
                    });
                    json = json.Replace("target_index", "@target_index").Replace("timestamp", "@timestamp");
                    var httpContent = new StringContent(json, Encoding.UTF8);
                    httpContent.Headers.ContentType = new MediaTypeHeaderValue("application/json");
                    _httpClient.PostAsync(apiLoggerUri, httpContent).Wait();
    复制代码

    通过上面的改造,我们我系统性能得到了改善,TCP的连接数也降下来了

    所以对于长链接的多路复用技术,相对于请求过多的情况还是最省资源的!

  • 相关阅读:
    ES6之6种遍历对象属性的方法
    css自定义滚动条样式,自定义文字选择样式,设置文字不被选择
    js img转换base64
    移动端rem造成的很多问题
    移动端边框1像素的问题
    【小练习1】如何制作“表单”
    2015-09-24 第六节课 (CSS补充和html 标签讲解、浏览器兼容性)
    2015-09-22 第四节课 CSS块级元素 行内元素 浮动 盒子模型 绝对定位、相当定位和固定定位
    2015-09-21 第三节课 css属性 border(边框)、background(背景)
    html你可能还不知道的一些知识点
  • 原文地址:https://www.cnblogs.com/EasyLive2006/p/7698857.html
Copyright © 2011-2022 走看看