Joyber 发布的文章

你想要的无需自身开发、用户安装后就能直接用的第三方消息通知APP,大多是开源轻量型工具,用户安装后获取密钥或绑定服务器就能接收通知,适配个人或中小团队的各类通知场景,以下是几款主流工具:

  1. PushDeer
    这款开源工具主打“无需开发自有APP”,用户直接安装官方APP或使用轻应用即可。使用时,用户安装后绑定设备会生成专属pushkey,你只需通过简单的HTTP请求,就能向绑定的设备推送文字、图片、Markdown格式的消息。它还支持自架服务器,数据安全性更高,适合给用户推送订单提醒、系统通知等内容。比如用户开户登录后,将其pushkey与账号绑定,后续就能精准推送相关业务消息。
  2. PushMe
    专为安卓设备设计的轻量级通知APP,安装包不到3M,无多余功能。用户安装后无需注册登录,获取专属push_key就能接收通知,操作零门槛。它支持文本、Markdown、HTML等多种消息格式,还能自定义通知的声音、震动方式,甚至支持语音播报消息。其接口兼容企业微信、钉钉等群机器人,可直接替换对接,适合快速给安卓用户推送服务器监控、业务提醒等消息。
  3. Ntfy
    开源免费的跨平台通知APP,覆盖安卓、iOS及桌面端,核心优势是无需账号和复杂配置。用户安装后订阅对应的主题,你通过HTTP请求就能向该主题推送消息,用户端实时接收。它支持消息优先级设置、文件附件发送,还能端到端加密保障隐私。如果有更高的数据掌控需求,也可自托管服务器,适合给用户推送日常业务通知、离线消息等。
  4. Gotify
    开源的消息推送工具,搭配对应的安卓客户端APP使用。你可先搭建简易的Gotify服务器,用户安装APP后,输入服务器地址和访问令牌就能完成绑定。后续通过调用简单的API,就能向用户推送消息,还能设置消息优先级,让重要的开户成功通知、业务预警等消息优先展示。该工具适合小团队定向给用户推送精准通知,且安全性可通过SSL加密保障。
  5. 灵动通知
    一款轻量化的免费通知管理APP,用户安装后开启无障碍服务权限即可使用,无需额外开发对接。它能聚合接收社交软件、应用推送、系统通知等各类消息,还支持灵动岛胶囊样式弹窗,用户不用解锁手机就能查看消息。如果你的平台消息需适配用户手机的多样化通知场景,这款APP可让用户快速接收和查看消息,适合日常通用类通知推送。

Redis 是可以转移(迁移/搬迁) 的,无论是迁移数据到新实例、新服务器,还是整体迁移 Redis 服务,都有成熟的方案。具体迁移方式需根据场景(如是否停机、数据量大小、是否跨版本/跨架构)选择,以下是最常用的方法和注意事项:

一、核心迁移场景

1. 单机 Redis 迁移到新服务器/新端口
2. 集群(Redis Cluster)迁移(扩缩容/整体搬迁)
3. 主从架构迁移(切换主节点/迁移从节点)
4. 云厂商 Redis 实例迁移到自建/其他云

二、常用迁移方法(按优先级/场景划分)

方法 1:RDB 冷迁移(停机迁移,适合小数据量)

原理:通过 Redis 的 RDB 持久化文件(快照)迁移数据,需停机保证数据一致性。
步骤:

1. 目标实例:停止 Redis 服务,清空原有数据( redis-cli FLUSHALL ),确保配置(端口、密码、持久化策略)与源实例兼容。
2. 源实例:

  • 停机: redis-cli SHUTDOWN SAVE (优雅关闭,自动生成最新 RDB 文件);
  • 若不停机:执行  redis-cli BGSAVE ,等待后台生成 RDB(默认路径  dump.rdb )。
    3. 拷贝 RDB 文件:用  scp / rsync  将源实例的  dump.rdb  拷贝到目标实例的 Redis 数据目录(通过  redis-cli CONFIG GET dir  查看)。
    4. 启动目标 Redis: redis-server redis.conf ,自动加载 RDB 文件恢复数据。
    5. 验证: redis-cli KEYS *  或  dbsize  确认数据一致。

优点:简单、速度快;
缺点:需停机(或 BGSAVE 期间可能有少量数据丢失),不适合高可用场景。

方法 2:AOF 迁移(精准恢复,适合需完整数据)

原理:AOF 是增量日志,记录所有写操作,恢复后数据与源实例完全一致。
步骤:

