您好,歡迎來到易龍商務(wù)網(wǎng)!
發(fā)布時(shí)間:2020-11-17 13:12  
【廣告】





“你們的公司文化是什么樣的?”
公司文化也許是個(gè)非常含糊的概念,但即便像開放辦公室還是小隔間這樣的小事情都會(huì)顯著改變你與同事的日?;?dòng)。這方面沒有普遍性的危險(xiǎn)信號,但是要確保他們的答案是你可以按照每周 40 小時(shí)的節(jié)奏持續(xù)相處數(shù)年的東西。
以軟件工程師的身份工作
在這個(gè)階段,如果你面試過程中表現(xiàn)不錯(cuò)并且喜歡面試官回答你問題的方式,你被錄用的可能性就很高了。
祝賀,你正式成為一名工程師了!
那現(xiàn)在又該如何呢?好吧,現(xiàn)在是時(shí)候重新學(xué)量編碼和工作方面的東西了。既然我們是程序員,我們就從討論代碼開始。
分析之前
依我個(gè)人的理解來說限流的話應(yīng)該靈活到可以針對每一個(gè)接口來做。比如說一個(gè)類里面有5個(gè)接口,那么我的限流插件就應(yīng)該能針對每一個(gè)接口就行不同的限流方案。所以呢,既然針對的每個(gè)接口所以就需要一個(gè)可以標(biāo)示這個(gè)接口的key(我取的是類名 方法名 入?yún)ⅲ?。上班時(shí)間:開發(fā)經(jīng)常加班熬夜,常常一天24小時(shí)睡不了多久,更別提照顧家庭。
分布式限流強(qiáng)烈推薦使用redis lua或者nginx lua來實(shí)現(xiàn)。
這里用2個(gè)限流條件來做示例講一下常見的限流算法:
接口1它10秒鐘很大允許訪問100次
接口2它10秒鐘很大允許每個(gè)人訪問100次。
計(jì)數(shù)器算法
這個(gè)算法可以說是限流算法中簡單的一種算法了。
核心思想
計(jì)數(shù)器算法的意思呢就是當(dāng)接口在一個(gè)時(shí)間單位中被訪問時(shí),我就記下來訪問次數(shù),直到它訪問的次數(shù)到達(dá)上限。
涉及變量
接口(key)
時(shí)間單位(expire)
允許訪問多少次(limit)
訪問次數(shù)(value)
條件一
當(dāng)一個(gè)請求過來時(shí),我們就會(huì)得到這個(gè)key。
123456789 if(存在key){ value ; if(value>=limit){ 不能訪問 } }else{ 添加key,value為1 設(shè)置key過期時(shí)間為expire }
條件二
既然條件一已經(jīng)實(shí)現(xiàn)了,那條件二會(huì)復(fù)雜么 ?
相比于條件一來說就是同一個(gè)key對應(yīng)了多個(gè)用戶。那么我們只需要把key加上用戶的信息就可以了。比如說 key_用戶1、key_用戶2。
漏桶算法核心思想
漏桶算法的意思呢就是一個(gè)接口在一個(gè)時(shí)間單位中允許被訪問次數(shù)是動(dòng)態(tài)變化的(假如一分鐘允許訪問60次,那么從開始計(jì)時(shí)時(shí)不管有沒有被訪問第59秒只允許訪問59次,30秒只允許30次)。為什么這樣呢,因?yàn)橛辛硗庖粋€(gè)線程在進(jìn)行遞減操作
遞減間隔時(shí)間(interval)
遞減步長(step)
剩余可訪問次數(shù)(value)
key的訪問時(shí)間(lastUpdateTime)
當(dāng)前時(shí)間(nowTime)(注意nowTime的取值應(yīng)為應(yīng)用取得的時(shí)間而不是redis或者nginx取得的時(shí)間)
條件一線程一:
12345678 if(存在key){ value--; if(value<=0){ 不能訪問 } }else{ 添加key,設(shè)置value為limit }
快進(jìn)5個(gè)月……
該系統(tǒng)開始經(jīng)歷許多關(guān)于維護(hù)CRUD操作完整性的問題。設(shè)計(jì)用來處理事務(wù)的瘦應(yīng)用程序邏輯層已經(jīng)不再那么薄了。升級和向后兼容性的故事開始變得更加復(fù)雜。
由于受到許多其他問題的困擾,工程師們又回到了繪圖板——這次是用Azure SQL替換存儲(chǔ)層!我不記得具體的細(xì)節(jié),但是這個(gè)改變增加了大約40%的額外時(shí)間和成本。
管理層很不高興,這個(gè)項(xiàng)目幾乎掉了。但是團(tuán)隊(duì)的工程師們非常好,他們能夠完成這個(gè)項(xiàng)目,盡管有了一些延遲和初的錯(cuò)誤的技術(shù)決定。
這個(gè)項(xiàng)目有一個(gè)圓滿的結(jié)局——但它也可能不是這樣的。事實(shí)上,很多內(nèi)部項(xiàng)目都被關(guān)閉了,因?yàn)樗麄儾荒茉诔兄Z的日期范圍內(nèi)交付承諾的功能。
那么,您如何知道NoSQL解決方案適合您的下一個(gè)軟件項(xiàng)目呢?首先問問你自己和你的團(tuán)隊(duì)這十個(gè)問題: