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

如何制作家具网站外国网站后台

如何制作家具网站,外国网站后台,东莞网站建设 食品厂,兰州网站卡法一、背景与整体架构 在电商、内容推荐等业务里&#xff0c;我们常把 热数据 拆成两层&#xff1a; 数据结构存什么为什么要用它Hash prod:<id>数值型 KV&#xff08;价格、库存、点击数…&#xff09;HINCRBY、HSET 超快&#xff1b;天然适合计数与并发写JSON prodjs:&…

一、背景与整体架构

在电商、内容推荐等业务里,我们常把 热数据 拆成两层:

数据结构存什么为什么要用它
Hash prod:<id>数值型 KV(价格、库存、点击数…)HINCRBYHSET 超快;天然适合计数与并发写
JSON prodjs:<id>结构化/全文/向量字段RediSearch 可直接对 JSON 做全文、过滤、KNN

核心挑战:一次业务写请求 → 两份数据都要最新可见,且

  • 有时必须 强一致(写失败全回滚)
  • 有时需要 高吞吐、可弹性(轻微延迟可接受)

下文给出两种落地方案 + 一套索引迁移套路 + 内存预估方法。

二、Lua 事务双写:强一致实时入库

1.1 典型场景

  • 订单入库、库存扣减、价格改动等 不能容忍写丢失
  • 应用侧不想维护 Redis 事务指令细节
  • 单条写吞吐 < 数千 QPS

1.2 脚本 & 调用

-- save_product.lua  —— 原子写 Hash + JSON
-- ARGV: id  price  stock  jsonBody
local id, price, stock, body = ARGV[1], ARGV[2], ARGV[3], ARGV[4]redis.call('HSET',  'prod:'..id,'price', price,'stock', stock,'ts',    redis.call('TIME')[1])redis.call('JSON.SET', 'prodjs:'..id, '$', body)
redis.call('INCR', 'metrics:prod_write_cnt')
return 'OK'
sha=$(redis-cli SCRIPT LOAD "$(cat save_product.lua)")
redis-cli EVALSHA $sha 0 1001 199 8 \'{"title":"Alpha","desc":"6.7\" AMOLED"}'

1.3 细节拆解

说明
redis.call('HSET' …)写 KV,并记录毫秒时间戳
JSON.SET一次性覆盖全文 JSON;内部触发 RediSearch 索引更新
INCR metrics:…监控指标(可观测)
Lua 脚本天然单线程Redis 内部串行执行 = 原子事务

1.4 优缺点

✅ 优点

  • 真·原子,成功或失败毫无中间态
  • 客户端代码极简:一次 RPC

⚠️ 局限

  • 单节点 Lua 执行;高并发 CPU 上升
  • 脚本更新需重新加载 SHA
  • 脚本逻辑越重,阻塞时间越长 → 建议只做轻量写

三、RedisGears 异步双写:高吞吐流式同步

2.1 典型场景

  • 写入峰值达 数万 QPS+
  • 可接受 <1 ms 索引延迟
  • 希望同步逻辑热插拔、动态升级

2.2 部署一步到位

MODULE LOAD /opt/redisgears/libredisgears.so \Plugin /opt/redisgears/redisgears-python.so

2.3 JSON→Hash Pipeline

# json2hash.py
import json
from redisgears import executeCommand as cmd, GearsBuilderdef sync_hash(r):k, ev = r['key'], r['event']if ev != 'json.set' or not k.startswith('prodjs:'):returnpid = k.split(':',1)[1]body = json.loads(cmd('JSON.GET', k))cmd('HSET', f'prod:{pid}','price', body.get('price', 0),'stock', body.get('stock', 0),'ts',    body.get('updated_at', ''))cmd('INCR', 'metrics:prod_sync_cnt')GearsBuilder('KeysReader') \.foreach(sync_hash) \.register(prefix='prodjs:*', eventTypes=['json.set'])
RG.PYEXECUTE "$(cat json2hash.py)"
事件流原理
JSON.SET ---> KeySpace Event ---> RedisGears Stream ---> Python Function ---> HSET

2.4 优缺点

✅ 优点

  • 写入路径只需操作 JSON,业务简单
  • Gears 代码热更新,不影响主线程
  • 延迟通常在 µs〜ms 级

⚠️ 局限

  • 最终一致,脚本出错会导致滞后
  • 依赖 RedisGears 模块(需运维评估)
  • 集群模式需每分片都部署同脚本

四、索引热迁移:新 Schema 零停机上线

当你需要

  • 新增向量字段 / 改分词 / 改 SORTABLE
  • 重建索引避免碎片(FT.DUMPFT.LOAD 不支持时)