1. 源实例:执行  redis-cli BGREWRITEAOF (优化 AOF 文件大小),等待重写完成。
2. 拷贝 AOF 文件(默认  appendonly.aof )到目标实例数据目录。
3. 目标实例:修改配置  appendonly yes ,关闭 RDB(可选),启动 Redis 自动加载 AOF。
注意:AOF 文件通常比 RDB 大,加载速度慢,适合数据量小、对一致性要求极高的场景。

方法 3:redis-migrate-tool(开源工具,支持在线迁移)

原理:唯品会开源的 Redis 数据迁移工具,支持单机/集群/主从互迁,在线无感知迁移。
核心优势:

  • 支持增量同步(迁移过程中源实例的新写入会同步到目标);
  • 支持跨版本、跨架构(如单机→集群、集群→单机);
  • 可校验数据一致性。
    基本使用:

    # 1. 安装(需编译)
    git clone https://github.com/vipshop/redis-migrate-tool.git
    cd redis-migrate-tool && make

2. 编写配置文件(migrate.conf)

[source]
type: single  # 源类型:single/cluster/master/slave
servers:
- 192.168.1.100:6379  # 源实例地址
auth: 123456  # 源密码(可选)

[target]
type: single
servers:
- 192.168.1.101:6379  # 目标实例地址
auth: 654321  # 目标密码(可选)

[common]
listen: 0.0.0.0:8888  # 工具监听端口

3. 启动迁移

./redis-migrate-tool -c migrate.conf -o migrate.log -d

4. 校验数据

./redis-migrate-tool -c migrate.conf -C check

 

方法 4:Redis 复制(主从同步,在线迁移)

原理:将目标实例作为源实例的从节点,同步完成后切换为主节点,适合高可用场景。
步骤:

1. 目标实例:清空数据( FLUSHALL ),确保端口/密码与源兼容。
2. 目标实例执行:

# 连接源主节点(若源有密码,加 -a 密码)
redis-cli SLAVEOF 192.168.1.100 6379
# (可选)设置主节点密码(若源有密码)
redis-cli CONFIG SET masterauth 123456

 
3. 等待同步完成:通过  redis-cli INFO replication  查看  master_link_status:up  且  sync_full:1 。
4. 切换目标为独立主节点:
redis-cli SLAVEOF NO ONE

 
5. 割接业务:将应用的 Redis 连接地址改为目标实例。

优点:完全在线,无数据丢失;
缺点:迁移过程中源实例需承担复制压力,适合中小数据量。

方法 5:集群迁移(Redis Cluster)

若源/目标是 Redis 集群,推荐两种方式:

1. redis-cli --cluster reshard:手动迁移槽位(适合扩缩容);
2. redis-migrate-tool:支持集群→集群、集群→单机的全量+增量迁移(推荐)。

三、迁移关键注意事项

1. 数据一致性:

  • 停机迁移优先用  SHUTDOWN SAVE  生成 RDB,避免数据丢失;
  • 在线迁移需确保迁移期间源实例的写操作被同步(如 redis-migrate-tool 增量同步、主从复制)。
    2. 版本兼容:
  • 低版本→高版本:通常兼容,但需注意新特性(如 Redis 7.0 的 ACL);
  • 高版本→低版本:可能不兼容(如 RDB/AOF 格式差异),建议先测试。
    3. 配置兼容:
  • 目标实例需同步源的关键配置:密码(requirepass)、最大内存(maxmemory)、持久化策略(save/appendonly)、过期策略等。
    4. 性能与压力:
  • 在线迁移时,源实例会有复制/网络压力,建议低峰期操作;
  • 大数据量(TB 级)优先用 redis-migrate-tool 分批次迁移。
    5. 验证:
  • 迁移后必做:校验 key 数量( dbsize )、随机抽查 key 的值、检查过期时间( TTL )、验证业务读写正常。
    6. 回滚方案:
  • 迁移完成后,保留源实例一段时间,若目标异常,可快速切回源实例。

四、总结

迁移方式 适用场景 优点 缺点
RDB 冷迁移 小数据量、可停机 简单、速度快 需停机、可能丢增量数据
主从复制 在线迁移、中小数据量 无停机、数据一致 源实例有复制压力
redis-migrate-tool 全场景(单机/集群、大数量) 在线、增量同步、可校验 需编译安装、配置稍复杂
AOF 迁移 数据一致性要求极高 精准恢复 文件大、加载慢

根据你的实际场景(是否停机、数据量、架构)选择即可,中小规模推荐主从复制,大规模/集群推荐redis-migrate-tool。

redis-migrate-tool 支持通过 增量同步(实时复制) 机制,将迁移结束后源库的新写入数据同步到目标库,核心依赖 Redis 的  SYNC / PSYNC  协议实现。

关键实现逻辑与配置:

