Skip to main content

Command Palette

Search for a command to run...

关于 Manifest V3 中的 storage 配额

Published
1 min read
关于 Manifest V3 中的 storage 配额

这几天在开发浏览器插件,用的是 Plasmo + Redux 做状态管理,中途遇到了一个很“诡异”的问题,简单来说就是 Redux 的状态持久化刚开始能用,但数据量多起来之后,就会丢失状态。

在配置页面点击添加,当场是能看到变化的,但是刷新之后状态又会恢复到之前那样,如果 A 配置有 5 个,那么 B 配置只能存 1 个,反之 A 有 1 个,B 能存 2 个。

刚开始我在怀疑是 Plasmo 的问题,于是去 issues 里搜索,发现没有人问过,后来猜想可能是 storage 的配额问题,查了一下 MV3 的文档,果不其然。

在文档中可以知道 MV3 有 4 种 storage,分别是 localsessionmanagedsync,其中前两个大家都很熟悉,这两个的配额都是 10MBmanaged管理员下发的配置,是只读的,所以没有配额上限。

sync 是很特殊的,它能在多个设备之间同步,即便你浏览器关闭了同步功能,但他的配额也是最少的,只有 100 KB,而且由于他是键值对存储,所以规定了每个项目不能超过 8KB,所以你可以看到 Tampermonkey 等插件都不依赖 sync 来做同步,他们更喜欢用 Google Drive 等网盘。

那么回到 Plasmo,这个框架提供了 @plasmohq/redux-persist 这个库,用于 Redux 状态的持久化,在他的样例代码里默认使用的就是 syncStorage,对应 MV3 中的 stroage.sync

我计算了一下我的配置大小,B 配置每个占用 3KB 上下,那么按他项目(状态树)的配额限制,确实最多只能存下两个,所以解决起来最简单的办法就是换用 storage.local 来储存配置。

如果觉得 localsession 配额不够的话,可以申请 unlimitedStorage 权限,它会解除这两种的配额上限(sync 的不行,毕竟云空间要花钱)。

More from this blog

12 月装机行动记录

(Banner 图文无关) 这几天买了新的装备回来升级配置,除了显卡和散热器,其他都更新了,这两个不更新的原因是太贵了。 由于我不太懂选配置,所以还是让朋友给推荐,我说我的预算在 5000 左右,他就给我转了一个整机,配置大概是这样的: CPU:AMD 9700X 主板:微星 B650M GAMING PLUS WIFI 或者 微星 B650M GAMING WIFI 显卡:木有 内存:英睿达/宇瞻 DDR5 6000 32G 硬盘:1T NVMe PCIe4 SSD 读速 3500M...

Dec 7, 20241 min read
12 月装机行动记录

Homekit + cozylife 插座连接 HA

近期在淘宝上买了个 Homekit + cozylife 的插座,就这种: 一开始只通过 iOS 访问,就是只连接 Homekit,长按开关重置插座,iOS 一扫码就连上了,后来我嫌在外面访问不了,又不想掏钱买苹果的 HomePod,于是就装上了 Home Assistant,打算让设备们都连上 HA,这样就不用交苹果税了。 连接方式还是通过 Homekit,一般来说支持 Homekit 设备都能这样连接,先连上 iOS,然后在 Home App 中移除设备,这时候就能在 HA 中找到设备了:...

Nov 30, 20241 min read
Homekit + cozylife 插座连接 HA

找到了一台祖传的 Ccd 相机

开个玩笑,这台相机其实是我们家在 05 年的时候买的,发票都还在呢,当时花了 4000 块钱!搁现在我都受不了,更别说当年了,看到价格我都震惊了。 相机的型号是索尼的 Cybershot DSC-N1,属于小红书时尚单品 CCD 相机,由于一直放在包装盒里,现在还有 99 新呢。 机子还是正常的,能开机,能拍照,其中一个问题是日期,这款没有 WiFi 功能,所以时间只能保存在本地,不知道是不是 BUG,每次开机都让我重新设置,默认就定在 2005 年 1 月 1 日。 第二个问题是电池,电池应该...

Nov 28, 20241 min read
找到了一台祖传的 Ccd 相机

记录和 ffmpeg 与 LLM 搏斗的两天

要做的 最近在写一个制作视频的功能,就是把 N 个视频合并,然后把对应的 N 张图片,在视频开始的前 5 秒叠加显示出来。 第一口 - diffusion studio 本来我用的是 diffusion studio,这是一个 JS 库,但这玩意性能太差了,因为他要把视频每一帧都读到 canvas 里,数据一多页面就卡住了(为啥要折腾 DOM 呢?) 而且他的 API 十分不好用,作为浏览器脚本你无法读本地数据也就算了,你起码给一个接受纯数据的参数吧,比如 HTML 类型接受源代码,Image ...

Nov 16, 20242 min read
记录和 ffmpeg 与 LLM 搏斗的两天
V

void mian

39 posts