zoukankan      html  css  js  c++  java
  • 利用取消机制缓解后台的查询性能瓶颈


    内容:
    利用取消机制缓解后台的查询性能瓶颈,核心在WebAPI查询方法体内关注CancellationToken并适时取消异步任务, 这将大大提高应用的响应能力。

    场景优化:
    1.网络交互 不按超时时间的 【高并发场景下 受CPU 时间片切换到时的超时操作不按设定时间执行】偶发小概率事件
    2.浏览器访问情况下、适用于 APP取消或者网路中断
    1.F5刷新 2.转向其他页面 3.浏览请求被终止

    注意:适用某些长查询或者高并发下任务堆积情况下的取消或熔断

    处理方案 取消令牌
    1.httpclient 三方交互 如极光、大汉、es、权重服务、微信等网络交互的 超时方式
    示例:
    CancellationTokenSource cs = new CancellationTokenSource();
    if (timeOut > 0)
    {
    cs.CancelAfter(timeOut);
    }
    var response = await http.SendAsync(httpRequestMessage,cs.Token);

    2.webapi Http 用户请求取消,终端等

    注入:
    private readonly IHttpContextAccessor _httpContextAccessor;

    //网络请求示例
    var ct = _httpContextAccessor.HttpContext?.RequestAborted ?? default(System.Threading.CancellationToken) ;
    return await client.RequestPasswordTokenAsync(clientRequest,cancellationToken:ct);


    3.ORM dapper 示例 数据库长度

    CancellationTokenSource cs = new CancellationTokenSource();
    cs.CancelAfter(1000);

    var id = (await conn.QueryAsync<int>(
    new CommandDefinition(sqlStr, cancellationToken: cs.Token)
    )).FirstOrDefault();


    注入:
    private readonly IHttpContextAccessor _httpContextAccessor;

    var ct = _httpContextAccessor.HttpContext?.RequestAborted ?? default(System.Threading.CancellationToken) ;

    var id = (await conn.QueryAsync<int>(
    new CommandDefinition(sqlStr, cancellationToken: ct)
    )).FirstOrDefault();

  • 相关阅读:
    go语言时间格式化----go语言学习笔记(二)
    go语言模拟post请求----go语言学习笔记(一)
    beego框架配置mysql
    django---request在url中传值请求其他服务的get请求,获取请求头
    nginx+uwsgi+ubuntu 部署django
    集成jenkins自动安装apk文件
    python数据可视化之flask+echarts(二)
    httpd 2.2 实验小结
    CentOS 6安装详解及PXE 安装
    有关安全知识点及实验小结
  • 原文地址:https://www.cnblogs.com/lhbshg/p/13332369.html
Copyright © 2011-2022 走看看