linux - redis連接池應(yīng)用在一萬(wàn)并發(fā)下時(shí)連接數(shù)只有2?
問(wèn)題描述
如圖所示,我用golang的redigo庫(kù)寫了一個(gè)redis連接池,用ab測(cè)試模擬一萬(wàn)并發(fā)讀操作,但是redis無(wú)論怎么刷新info,連接數(shù)一直是2,最多也只顯示了4,但是使用寫操作有六十多的連接數(shù),同時(shí)netstat-ano顯示確實(shí)有大量TIME_WAIT狀態(tài)的TCP連接發(fā)生在遠(yuǎn)程127.0.0.1:6379上,請(qǐng)問(wèn)這是什么原因?(redis配置里面最大連接數(shù)為10000)
(請(qǐng)無(wú)視右邊的netstat窗口,那只是我截圖的時(shí)候沒(méi)截好,其實(shí)我自己find過(guò)濾了一下確實(shí)有大量TIME_WAIT狀態(tài)的TCP連接發(fā)生在遠(yuǎn)程127.0.0.1:6379上)
PS:另外還有一個(gè)問(wèn)題就是ab測(cè)試程序的-c參數(shù)為什么最大只能一萬(wàn)啊,我輸入十萬(wàn)直接顯示了幫助文檔。。。
問(wèn)題解答
回答1:嫌連接池沒(méi)被占用?
這樣寫
package mainimport 'github.com/garyburd/redigo/redis'import ( 'flag' 'fmt' 'time')func newPool(addr string) *redis.Pool { return &redis.Pool{MaxIdle: 30,IdleTimeout: 240 * time.Second,Dial:func() (redis.Conn, error) { return redis.Dial('tcp', addr) }, }}var ( pool*redis.Pool redisServer = flag.String('redisServer', ':6379', ''))func main() { flag.Parse() pool = newPool(*redisServer) fmt.Println(pool) conn := pool.Get() conn2 := pool.Get() conn3 := pool.Get() conn4 := pool.Get() conn.Do('get', 'a') conn2.Do('get', 'a') conn3.Do('get', 'a') conn4.Do('get', 'a') //這里使勁加connX,就能看到效果了 //defer conn.Close() //defer conn2.Close() //defer conn3.Close() //defer conn4.Close() time.Sleep(100 * time.Second)}
相關(guān)文章:
1. javascript - vue 移動(dòng)端的input 數(shù)字輸入優(yōu)化2. 為什么我ping不通我的docker容器呢???3. javascript - 有什么兼容性比較好的辦法來(lái)判斷瀏覽器窗口的類型?4. 關(guān)于docker下的nginx壓力測(cè)試5. HTML5禁止img預(yù)覽該怎么解決?6. 服務(wù)器端 - 采用nginx做web服務(wù)器,C++開發(fā)應(yīng)用程序 出現(xiàn)拒絕連接請(qǐng)求?7. javascript - npm start 運(yùn)行’webpack-dev-server’報(bào)錯(cuò) Cannot find module ’webpack’8. angular.js - Ionic 集成crosswalk后生成的apk在android4.4.2上安裝失?。浚??9. java - 靜態(tài)屬性中的賦值和靜態(tài)代碼塊中的賦值有什么區(qū)別?10. javascript - nidejs環(huán)境設(shè)置操作一直出現(xiàn)這種問(wèn)題怎么解決?
