網(wǎng)上有很多講解限頻原理以及限頻原因的,限頻常用在接口、服務(wù)的流量、并發(fā)上,主要是為了合理使用后端資源,防止后端被壓垮,雪崩等等。
成都創(chuàng)新互聯(lián)是一家專業(yè)提供鶴山企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站設(shè)計制作、成都網(wǎng)站制作、H5開發(fā)、小程序制作等業(yè)務(wù)。10年已為鶴山眾多企業(yè)、政府機構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站建設(shè)公司優(yōu)惠進行中。
這里使用使用go的ring(環(huán)形隊列)實現(xiàn)滑動窗口
另外起一個終端,用golang的boom來做壓測。要提前安裝boom工具
進行壓測試:
查看其中數(shù)組可以知道每一秒此時滑動窗口的限頻值,以及變化。
可以看出壓測試服務(wù)在12.6秒進行了300次http請求其中有23次正確響應(yīng)成功,限頻測試ok
很多朋友可能知道Go語言的優(yōu)勢在哪,卻不知道Go語言適合用于哪些地方。
1、 Go語言作為服務(wù)器編程語言,很適合處理日志、數(shù)據(jù)打包、虛擬機處理、文件系統(tǒng)、分布式系統(tǒng)、數(shù)據(jù)庫代理等;網(wǎng)絡(luò)編程方面。Go語言廣泛應(yīng)用于Web應(yīng)用、API應(yīng)用、下載應(yīng)用等;除此之外,Go語言還可用于內(nèi)存數(shù)據(jù)庫和云平臺領(lǐng)域,目前國外很多云平臺都是采用Go開發(fā)。
2、 其實Go語言主要用作服務(wù)器端開發(fā)。其定位是用來開發(fā)"大型軟件"的,適合于很多程序員一起開發(fā)大型軟件,并且開發(fā)周期長,支持云計算的網(wǎng)絡(luò)服務(wù)。Go語言能夠讓程序員快速開發(fā),并且在軟件不斷的增長過程中,它能讓程序員更容易地進行維護和修改。它融合了傳統(tǒng)編譯型語言的高效性和腳本語言的易用性和富于表達性。
3、 Go語言成功案例。Nsq:Nsq是由Go語言開發(fā)的高性能、高可用消息隊列系統(tǒng),性能非常高,每天能處理數(shù)十億條的消息;
4、 Docker:基于lxc的一個虛擬打包工具,能夠?qū)崿F(xiàn)PAAS平臺的組建。
5、 Packer:用來生成不同平臺的鏡像文件,例如VM、vbox、AWS等,作者是vagrant的作者
6、 Skynet:分布式調(diào)度框架。
7、 Doozer:分布式同步工具,類似ZooKeeper。
8、 Heka:mazila開源的日志處理系統(tǒng)。
9、 Cbfs:couchbase開源的分布式文件系統(tǒng)。
10、 Tsuru:開源的PAAS平臺,和SAE實現(xiàn)的功能一模一樣。
11、 Groupcache:memcahe作者寫的用于Google下載系統(tǒng)的緩存系統(tǒng)。
12、 God:類似redis的緩存系統(tǒng),但是支持分布式和擴展性。
13、 Gor:網(wǎng)絡(luò)流量抓包和重放工具。
以上的就是關(guān)于go語言能做什么的內(nèi)容介紹了。
在做接口性能測試的時候也使用過幾個工具:AB、Jmeter、Locust、Vegeta。
這幾個工具中,應(yīng)該當(dāng)屬Jmeter的功能最強大,使用的人也最多,但使用上也比較繁瑣,如果測的接口比較單一,需要得到的值也就是并發(fā)量、每秒請求數(shù)、響應(yīng)時間這三個的話,那就推薦使用個簡單點兒的工具。在這兒主要介紹Locust,原因無非是使用簡單,另外在web界面能實時顯示性能測試情況,可以隨時調(diào)整參數(shù),也支持分布式。
使用Locust也需要編寫腳本,對于不熟悉Python的人來說,又是一個障礙。為此筆者編寫了一個工具 Easy-Locust ,Locust的幾種使用方式都有,并且參數(shù)和Locust也保持一致,需要操作的就是在Excel中編輯好參數(shù)就行。
GitHub: Easy-Locust
執(zhí)行下面命令會自動安裝easy-locust及l(fā)ocustio=0.13.5的版本
此處只介紹和Locust不同的地方,如果想了解詳細參數(shù),請查閱: Locustio
一共4個sheet頁,逐一進行介紹
除了可以從Header中獲取token外還可以從json中獲取,格式為 Json: body.token ,獲取到的值會在調(diào)用接口時填充到header中,這個地方在Excel demo文件中無法配置,如果要改的話,可以生成locustfile文件,然后小改一下locustfile文件即可。
注意:需要指定 -d 參數(shù)才可生效;各壓測機中需要提前安裝好相同版本的locustio=0.13.5
如果希望使用多個用戶信息隨機進行壓測則可以使用此功能。
這篇比較的文章比較不錯,貼一下: 性能測試工具Locust和JMeter比較 ,文章中提到并發(fā)用戶數(shù)那,jmeter和locust實現(xiàn)的機制不一樣,所以測得的值也是有差別的,一般同樣并發(fā)數(shù)下jmeter的每秒請求數(shù)更高一些。
Locust開啟服務(wù)只占用一個進程,如果機器是多核的,則可以開啟master-slave模式,開一個master,剩下幾核就開啟幾個slave,充分利用機器性能。下圖是在本地筆記本(虛擬4核)上執(zhí)行的 普通模式 和 master-slave模式 的對比:
master-slave模式下RPS最高值達到了2600,最低值1300,大概穩(wěn)定在1900左右。
下面是使用Jmeter的一個測試數(shù)據(jù):
Throughput峰值達到了3000,最低值1900,后續(xù)穩(wěn)定在2200左右,但出現(xiàn)了報錯,不過服務(wù)端那并沒有報錯。
上面三張圖對比,可以看出在單核機器上如果使用Jmeter和Locust的話測得的數(shù)據(jù)應(yīng)該相差不大,多核機器上Locust需要使用master-slave模式才能達到Jmeter的性能。不過說到底,兩者之間對并發(fā)用戶數(shù)的實現(xiàn)是不同的,測得的數(shù)據(jù)必定有差值。
性能調(diào)優(yōu)或測個粗指標的話,十八般工具都可以用,只要保證一直使用同一個工具測就行了。如果測精細指標的話,還得是工業(yè)級別的工具/測試儀來完成。
另外Locust + Boomer在相同并發(fā)數(shù)的情況下,RPS比Jmeter還要高,得益于Go語言天生的優(yōu)勢,可以直接使用Boomer示例中的client文件,獲取編譯好的文件及簡單使用方法點擊下面鏈接:
;sub=683B4DBECED3468CACFC386E51F8B33E
在 ci 過程中,經(jīng)常有一些可以通過靜態(tài)分析或者白盒檢測去避免一些問題以及規(guī)范代碼格式!使用Go語言一般是使用 golangci-line 作為代碼檢測工具!
參考官網(wǎng):
安裝: curl-sSfL | sh -s -- -b $(go env GOPATH)/bin v1.43.0
版本信息: golangci-lint--version
目前我司是自己二開的 golangci-line,所以這里使用的開源版本,其實大同小異,就是開發(fā)了一些插件!
這個就是一個工具,集成了各類自動檢測代碼的工具,所以不需要本地安裝太多的工具,只需要這個工具即可!
由于它需要一個go的項目,這里以我自己的項目去介紹, 項目地址:,如果有同學(xué)想自己嘗試下可以直接下載我這個項目!項目也比較規(guī)范!
其實執(zhí)行 golangci-lint run-h 就可以獲取以下幫助
例如我經(jīng)常使用的: 我日常就是開啟format功能!
1、默認使用的插件
2、默認沒用的
3、presets 分類:
具體可以參考我的:
主要是做一些 無用代碼檢測,簡化代碼,格式化代碼!然后執(zhí)行 golangci-lint run --fix 即可
go語言抓包工具的網(wǎng)站:
1,sql2go網(wǎng)。
用于將 sql 語句轉(zhuǎn)換為 golang 的 struct. 使用 ddl 語句即可。
例如對于創(chuàng)建表的語句: show create table xxx. 將輸出的語句,直接粘貼進去就行。
2,toml2go網(wǎng)。
用于將編碼后的 toml 文本轉(zhuǎn)換問 golang 的 struct。
3,curl2go網(wǎng)。
用來將 curl 命令轉(zhuǎn)化為具體的 golang 代碼。
4,json2go網(wǎng)。
用于將 json 文本轉(zhuǎn)換為 struct。
5,mysql 轉(zhuǎn) ES 工具網(wǎng)站。
模擬模板的工具,在支持泛型之前,可以考慮使用。7)查看某一個庫的依賴情況,類似于 go list 功能。
GO語言簡介:
Go(又稱?Golang)是?Google?的 Robert Griesemer,Rob Pike 及 Ken Thompson 開發(fā)的一種靜態(tài)強類型、編譯型語言。
Go 語言語法與?C?相近,但功能上有:內(nèi)存安全,GC(垃圾回收),結(jié)構(gòu)形態(tài)及 CSP-style?并發(fā)計算。
當(dāng)前有兩個Go編譯器分支,分別為官方編譯器gc和gccgo。官方編譯器在初期使用C寫成,后用Go重寫從而實現(xiàn)自舉。Gccgo是一個使用標準GCC作為后端的Go編譯器。
官方編譯器支持跨平臺編譯(但不支持CGO),允許將源代碼編譯為可在目標系統(tǒng)、架構(gòu)上執(zhí)行的二進制文件。
可以去DELVE官網(wǎng)進行下載。
關(guān)于delve工具的介紹,這里簡單給大家介紹一下。
delve在go項目及應(yīng)用的開發(fā)中可以用來追蹤程序中的異常代碼,也可以通過打日志的方式追查問題,但是更重要也是非常厲害的一點,就是delve可以直接分析程序執(zhí)行的情況。這一點在后期或線上的問題排查中無疑是提供了一個非常大的便捷。
Go(又稱?Golang)是?Google?的 Robert Griesemer,Rob Pike 及 Ken Thompson 開發(fā)的一種靜態(tài)強類型、編譯型語言。
Go 語言語法與?C?相近,但功能上有:內(nèi)存安全,GC(垃圾回收),結(jié)構(gòu)形態(tài)及 CSP-style?并發(fā)計算。
Go的語法接近C語言,但對于變量的聲明有所不同。Go支持垃圾回收功能。Go的并行模型是以東尼·霍爾的通信順序進程(CSP)為基礎(chǔ)。
采取類似模型的其他語言包括Occam和Limbo,但它也具有Pi運算的特征,比如通道傳輸。在1.8版本中開放插件(Plugin)的支持,這意味著現(xiàn)在能從Go中動態(tài)加載部分函數(shù)。
Delve常用命令
命令功能:
dlv attach后面跟 pid,用來Debug編譯好的Golang程序。
dlv core用于 coredump。
dlv debug后面跟要調(diào)試的 go 文件,進入 Debug。
dlv testDebug test 函數(shù)。