分享一个解决 EF 性能低的思路,通过 Python 访问心跳侦测 API 保持 EF 在线

15 篇文章 1 订阅
2 篇文章 0 订阅

image

前言

.NET FrameWork EF(Entity Framework)是一个很优秀的 ORM 框架,对于提高工作效率很有帮助,但由于底层原因,在程序启动时,EF 需要初始化和加载模型及其对应的数据库元数据等等,涉及到数据库连接、元数据的加载等过程,导致启动时间较长,让很多程序员对于使用 EF 望而却步,今天分享解决 EF 初始启动慢的一个思路,即通过 Python 访问心跳侦测 API 保持 EF 在线,以避免这个问题,来看看具体是怎么实现的吧?

Step By Step 步骤

  1. 创建一个心跳侦测 API

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Net;
    using System.Text;
    using System.Threading.Tasks;
    using System.Web.Http;
    
    namespace EFSample.Controllers
    {
    	/// <summary>
    	/// 心跳侦测 API
    	/// 第三方程序如 Python 呼叫此 API,保持 EF 连接,提升性能
    	/// </summary>
    	[Route("keepalive")]
    	[AllowAnonymous]
    	public class KeepAliveController : Controller
    	{
    		public IHttpActionResult Index()
    		{
    			// 1. 连接 EF 请求一个数据量少的表数据
    			// ......
    			// 2. 返回
    			return ok();
    		}
    	}
    }
    

    说明:
    EF 请求可以找一个数据量少的表,对于进行 count 操作

  2. 编写 Python 方法,访问心跳侦测 API

    import threading
    import requests
    import datetime
    import schedule
    import time
    import ctypes
    from requests.packages.urllib3.exceptions import InsecureRequestWarning
    
    # 服务器跑,请安装schedule,requests模块
    
    # 正式环境请更换主机地址
    host = 'http://192.168.1.126:8083'
    
    
    # 保持活跃
    def KeepAlive():
    	time.sleep(2)
    	requests.packages.urllib3.disable_warnings(InsecureRequestWarning)
    	r = requests.get(host+'/keepalive',verify=False)
    	print('keepalive:test'+r.text)
    
     
    # 不同数据分开线程
    def run_threaded(job_func):
    	 job_thread = threading.Thread(target=job_func)
    	 job_thread.start()
    
    
    # 保持活跃
    schedule.every(5).minutes.do(run_threaded,KeepAlive)
     
    ctypes.windll.user32.ShowWindow( ctypes.windll.kernel32.GetConsoleWindow(), 6 )
    while True:
    	schedule.run_pending()
    	time.sleep(1)
    
  3. 写一个批处理文件自动执行 Python 文件

    // KeepAlive.bat
    python D:\EFSample\KeepAlive\task.py
    pause
    

测试步骤

  1. 部署 Web Api
  2. 运行批处理
    • 可设为开机自动运行
    • 前提是先安装 Python 运行环境
  3. 用 Postman 访问一个有 EF 操作的 API,速度明显比之前快

总结

.NET Framework EF 的性能问题一直都是程序员们关注的焦点,由于 EF 在某些情况下性能表现不佳,导致了许多程序员对其诟病。针对这个问题,我们可以展开更深入的讨论和研究,在解决 EF 性能问题的过程中,不仅要考虑代码优化和调优的方面,还可以探讨一些新的思路和解决方案,本文抛砖引玉,希望本文所提供的思路和参考能够启发更多程序员在实际项目中尝试并探索更好的解决方案,从而提升 EF 性能

我是老杨,一个奋斗在一线的资深研发老鸟,让我们一起聊聊技术,聊聊人生。

都看到这了,求个点赞、关注、在看三连呗,感谢支持。

  • 9
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值