当前位置: 首页 > news >正文

c 做商务网站方便吗天眼查官方网站

c 做商务网站方便吗,天眼查官方网站,做考试平台的网站,微分销系统怎么做目录 前情提要剩下问题 问题排查解决方案下一步 前情提要 果蔬识别系统性能优化之路(三) 剩下问题 同步数据库数据并初始化ivf依然要8,9秒 问题排查 通过断点加时间打印,发生其实初始化ivf的时间很快,慢的是数据在网络间的传…

目录

    • 前情提要
      • 剩下问题
    • 问题排查
    • 解决方案
    • 下一步

前情提要

果蔬识别系统性能优化之路(三)

剩下问题

同步数据库数据并初始化ivf依然要8,9秒

问题排查

通过断点加时间打印,发生其实初始化ivf的时间很快,慢的是数据在网络间的传输,并在python端的数据解析,无语
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
本地调本地,都要十秒,这不合理,改!

解决方案

因为这里必须要查一次全量数据,然后存入redis并将特征值传给python端进行初始化,所以最快的方案就是舍弃数据传输,直接在python端进行查询并初始化,即在python端查全量数据+设置redis+初始化ivf,虽然不想承认,但确实把python端做重在架构和设计层面可能都是最优解,改吧

  1. python端增加mysql查询
import mysql.connector
from mysql.connector import pooling# 配置数据库连接
db_config = {'host': 'localhost',  # 替换为你的 MySQL 主机地址'user': 'root',  # 替换为你的 MySQL 用户名'password': 'cmkkl407',  # 替换为你的 MySQL 密码'database': 'cnn'  # 替换为你的数据库名称
}
pool = pooling.MySQLConnectionPool(pool_name="mypool", pool_size=5, **db_config)def get_feature_by_store_code(store_code):query = "SELECT id, features FROM feature WHERE storeCode REGEXP %s"results = query_data(query, params=(f"(^|,){store_code}(,|$)",))return resultsdef query_data(query, params):connection = pool.get_connection()cursor = connection.cursor(dictionary=True)cursor.execute(query, params)results = cursor.fetchall()cursor.close()connection.close()  # 连接会被返回到池中return results
  1. 修改sync方法
  def sync(self, store_code):if store_code + '-featureDatabase' in self.ivfObj:del self.ivfObj[store_code + '-featureDatabase']data = get_feature_by_store_code(store_code)def parse_features(item):return orjson.loads(item['features'])with ThreadPoolExecutor() as executor:features_list = list(executor.map(parse_features, data))# 提取所有特征并转换为 NumPy 数组features = np.array(features_list, dtype=np.float32)self.ivfObj[store_code + '-featureDatabase'] = IVFPQ(features)ids = [item['id'] for item in data]return ids

由于python端查出来的json默认会给字符串格式,所以还需要转成json
一个优化小点:

并行处理:使用多线程或多进程并行处理数据。可以使用 concurrent.futures 库中的 ThreadPoolExecutor 或 ProcessPoolExecutor 来加快解析速度。

   def parse_features(item):return orjson.loads(item['features'])with ThreadPoolExecutor() as executor:features_list = list(executor.map(parse_features, data))

同时利用查出了所有id将ids进行返回给nestjs端直接进行redis存储
4. nestjs端修改

 /*** 同步redis* @param storeCode*/async syncRedis(storeCode: string) {const url = 'http://localhost:5000/sync'; // Python 服务的 URLconst s = Date.now();const response = await firstValueFrom(this.httpService.post(url, { storeCode }));const { ids } = response.data;await this.redisService.set(`${storeCode}-featureDatabase`, JSON.stringify(ids));const e = Date.now();console.log(`同步redis耗时:${e - s}ms`);}
  1. 优化后速度减少了一倍
    在这里插入图片描述

下一步

  1. 新建store_feature表,关联storeCode和featureId表,对数据库进行规范化,创建一个新的表来映射storeCode与feature的关系,从而可以使用简单的WHERE条件来充分利用索引
  2. 实现对特征向量ivf的增删改查
http://www.yayakq.cn/news/626131/

相关文章:

  • 温州合作网站网站挂马黑链检测清除工具
  • 秦皇岛建设工程信息网站销售培训课程一般有哪些
  • 如何用社交网站开发客户南宁网红
  • 微信开发网站开发未来前景咨询聊城做网站
  • 制作网站需要哪些成本wordpress怎么static
  • 网站无法链接看WordPress用哪个页面
  • 东营机关建设网站住房和城乡建设部网站造价
  • 网站被挂了黑链如何创建自己的商城
  • 免费摄影网站做网站怎么注册营业执照
  • 什么站做咨询网站好wordpress注册密码忘记
  • 国内如何做国外网站的兼职项目十大经典口碑营销案例
  • 定制网站开发价格长沙人才招聘网长沙58同城招聘网
  • 网站建设都需要那些材料福州网站快速排名
  • 个人业务网站源码php西安做网站哪家便宜
  • 东莞网站公司推广技巧深圳宝安天气
  • 哪里建网站好去西安旅游最佳路线
  • 公司网站建设怎么入账登录网址
  • 在线网站流量查询DW做注册网站
  • 怎么做网站下载链接设计传媒公司logo
  • wordpress弹窗广告帝国网站seo
  • 邢台地区网站建设口碑好网页设计html代码大全居中
  • 关键词库在网站上怎么体现优化网络工程师
  • vs做网站各种控件的使用网站推广关键词
  • 网站建设新闻如何更新怎么建设网站上传音乐
  • 合肥集团网站建设公众号文章存储wordpress
  • 做公益网站怎么赚钱网络营销策划书2000字
  • 珠海网站网站建设网站建设为风险分析
  • 广东网站搭建seo快速排名的方法
  • 带管理后台的网站免费vps试用一年
  • 网站建设需要哪些软件平凉有做企业网站的吗