1. 增量同步的触发:

  • 工具默认执行「全量迁移 + 增量同步」流程:全量数据传输完成后,不会立即退出,而是持续监听源库的写操作(如  SET 、 HSET 、 LPUSH  等),并实时转发到目标库。
  • 即使全量迁移结束后,源库新增的写入数据,也会被实时同步到目标库,确保两端数据最终一致。
    2. 核心配置(必须启用):
  • 配置文件中需显式开启增量同步(默认开启,无需额外修改,但若手动关闭需恢复):

    [source]
    type: single
    addr: 源库IP:端口
    auth: 源库密码(如有)
    
    [target]
    type: single
    addr: 目标库IP:端口
    auth: 目标库密码(如有)
    
    [common]
    # 增量同步开关(默认yes,开启后全量迁移后持续同步)
    incremental_sync = yes
    # 增量同步超时时间(默认3600秒,0表示无限期同步,直到手动停止)
    incremental_sync_timeout = 0

     
    3. 迁移结束后的操作:

  • 若需长期同步:保持工具运行(后台启动,如  nohup redis-migrate-tool -c config.ini & ),直到业务完全切换到目标库。
  • 停止同步:确认应用已全部切换到目标库后,手动终止工具进程( kill -9 进程ID ),增量同步即停止。

注意事项:

  • 仅支持「单源库 → 单目标库」的增量同步,集群场景需额外配置分片映射。
  • 若迁移过程中工具中断,重启后会通过  PSYNC  协议续传增量数据(无需重新全量迁移)。

bun create elysia app  是基于 Bun 构建工具创建 Elysia 框架项目的快捷命令,以下是 结合前端开发场景的完整使用流程+适配建议:

一、核心使用步骤(可直接复制执行)

1. 前提条件:确保已安装 Bun(未安装则先执行)

安装 Bun(Windows/Mac/Linux 通用)

curl -fsSL https://bun.sh/install | bash
 
2. 创建 Elysia 项目:执行命令后自动生成项目结构
bun create elysia app
 
3. 启动项目:进入项目目录并运行开发服务器
cd app
bun run dev
 

启动后默认端口  3000 ,访问  http://localhost:3000  即可看到默认页面。

二、关键适配说明(针对 Vue3/TSX 前端开发)

  • 项目结构:生成的  src/index.ts  是入口文件,可直接编写 Elysia 路由和接口(适配 Hyperf 后端的 API 调用场景)。
  • TS 支持:默认集成 TypeScript,可直接使用  interface  定义类型(与 Vue3/TSX 类型系统一致)。
  • 跨域配置:若需对接本地 Hyperf 后端,在入口文件添加跨域中间件:
    import { Elysia } from 'elysia'

const app = new Elysia()
.use(cors()) // 需先安装:bun add @elysiajs/cors
.get('/', () => 'Hello Elysia')
.listen(3000)
 

三、扩展建议

  • 若需结合 Vue3 前端开发,可将 Elysia 作为 BFF 层(中间层),转发请求到 Hyperf 后端,简化前端接口调用。
  • 支持热更新:开发时修改代码自动重启服务器,无需手动刷新。

Bun 是一个用 Zig 编写的全栈 JavaScript/TypeScript 运行时与集成工具包,目标是替代 Node.js,提供更快的性能和更统一的开发体验。

核心定位与优势

  • 一站式工具链:集成运行时、包管理器、打包器、测试运行器,单命令搞定开发。
  • 极致性能:包安装速度通常是 npm 的 20-100 倍,启动与执行更快。
  • 原生兼容:支持 package.json、node_modules 与多数 npm 包,可直接运行 Node.js 项目。
  • 内置支持:原生解析 TypeScript/JSX,自动加载 .env,内置 fetch/WebSocket 等 Web API。

常用命令(可直接复制)

安装 Bun(Windows/Mac/Linux)

curl -fsSL https://bun.sh/install | bash

创建项目(如 Elysia)

bun create elysia app

安装依赖

bun install # 替代 npm install
bun add axios # 替代 npm add axios

运行脚本与开发

bun run dev # 启动开发服务器
bun test # 运行测试
bun build # 打包项目
 

对 Vue3/TSX 开发的价值

  • 与 Vue3/TSX 类型系统无缝衔接,无需额外配置即可解析 TS/TSX。
  • 可作为 BFF 层快速搭建接口服务,对接 Hyperf 后端更高效。
  • 热更新与快速启动提升开发效率,适合快速迭代的前端项目。

现状与注意事项

  • 已被 Anthropic 收购,路线图聚焦高性能与 Node.js 兼容性。
  • 适合新项目;老 Node.js 项目迁移前建议先做兼容性测试。