久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

linux - redis連接池應用在一萬并發下時連接數只有2?

瀏覽:138日期:2024-07-08 18:40:19

問題描述

linux - redis連接池應用在一萬并發下時連接數只有2?

如圖所示,我用golang的redigo庫寫了一個redis連接池,用ab測試模擬一萬并發讀操作,但是redis無論怎么刷新info,連接數一直是2,最多也只顯示了4,但是使用寫操作有六十多的連接數,同時netstat-ano顯示確實有大量TIME_WAIT狀態的TCP連接發生在遠程127.0.0.1:6379上,請問這是什么原因?(redis配置里面最大連接數為10000)

(請無視右邊的netstat窗口,那只是我截圖的時候沒截好,其實我自己find過濾了一下確實有大量TIME_WAIT狀態的TCP連接發生在遠程127.0.0.1:6379上)

PS:另外還有一個問題就是ab測試程序的-c參數為什么最大只能一萬啊,我輸入十萬直接顯示了幫助文檔。。。

問題解答

回答1:

嫌連接池沒被占用?

這樣寫

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)}

相關文章:
主站蜘蛛池模板: 珲春市| 延吉市| 景东| 岑巩县| 额尔古纳市| 定州市| 伊金霍洛旗| 芮城县| 沙坪坝区| 名山县| 福安市| 汶上县| 来安县| 迁西县| 南充市| 印江| 仁寿县| 谢通门县| 漾濞| 栾城县| 栾川县| 富平县| 晋中市| 平湖市| 夏津县| 宿松县| 大庆市| 永嘉县| 睢宁县| 佛冈县| 贵州省| 扎赉特旗| 大庆市| 大厂| 南木林县| 图们市| 莱西市| 曲靖市| 邢台市| 镇沅| 锡林浩特市|