一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術(shù)及教程分享平臺!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Golang - 如何利用Golang寫出高并發(fā)代碼詳解

如何利用Golang寫出高并發(fā)代碼詳解

2020-05-08 11:16tomorrowwu Golang

今天領(lǐng)導(dǎo)問起為什么用Golang,同事回答語法簡單,語言新,支持高并發(fā)。那高并發(fā)到底如何實現(xiàn),下面這篇文章主要給大家介紹了關(guān)于如何利用Golang寫出高并發(fā)代碼的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考

前言

之前一直對Golang如何處理高并發(fā)http請求的一頭霧水,這幾天也查了很多相關(guān)博客,似懂非懂,不知道具體代碼怎么寫

下午偶然在開發(fā)者頭條APP上看到一篇國外技術(shù)人員的一篇文章用Golang處理每分鐘百萬級請求,看完文章中的代碼,自己寫了一遍代碼,下面自己寫下自己的體會

核心要點

將請求放入隊列,通過一定數(shù)量(例如CPU核心數(shù))goroutine組成一個worker池(pool),workder池中的worker讀取隊列執(zhí)行任務(wù)

實例代碼

以下代碼筆者根據(jù)自己的理解進(jìn)行了簡化,主要是表達(dá)出個人的思路,實際后端開發(fā)中,根據(jù)實際場景修改

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
func doTask() {
 //耗時炒作(模擬)
 time.Sleep(200 * time.Millisecond)
 wg.Done()
}
 
//這里模擬的http接口,每次請求抽象為一個job
func handle() {
 //wg.Add(1)
 job := Job{}
 JobQueue <- job
}
 
var (
 MaxWorker = 1000
 MaxQueue = 200000
 wg  sync.WaitGroup
)
 
type Worker struct {
 quit chan bool
}
 
func NewWorker() Worker {
 return Worker{
  quit: make(chan bool)}
}
 
// Start method starts the run loop for the worker, listening for a quit channel in
// case we need to stop it
func (w Worker) Start() {
 go func() {
  for {
   select {
   case <-JobQueue:
    // we have received a work request.
    doTask()
   case <-w.quit:
    // we have received a signal to stop
    return
   }
  }
 }()
}
 
// Stop signals the worker to stop listening for work requests.
func (w Worker) Stop() {
 go func() {
  w.quit <- true
 }()
}
 
type Job struct {
}
 
var JobQueue chan Job = make(chan Job, MaxQueue)
 
type Dispatcher struct {
}
 
func NewDispatcher() *Dispatcher {
 return &Dispatcher{}
}
 
func (d *Dispatcher) Run() {
 // starting n number of workers
 for i := 0; i < MaxWorker; i++ {
  worker := NewWorker()
  worker.Start()
 }
}

測試

?
1
2
3
4
5
6
7
8
9
10
func Benchmark_handle(b *testing.B) {
 runtime.GOMAXPROCS(runtime.NumCPU())
 d := NewDispatcher()
 d.Run()
 for i:=0;i<10000;i++ {
  wg.Add(1)
  handle()
 }
 wg.Wait()
}

測試結(jié)果

?
1
2
3
pkg: golang-study-demo/goroutine
1 2029931652 ns/op
PASS

1w個任務(wù)放到隊列中,1000個worker去執(zhí)行任務(wù),每個任務(wù)的耗時200ms,任務(wù)執(zhí)行完需要2s多

以上只是筆者的個人看法,不知道對Golang并發(fā)編程的理解是否正確,有錯誤的地方,希望高手指點一二,在此謝過

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對服務(wù)器之家的支持。

原文鏈接:https://segmentfault.com/a/1190000011063451

延伸 · 閱讀

精彩推薦
  • Golanggolang 通過ssh代理連接mysql的操作

    golang 通過ssh代理連接mysql的操作

    這篇文章主要介紹了golang 通過ssh代理連接mysql的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    a165861639710342021-03-08
  • Golanggolang json.Marshal 特殊html字符被轉(zhuǎn)義的解決方法

    golang json.Marshal 特殊html字符被轉(zhuǎn)義的解決方法

    今天小編就為大家分享一篇golang json.Marshal 特殊html字符被轉(zhuǎn)義的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧 ...

    李浩的life12792020-05-27
  • Golanggolang如何使用struct的tag屬性的詳細(xì)介紹

    golang如何使用struct的tag屬性的詳細(xì)介紹

    這篇文章主要介紹了golang如何使用struct的tag屬性的詳細(xì)介紹,從例子說起,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看...

    Go語言中文網(wǎng)11352020-05-21
  • Golanggolang的httpserver優(yōu)雅重啟方法詳解

    golang的httpserver優(yōu)雅重啟方法詳解

    這篇文章主要給大家介紹了關(guān)于golang的httpserver優(yōu)雅重啟的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,...

    helight2992020-05-14
  • Golanggo日志系統(tǒng)logrus顯示文件和行號的操作

    go日志系統(tǒng)logrus顯示文件和行號的操作

    這篇文章主要介紹了go日志系統(tǒng)logrus顯示文件和行號的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    SmallQinYan12302021-02-02
  • Golanggo語言制作端口掃描器

    go語言制作端口掃描器

    本文給大家分享的是使用go語言編寫的TCP端口掃描器,可以選擇IP范圍,掃描的端口,以及多線程,有需要的小伙伴可以參考下。 ...

    腳本之家3642020-04-25
  • GolangGolang中Bit數(shù)組的實現(xiàn)方式

    Golang中Bit數(shù)組的實現(xiàn)方式

    這篇文章主要介紹了Golang中Bit數(shù)組的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    天易獨尊11682021-06-09
  • GolangGolang通脈之?dāng)?shù)據(jù)類型詳情

    Golang通脈之?dāng)?shù)據(jù)類型詳情

    這篇文章主要介紹了Golang通脈之?dāng)?shù)據(jù)類型,在編程語言中標(biāo)識符就是定義的具有某種意義的詞,比如變量名、常量名、函數(shù)名等等,Go語言中標(biāo)識符允許由...

    4272021-11-24
主站蜘蛛池模板: 极品美女写真菠萝蜜视频 | 日韩免费| 国产成人综合一区精品 | 2020国产精品亚洲综合网 | 久久精品一卡二卡三卡四卡视频版 | 亚洲乱人伦在线 | 国产一区二区免费福利片 | 久久久久久久伊人电影 | 国产福利不卡 | 五月精品| 97综合 | 精品国产成人AV在线看 | 好姑娘在线视频观看免费 | 任你操视频在线观看 | 国产成人91高清精品免费 | 精品视频在线免费播放 | 日本特黄一级午夜剧场毛片 | 国产啪精品视频网给免丝袜 | 国产suv精品一区二区四区三区 | 韩国成人毛片aaa黄 含羞草国产亚洲精品岁国产精品 | 女人张开腿 让男人桶个爽 免费观看 | 99九九成人免费视频精品 | 成人免费观看一区二区 | 国语视频高清在线观看 | 草草视频免费看 | 国产一区二区视频免费 | 精品图区 | 無码一区中文字幕少妇熟女网站 | 成人免费网站视频ww | 日韩日b视频 | 日本一区免费观看 | 国产香蕉一区二区在线网站 | 精品视频免费 | 好爽轻点太大了太深了 | 亚洲成人一区二区 | 四虎影视在线看免费 720p | 女人被男人躁得好爽免费视频 | 门房秦大爷在线阅读 | 日本特黄一级午夜剧场毛片 | 国产精品思瑞在线观看 | 99热这里只有精品在线播放 |