czf2505 2019-08-02 14:01 采纳率: 0%
浏览 589
已结题

WCF 百万级数据获取 并发量达到3个,CPU就突然飙到80以上,然后程序超时?

1 楼主用WCF做的是一个获取数据,生成excel文件的服务.大致的思路就是用EF结合LINQ获取数据,然后生成excel。

2 数据量小的时候代码运行没有问题

3 只有一个或者两个请求百万级数据,程序运行没有问题

4 但是当并发数达到3个以后,而且请求的也是百万级数据的时候,CPU占用就超过80了,并发数两个的时候都没有到30,这CPU飙升速度太异常了。下面是获取数据的主要代码

var exportList = from dataMain in dataList
join fina in finaNonameList on dataMain.FnId equals fina.Id into aa
from a in aa.DefaultIfEmpty()
join dep in _depList on dataMain.DeptId equals dep.Id into bb
from b in bb.DefaultIfEmpty()
join pub1 in pubList1 on dataMain.BusTypeId.ToString() equals pub1.Value
into cc
from c in cc.DefaultIfEmpty()
join pub2 in pubList2 on dataMain.OpeBusinessesId.ToString() equals
pub2.Value into dd
from d in dd.DefaultIfEmpty()
orderby dataMain.Id descending
select new ExportRePayInformationViewModel
{
Id = dataMain.Id,
FnId = dataMain.FnId,
SubContractNum = dataMain.SubContractNum,
InnerCode = dataMain.InnerCode,
InnerName = dataMain.InnerName,
};

        data = exportList.ToList();
        return data;    


百万级数据量的时候,代码运行到这里“ data = exportList.ToList();”,CPU占用就马上超过80了,然后程序就超时啦。跪求高手指点一二
作者:czf2505
来源:CSDN
原文:https://blog.csdn.net/czf2505/article/details/98183051
版权声明:本文为博主原创文章,转载请附上博文链接!

  • 写回答

2条回答 默认 最新

  • threenewbee 2019-08-02 14:13
    关注
    tolist操作需要大量的内存,如果你内存不够,可能会造成问题。
    你可以返回 IEnumerable<ExportRePayInformationViewModel> 代替 List<ExportRePayInformationViewModel> 
    
    评论

报告相同问题?

悬赏问题

  • ¥15 运筹学排序问题中的在线排序
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥30 求一段fortran代码用IVF编译运行的结果
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥30 python代码,帮调试,帮帮忙吧
  • ¥15 #MATLAB仿真#车辆换道路径规划