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

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

前言

.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 运行环境
  1. 用 Postman 访问一个有 EF 操作的 API,速度明显比之前快

总结

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

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

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


相关文章
|
19天前
|
API 数据安全/隐私保护 UED
探索鸿蒙的蓝牙A2DP与访问API:从学习到实现的开发之旅
在掌握了鸿蒙系统的开发基础后,我挑战了蓝牙功能的开发。通过Bluetooth A2DP和Access API,实现了蓝牙音频流传输、设备连接和权限管理。具体步骤包括:理解API作用、配置环境与权限、扫描并连接设备、实现音频流控制及动态切换设备。最终,我构建了一个简单的蓝牙音频播放器,具备设备扫描、连接、音频播放与停止、切换输出设备等功能。这次开发让我对蓝牙技术有了更深的理解,也为未来的复杂项目打下了坚实的基础。
102 58
探索鸿蒙的蓝牙A2DP与访问API:从学习到实现的开发之旅
|
6天前
|
数据采集 供应链 API
Python爬虫与1688图片搜索API接口:深度解析与显著收益
在电子商务领域,数据是驱动业务决策的核心。阿里巴巴旗下的1688平台作为全球领先的B2B市场,提供了丰富的API接口,特别是图片搜索API(`item_search_img`),允许开发者通过上传图片搜索相似商品。本文介绍如何结合Python爬虫技术高效利用该接口,提升搜索效率和用户体验,助力企业实现自动化商品搜索、库存管理优化、竞品监控与定价策略调整等,显著提高运营效率和市场竞争力。
30 3
|
14天前
|
JavaScript API C#
【Azure Developer】Python代码调用Graph API将外部用户添加到组,结果无效,也无错误信息
根据Graph API文档,在单个请求中将多个成员添加到组时,Python代码示例中的`members@odata.bind`被错误写为`members@odata_bind`,导致用户未成功添加。
37 10
|
26天前
|
存储 应用服务中间件 开发工具
对象存储OSS-Python设置代理访问请求
通过 Python SDK 配置 nginx 代理地址请求阿里云 OSS 存储桶服务。示例代码展示了如何使用 RAM 账号进行身份验证,并通过代理下载指定对象到本地文件。
80 15
|
27天前
|
数据采集 JSON API
如何利用Python爬虫淘宝商品详情高级版(item_get_pro)API接口及返回值解析说明
本文介绍了如何利用Python爬虫技术调用淘宝商品详情高级版API接口(item_get_pro),获取商品的详细信息,包括标题、价格、销量等。文章涵盖了环境准备、API权限申请、请求构建和返回值解析等内容,强调了数据获取的合规性和安全性。
|
5天前
|
数据采集 JavaScript 前端开发
京东商品详情 API 接口指南(Python 篇)
本简介介绍如何使用Python抓取京东商品详情数据。首先,需搭建开发环境并安装必要的库(如requests、BeautifulSoup和lxml),了解京东反爬虫机制,确定商品ID获取方式。通过发送HTTP请求并解析HTML,可提取价格、优惠券、视频链接等信息。此方法适用于电商数据分析、竞品分析、购物助手及内容创作等场景,帮助用户做出更明智的购买决策,优化营销策略。
|
1月前
|
存储 API 数据库
使用Python开发获取商品销量详情API接口
本文介绍了使用Python开发获取商品销量详情的API接口方法,涵盖API接口概述、技术选型(Flask与FastAPI)、环境准备、API接口创建及调用淘宝开放平台API等内容。通过示例代码,详细说明了如何构建和调用API,以及开发过程中需要注意的事项,如数据库连接、API权限、错误处理、安全性和性能优化等。
102 5
|
1月前
|
API Python
【Azure Developer】分享一段Python代码调用Graph API创建用户的示例
分享一段Python代码调用Graph API创建用户的示例
55 11
|
1月前
|
JSON 安全 API
Python调用API接口的方法
Python调用API接口的方法
251 5
|
1月前
|
API Python
利用python淘宝/天猫获得淘宝app商品详情原数据 API
要使用Python获取淘宝/天猫商品详情原数据,需先注册开放平台账号并实名认证,创建应用获取API权限。随后,根据API文档构建请求URL和参数,使用requests库发送请求,处理返回的商品详情数据。注意遵守平台使用规则。