3.1 流程总览

  1. 创建新索引 idx_new,带 SKIPINITIALSCAN
  2. 回填历史FT.ADDHASH or FT.ADD
  3. 对比文档数FT.INFO num_docs
  4. FT.ALIASUPDATE 一行切流
  5. 验证:业务监控 / A/B
  6. 可选删除FT.DROPINDEX idx_old DD

3.2 Bash 脚本速用

redis-cli FT.CREATE idx_new ON JSON PREFIX 1 prodjs: ... SKIPINITIALSCAN
redis-cli --scan --pattern 'prodjs:*' | while read k; doredis-cli FT.ADDHASH idx_new "$k" 1.0 REPLACE
done
[ $(redis-cli FT.INFO idx_old |grep num_docs|awk '{print $2}') \-eq $(redis-cli FT.INFO idx_new |grep num_docs|awk '{print $2}') ] \|| { echo 'doc mismatch'; exit 1; }redis-cli FT.ALIASUPDATE prod_read idx_new   # 零停机切流
# 回滚: redis-cli FT.ALIASUPDATE prod_read idx_old

3.3 实战小贴士

  • 并行回填:用 xargs -P 或多线程脚本
  • 回填期间新写入会即时进入 idx_new(未 SKIP 时)
  • 监控 indexing 指标确保写放大可接受
  • Tag 升级:重建时顺便加 SEPARATOR ";" 等配置

五、RediSearch 容量预估:上线前必做的轰炸测试

4.1 公式来源

组件估算因子含义
倒排表T × 6 MB百万级词条 ×6
Posting 位图D × F × 1.5 MB文档数 × TEXT 字段
SORTABLES × 8 MB排序字段
向量V × dim × dt MBHNSW/FLAT 数据

简化公式

Mem(MB) ≈ (T*6) + (D*F*1.5) + (S*8) + (V*dim*dt/1024)

4.2 样例计算

  • 1M 商品 (D=1)
  • 300 万词条 (T=3)
  • 2 个 TEXT (F=2)
  • 3 个 SORTABLE (S=3)
  • 向量 1M384float32 (V=1, dim=384, dt=4)
Mem ≈ 18 + 3 + 24 + 1.5 ≈ 46.5 MB
≈ 46.5 ×1.2 ≈ 60 MB  (预留 20% + AOF)

上线后 FT.INFOinverted_sz_mb, vector_index_sz_mb
再 cross-check INFO memory,调整参数:

  • 减少 SORTABLE
  • 打 Tag 的 SEPARATOR 优化
  • 向量改 INT8 + 量化

六、结语与延伸阅读

选型结论适用场景
Lua 事务双写写量低 & 强一致
RedisGears 异步高并发写 & 最终一致
ALIAUPDATE 热切Schema 频繁演进业务
容量公式 + INFO上线前粗估 & 线上持续校准
http://www.dtcms.com/wzjs/579130.html

相关文章:

  • 电商网站开发平台一跨境电商软件erp排名
  • 江西建设工程质量管理网站公司用wordpress建站用花钱
  • 怀化本地网站html5企业网站案例
  • 辅助wordpress 页面编辑器网站版面布局对seo
  • 重庆外贸网站建设关注公众号一单一结兼职app
  • 怎样黑网站东莞手机网站制作
  • 企业网站建设规划的基本原则有哪些汉中微信网站建设推广
  • 网站开发亿码酷技术怎么做推广赚钱
  • 长沙招聘网站有哪些wordpress视频外链
  • 没有网站怎么做百度竞价广州专做优化的科技公司
  • 大学生网站开发项目计划书范文昆明小程序开发制作公司
  • 长沙企业网站模板大学国际化网站建设
  • 晋城网站seo千图网素材解析网站开发
  • PHP做克隆网站网站优点
  • pc网站开发成app难度一个完整的营销策划方案范文
  • 有哪几个网站可以做贸易便宜做网站8818
  • 网站免费模板资源北京装饰公司名录
  • asp.net jsp 网站开发怎么下载app
  • 专业手机网站建设公司排名手机网卡
  • 刷东西网站建设微信网站设计欣赏
  • 网站模板 站长之家东营优化公司
  • 做外贸都有哪些网站给网站做图
  • 温岭企业网站建设公司网站建设公司兴田德润i优惠吗
  • 企业网站空间买虚拟主机海口网站优化
  • 绍兴网站开发公司网站制作珠海公司
  • 手机网站开发 html网站怎么做最省钱
  • 网站建设色彩搭配百度seo霸屏软件
  • 重庆网站建设途锦科技工业和信息网站备案管理系统
  • 网站接广告能赚多少钱网站模板 div
  • 专业定制网站开发公司做网站时怎么透明化