Golang短链接服务核心是可靠生成与快速跳转:用自增ID转62进制生成无冲突短码;通过/s/{code}路由+Redis缓存(TTL 1h)+DB冷热分离实现毫秒级302跳转;辅以限流、敏感词过滤、URL校验保障安全。

做一个 Golang 短链接服务,核心就两件事:一是把长 URL 映射成短字符串(生成算法),二是用户访问短链时能快速跳转回原地址(路由与存储设计)。不复杂,但容易忽略一致性、并发和可扩展性。
短链生成:用自增 ID + 进制转换最稳妥
别一上来就搞随机字符串或哈希——容易冲突、难排序、无法预估容量。推荐用数据库自增主键(如 PostgreSQL 的 serial 或 MySQL 的 AUTO_INCREMENT),插入长 URL 后拿到 ID,再转成 62 进制(0–9 + a–z + A–Z)字符串。
- ID=1 → "1",ID=62 → "z",ID=63 → "10"
- 6 位 62 进制最多支持约 568 亿条短链,够用好多年
- 生成函数写一次就行,无状态、无冲突、可预测、易调试
跳转路由:HTTP 302 + 路由前缀隔离
短链访问必须走 302 重定向(不是 301),方便后期修改目标、统计点击、灰度切换。URL 路由建议固定前缀,比如 /s/{code},避免和静态资源或其他接口冲突。
- 用 net/http 或 gin 注册
GET /s/:code路由 - 中间件里查缓存(Redis)→ 命中则 302;未命中再查 DB,成功则回写缓存(TTL 建议 1 小时)
- 查不到直接返回 404,不要跳到首页或错误页,影响 SEO 和用户体验
数据存储:冷热分离 + 带过期的缓存层
短链读多写少,DB 只存原始数据(ID、长 URL、创建时间、是否启用),高频跳转全靠 Redis 缓存映射关系。缓存 key 设计为 short:{code},value 存原始 URL 和元信息(如跳转次数,可选)。
立即学习“go语言免费学习笔记(深入)”;
- DB 字段精简:id (PK), long_url (TEXT), created_at, enabled (BOOL)
- Redis 设置 TTL(比如 1h),避免脏数据长期滞留;DB 更新后主动删对应缓存
- 如果需要统计 UV/PV,另起一个轻量异步服务写入 ClickHouse 或 Kafka,别卡在跳转主流程里
安全与可用:防刷、防恶意、防泄漏
短链天然容易被爬、被爆破、被滥用。加几道简单防线:
- 生成接口限流(如 10 次/分钟/IP),用 token bucket 实现
- 禁用敏感词开头的短码(如 admin、api、login),黑名单提前加载进内存
- 长 URL 做基础校验:scheme 必须是 http/https,长度限制 2KB,禁止内网地址(127.0.0.1、192.168.x.x 等)
- 管理后台或 API 需要 JWT 鉴权,短链跳转本身保持无状态、免鉴权
基本上就这些。Golang 写起来很轻快,重点不在语言特性,而在怎么让生成可靠、跳转飞快、数据可控。从单机 SQLite + Redis 开始跑通逻辑,再按需升级到分库分表或短码分片,路很清晰。











