0

0

Python feature flag 的低成本数据库实现

冰川箭仙

冰川箭仙

发布时间:2026-02-18 19:30:10

|

612人浏览过

|

来源于php中文网

原创

sqlite做feature flag存储够用,尤其适合中小流量、内部工具和灰度发布初期;它零网络开销、免运维、schema灵活、读写快,但需规避数据库锁、连接泄漏等问题,并配合缓存与规则解析策略。

python feature flag 的低成本数据库实现

用 SQLite 做 feature flag 存储够不够用

够用,而且在中小流量、内部工具、灰度发布初期场景下,是性价比最高的选择。它没网络开销、不用维护额外服务、schema 灵活,关键是写入快、读取毫秒级——feature_flags 表查一次 SELECT enabled FROM feature_flags WHERE key = ? 就能拿到开关状态。

常见错误现象:sqlite3.OperationalError: database is locked,多线程/多进程直连同一 DB 文件时高频读写会触发;或者用 sqlite3.connect() 每次都新建连接却不 close,导致 fd 耗尽。

  • 只开一个连接 + 连接池(如 sqlite3.Connection 复用),避免频繁 open/close
  • 读操作用 PRAGMA journal_mode = WAL,提升并发读性能
  • 写操作(比如后台管理界面 toggle 开关)加简单锁:用 threading.Lock 或文件锁 flock,别依赖 SQLite 自带的 busy timeout
  • 表结构建议至少包含:key(主键,TEXT)、enabledINTEGER CHECK(enabled IN (0,1)))、updated_atREAL,存 time.time()

Python 里怎么快速读取 flag 状态不拖慢请求

不能每次 HTTP 请求都查一次 DB。得缓存,但又不能缓存太久——灰度开关要能秒级生效。

使用场景:Django/Flask/FastAPI 中间件、Celery task、CLI 工具判断是否启用新逻辑。

立即学习Python免费学习笔记(深入)”;

易企CMS1.8
易企CMS1.8

易企CMS:国内首款完全基于SEO友好性开发的营销型企业网站系统,让企业网络营销从此易如反掌。 本程序特征:100%开发源代码,免费开源;后台管理操作简单易行;模板div+css标准设计,符合w3c标准,兼容主流浏览器;开发语言和数据库:PHP+Mysql。 本程序亮点:从基础代码开发起完全符合SEOWHY理论的SEO规范,力图实现国内首款对SEO最友好的企业网站开源程序,为企业网络营销的巨大成功

下载
  • functools.lru_cache(maxsize=128) 包裹读 DB 函数,但加 typed=True 防止字符串/bytes 键冲突
  • 缓存失效靠「时间戳」:每次查 DB 时顺带读 updated_at,如果本地缓存的 updated_at 比 DB 小超过 1 秒,就强制刷新
  • 避免用 @lru_cache 直接包 get_feature_flag('pay_v2'),因为参数是 str,无法感知 DB 变更;改用带版本号的封装,比如 get_flag_with_version('pay_v2') 返回 (value, version)
  • 如果项目已用 redis,那优先把 flag 同步到 Redis(用 SETNX + 过期时间),Python 层直接 redis_client.get('flag:pay_v2') ——比 SQLite 缓存更可控

SQLite 不支持 JSON 怎么存复杂规则(比如按用户 ID 百分比放量)

不硬上 JSON,用字段拆解 + 简单解析。SQLite 3.38+ 虽然支持 json_extract,但 Python 里用 sqlite3 模块默认不启用 JSON 扩展,开启麻烦还影响移植性。

参数差异:enabled 字段只管“开/关”,复杂规则全扔进 rules 字段(TEXT),内容是纯 JSON 字符串,Python 层负责 json.loads()

  • 示例值:{"type": "percent", "value": 5.0, "seed": "pay_v2"}{"type": "whitelist", "users": ["u123", "u456"]}
  • 读取时统一用 json.loads(row['rules'] or '{}'),加 try/except json.JSONDecodeError 容错,失败则当空规则处理
  • 别在 SQL 里做规则计算(比如 WHERE json_extract(rules, '$.value') > 5),这种查询没法走索引,且语义模糊——规则解释权必须收归 Python 层
  • 如果规则变多、变重,说明该拆服务了,别死撑 SQLite

上线后发现 flag 切换不生效,先查哪几处

90% 是缓存没清或没刷,不是数据库写错了。

性能影响:缓存层 miss 一次会打 DB,但只要缓存命中的 QPS 在 1k 以内,SQLite 完全扛得住;真正卡住的是应用层反复解析 JSON 或没设超时的 HTTP 调用。

  • 检查 Python 进程是否 reload 过——lru_cache 是 per-process 的,gunicorn 多 worker 下每个 worker 缓存独立,切 flag 后要滚动重启或加信号触发清缓存
  • 确认 DB 文件路径是不是被不同环境共用(比如 dev/staging 共用 ./flags.db),用绝对路径 + os.path.abspath() 初始化连接
  • 查日志里有没有 sqlite3.IntegrityError(比如重复插入同一 key),SQLite 默认不报错,但 insert or replace 要显式写
  • sqlite3 CLI 连上去执行 SELECT * FROM feature_flags WHERE key = 'xxx';,看 enabledupdated_at 是否真变了

最常被忽略的是:缓存 key 拼写和 DB 里的 key 不一致,比如代码里写 'payment_v2',DB 里存的是 'pay_v2',查不到就回退默认值,而默认值往往设成了 False,于是以为“关着”,其实根本没读到。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

985

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

334

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

377

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1717

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

373

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1272

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

436

2024.04.29

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

561

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4.4万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号