亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

利用Golang寫出高并發代碼的案例

發布時間:2021-02-20 16:22:57 來源:億速云 閱讀:373 作者:小新 欄目:編程語言

小編給大家分享一下利用Golang寫出高并發代碼的案例,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

核心要點

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

實例代碼

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

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

測試

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

測試結果

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

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

以上是“利用Golang寫出高并發代碼的案例”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

尚志市| 昔阳县| 大竹县| 福泉市| 鹤峰县| 吉水县| 本溪市| 公安县| 德江县| 吉木乃县| 宁陵县| 额敏县| 丹东市| 象州县| 聂拉木县| 盘锦市| 天台县| 宜城市| 宁都县| 洪江市| 江永县| 肇东市| 敦化市| 衡阳市| 南陵县| 太保市| 三亚市| 高唐县| 怀安县| 射洪县| 天长市| 裕民县| 望江县| 南溪县| 浮梁县| 突泉县| 潮安县| 临海市| 佛冈县| 江油市| 屯留县|