成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

淺談短鏈的設計

開發 前端
在很多社交平臺上,對于發送的文本是有長度限制,過長的 URL 很容易被截斷,然后觸達就無效了。

背景

目前在很多場景下,都需要短鏈,尤其是涉及到一些 URL 下發的邏輯。為什么需要短鏈呢?考慮到一個 URL 上有 path、query 等參數,各種參數拼接在一起就成了一個長不拉幾的字符串。

在很多社交平臺上,對于發送的文本是有長度限制,過長的 URL 很容易被截斷,然后觸達就無效了。當用戶收到一個短鏈,心情可能更加愉悅:

短鏈組成

知己知彼百戰百勝,先來看看一個短鏈有哪些信息。

協議 + 域名 + path,協議可以直接忽略。域名是必須的(廢話),并且足夠短,否則的話就變成了長的短鏈(挺傻的)。最后 path 的部分才是關鍵,看起來是一個由 6 個字符組成的字符串,并且字符的范圍是大小寫字母+數字。

足夠短的域名需要什么條件?大概率錢夠就行。涉及到錢的部分,這里就不深入探究了。所以來研究一下這個 path 的生成。

Path 的生成

獲取一個序號

哈希算法

Path 的其中一種方式就是通過哈希算法計算得到。常見的哈希函數有 MD5、SHA1 等大家常見的加密型哈希算法,也有 HighwayHash、MurmurHash 等非加密型哈希函數。以 MurmurHash 為例,目前已經迭代到 MurmurHash 3,能夠產生 32bit 和 128 bit 的哈希值,并且對于規律性較強的 key,隨機分布的特征表現的很不錯。

不過哈希沖突是不可控的,我們雖然有 N 種解決哈希沖突的方式,但是會增加整個系統的整體復雜度。

自增 ID

也可以維護一個 ID 自增生成器,對于每一個長鏈生成1、2、3等自增的序號,然后把長鏈和序號的映射保存在數據庫里面,然后得到如 https://fake.short/1、https://fake.short/2 等短鏈。考慮到單機容易造成單點故障,所以一般都是分布式的 ID 生成器。

Mysql 自增

假設有 10 臺 Mysql 服務器,每一臺初始值分別為 0……9,然后每生成一個需要就遞增 10,這樣確保這 10 臺 Mysql 服務器產生的 ID 不重復。但這個方案缺點比較明顯,就是 ID 是有跡可循的,爬蟲的可以順著順序依次請求得到;水平擴展不容易,如之前約定 10 臺機器,每臺機器生產的步長是 10,如果需要增加一臺機器,比較困難;數據庫壓力還是很大,每次獲取ID都得讀寫一次數據庫,只能靠堆機器來提高性能。

基于雪花算法

SnowFlake 是 Twitter 公司采用的一種算法,目的是在分布式系統中產生全局唯一且趨勢遞增的ID。

第一位占用 1bit,其值始終是0,沒有實際作用。2.時間戳 占用 41bit,精確到毫秒,總共可以容納約 69 年的時間。3.工作機器id 占用10bit,其中高位 5bit 是數據中心ID,低位 5bit 是工作節點ID,最多可以容納 1024 個節點。4.序列號 占用12bit,每個節點每毫秒0開始不斷累加,最多可以累加到4095,一共可以產生 4096 個ID。

SnowFlake算法在同一毫秒內最多可以生成 1024 X 4096 = 4194304 個全局唯一ID。

國內也有不少基于(類)雪花算法的開源分布式唯一ID生成器:

  1. UidGenerator

由百度開源的分布式 UID 生成器。https://github.com/baidu/uid-generator

  1. Leaf

Leaf 是美團開源的分布式ID生成器,能保證全局唯一,趨勢遞增,但需要依賴關系數據庫、Zookeeper等中間件。https://tech.meituan.com/2017/04/21/mt-leaf.html

進一步縮短

如果我們得到『1536389934』這個序號的話,看起來還是有點長,如果想進一步縮短,可以把十進制數轉換成62進制數。然后就得到一個比原序號更短的 ID 了。

為什么要用62進制轉換?

  • 62進制轉換是因為62進制轉換后只含數字+小寫+大寫字母。而64進制轉換會含有/,+這樣的符號(不符合正常URL的字符)encodeURIComponent('+') => %xx
  • 10進制轉62進制可以縮短字符,如果我們要6位字符的話,已經有560億個組合了。

重定向是 301 還是 302

眾所周知,301 是永久重定向,瀏覽器會把重定向后的地址緩存下來,下次訪問的時候,就不會向原地址發起請求;按理來說通過 301 的重定向性能會更好,對服務的壓力也更小。

但是,正因為 301 會在瀏覽器中有緩存,所以服務端就沒辦法知道有多少用戶是通過這個短鏈訪問的,在現如今什么數據都可以分析一波的時代,這些數據的缺失,就失去了分析活動的能力。所以一般都通過 302 進行重定向,便于記錄使用的數據,稍微增加點 Server 的壓力。(沒有什么是不能通過加機器解決的

責任編輯:龐桂玉 來源: 前端大全
相關推薦

2022-09-13 17:45:40

長網址短鏈系統

2023-08-10 10:13:35

轉轉短鏈平臺

2024-07-22 11:48:42

2025-06-23 08:23:04

2022-09-13 08:01:58

短鏈服務哈希算法字符串

2024-11-12 08:13:09

2024-11-19 16:31:23

2025-06-04 03:15:00

高并發短鏈系統

2015-05-15 13:21:22

URL系統設計

2021-06-18 11:17:36

URL數據庫MySQL

2024-06-28 09:59:35

2023-07-26 13:29:43

高性能短鏈系統

2009-06-26 10:48:45

職責鏈模式.NET

2009-07-15 15:47:12

JDBC DAO

2018-12-06 14:47:34

區塊鏈中介信任

2011-06-29 17:51:55

SEO外鏈

2023-02-27 09:10:57

前端組件設計

2025-04-27 10:10:04

2010-07-12 16:27:23

鏈路狀態路由選擇協議

2015-11-03 09:28:52

Hybrid技術設計實現
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 激情一区二区三区 | 天天爱天天操 | 91精品一区二区三区久久久久久 | 日韩精品免费在线观看 | 亚洲免费视频一区 | 性国产xxxx乳高跟 | 最新av在线网址 | 九九热这里 | 欧美五月婷婷 | 二区在线视频 | 日本韩国欧美在线观看 | 综合天天久久 | 男女羞羞免费视频 | 欧美成人精品一区二区男人看 | 日本天天操 | a天堂在线 | 黄色欧美在线 | 毛片高清 | 九九综合 | 国产精品成人av | 日韩av资源站 | 欧美人妖网站 | 欧美一极视频 | 精品视频一区二区 | 日韩欧美成人一区二区三区 | 超碰av人人| 欧美精品久久久久久 | 欧美成人影院在线 | 久久久精品综合 | 欧美精品久久久久 | 在线观看成人小视频 | 日本天天色 | www.国产一区 | 日本三级全黄三级a | 国产1区2区3区 | 欧美一级做性受免费大片免费 | www.成人免费视频 | 精品国产一区二区在线 | 国产99热精品 | 国产精品久久久久久238 | 99精品欧美一区二区三区 |