婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 基于Golang 高并發問題的解決方案

基于Golang 高并發問題的解決方案

熱門標簽:阿克蘇地圖標注 壽光微信地圖標注 評價高的400電話辦理 外呼系統顯本地手機號 電話機器人軟件免費 百度地圖標注后傳給手機 excel地圖標注分布數據 涿州代理外呼系統 外呼系統用什么卡

Golang 高并發問題的解決

Golang在高并發問題上,由于協程的使用,相對于其他編程語言,已經有了很大的優勢,即相同的配置上,Golang可以以更低的代價處理更多的線程,同樣的線程數,占用更低的資源!及時這樣,只是解決了一部分問題而已,因為在每個協程里,處理邏輯還是會有問題。

高并發時,還是要考慮服務器所能承受的最大壓力,數據庫讀取時的io問題,連接數問題,帶寬問題等等

研究了一下并發解決方案,在此記錄一下

參考文章:Handling 1 Million Requests per Minute with Go

地址:http://marcio.io/2015/07/handling-1-million-requests-per-minute-with-golang/

代碼如下:

//==================================
//  * Name:Jerry
//  * Tel:18017448610
//  * DateTime:2019/2/24 14:02
//==================================
package main
import (
	"github.com/lunny/log"
	"runtime"
	"sync"
	"time"
)
//工廠模型
type Factory struct {
	Wg        *sync.WaitGroup //任務監控系統
	MaxWorker int             //最大機器數
	MaxJobs   int             //最大工作數量
	JobQueue  chan int        //工作隊列管道
	Quit      chan bool       //是否關閉機器
}
//創建工廠模型
func NewFactory(maxWorker int, wg *sync.WaitGroup) Factory {
	return Factory{
		Wg:        wg,                        //引用任務監控系統
		MaxWorker: maxWorker,                 //機器數量(數量多少,根據服務器性能而定)
		JobQueue:  make(chan int, maxWorker), //工作管道,數量大于等于機器數
		Quit:      make(chan bool),
	}
}
//設置最大訂單數量
func (f *Factory) SetMaxJobs(taskNum int) {
	f.MaxJobs = taskNum
}
//開始上班
func (f *Factory) Start() {
	//機器開機,MaxWorker
	for i := 0; i  f.MaxWorker; i++ {
		//每一臺機器開啟后,去工作吧
		go func() {
			//等待下發命令
			for {
				select {
				case i := -f.JobQueue:
					//接到工作,開工!
					f.doWork(i)
				case -f.Quit:
					log.Println("機器關機")
					return
				}
			}
		}()
	}
}
//分配每個任務到管道中
func (f *Factory) AddTask(taskNum int) {
	//系統監控任務 +1
	f.Wg.Add(1)
	//分配任務到管道中
	f.JobQueue - taskNum
}
//模擬耗時工作
func (f *Factory) doWork(taskNum int) {
	//生產產品的工作
	time.Sleep(200 * time.Millisecond)
	//完成工作報告
	f.Wg.Done()
	//log.Println("完工:", taskNum)
}
//創建工廠
func Begin() {
	//配置工作核數
	gomaxprocs := runtime.GOMAXPROCS(runtime.NumCPU())
	log.Println("核數:", gomaxprocs)
	//配置監控系統
	wg := new(sync.WaitGroup)
	//開工廠
	factory := NewFactory(1000, wg)
	//訂單量
	factory.SetMaxJobs(10000)
	//開始上班
	factory.Start()
	log.Println("開始生產")
	//講所有的訂單,添加到任務隊列
	for i := 0; i  factory.MaxJobs; i++ {
		factory.AddTask(i)
	}
	factory.Wg.Wait()
	log.Println("所有訂單任務生產完成")
}

測試代碼及結果

上面代碼中,MaxWorker的數量很重要,取決于服務器所能承受的壓力,當然也不能無限增大,合理數值效率最高(具體多少合適,自己測試)

代碼:

func Benchmark_Begin(b *testing.B) {
 Begin()
}

結果:

1000臺機器(協程),10000的工作量,我的個人PC測試結果如下:

2019/02/26 16:42:31 核數: 4

2019/02/26 16:42:31 開始生產

2019/02/26 16:42:33 所有訂單任務生產完成

goos: windows

goarch: amd64

pkg: day11

Benchmark_hight2-4 1 2035574000 ns/op

PASS

Process finished with exit code 0

總結:

此方法僅僅是在代碼層面解決一定的問題,高并發 產生的原因還包括其他原因,如帶寬,數據庫讀取速度等等,還需加大帶寬,多級數據庫,優化數據的檢索等等方法

補充:golang 高并發任務處理方案

這個主要用golang 的chan 和routine屬性做的,比很多語言方便多了,可以參考參考

//任務的請求
type MtaskRequest struct {
    Ceshi int
    // [redacted]
}
 
//job隊列+work池
var (
    MaxWorker = os.Getenv("MAX_WORKERS")
    MaxQueue  = os.Getenv("MAX_QUEUE")
)
 
// Job represents the job to be run
type Job struct {
    MtaskRequest MtaskRequest
}
 
// A buffered channel that we can send work requests on.
 
// var JobQueue chan Job ---這樣申明會卡主,沒有初始化
var JobQueue = make(chan Job)
 
// Worker represents the worker that executes the job
type Worker struct {
    WorkerPool chan chan Job
    JobChannel chan Job
    quit       chan bool
}
 
func NewWorker(workerPool chan chan Job) Worker {
    return Worker{
        WorkerPool: workerPool,
        JobChannel: make(chan Job),
        quit:       make(chan bool)}
}
 
// Stop signals the worker to stop listening for work requests.
func (w Worker) Stop() {
    go func() {
        w.quit - true
    }()
}
 
type Dispatcher struct {
    // A pool of workers channels that are registered with the dispatcher
    WorkerPool chan chan Job
    maxWorkers int
}
 
func NewDispatcher(maxWorkers int) *Dispatcher {
    pool := make(chan chan Job, maxWorkers)
    return Dispatcher{WorkerPool: pool, maxWorkers: maxWorkers}
}
 
// 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 {
            // register the current worker into the worker queue.
            w.WorkerPool - w.JobChannel
            select {
            case -w.JobChannel:
                time.Sleep(5 * time.Second)
                // we have received a work request.
                fmt.Println("調起worker")
            case -w.quit:
                // we have received a signal to stop
                return
                //不能寫default
            }
        }
    }()
}
 
func (d *Dispatcher) Run() {
    //啟動一定數量的worker
    fmt.Println("啟動一定數量的worker")
    for i := 0; i  d.maxWorkers; i++ {
        worker := NewWorker(d.WorkerPool)
        worker.Start()
    }
 
    go d.dispatch()
}
 
//分派任務
func (d *Dispatcher) dispatch() {
    for {
        select {
        case job := -JobQueue: //接收一個job請求
            fmt.Println("JobQueue 收到請求")
 
            go func(job Job) {
                // try to obtain a worker job channel that is available.
                // this will block until a worker is idle
                jobChannel := -d.WorkerPool
                // dispatch the job to the worker job channel
                jobChannel - job
            }(job)
        }
    }
}
 
//接收到紅包數據
func (this *TaskRedbao) UserGetRedbao(red_id, uid, shop_id, rand_arr, Amoney string) error {
    fmt.Println("收到 接收到紅包數據 http請求")
    mtaskRequest := MtaskRequest{67}
    work := Job{MtaskRequest: mtaskRequest}
 
    JobQueue - work
    return nil
}

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • 解決golang 關于全局變量的坑
  • 深入淺析golang zap 日志庫使用(含文件切割、分級別存儲和全局使用等)
  • 關于golang高并發的實現與注意事項說明
  • 使用golang編寫一個并發工作隊列
  • golang 并發編程之生產者消費者詳解
  • golang 對私有函數進行單元測試的實例
  • Golang全局變量加鎖的問題解決

標簽:重慶 銅川 汕頭 蘭州 欽州 吐魯番 梅河口 雞西

巨人網絡通訊聲明:本文標題《基于Golang 高并發問題的解決方案》,本文關鍵詞  基于,Golang,高,并,發問,題的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《基于Golang 高并發問題的解決方案》相關的同類信息!
  • 本頁收集關于基于Golang 高并發問題的解決方案的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲欧洲99久久| 日本一区二区三区电影| 黄色日韩三级电影| 中文字幕在线观看不卡视频| 欧美美女网站色| 成人免费视频一区二区| 亚洲欧美激情小说另类| 99国产精品国产精品毛片| 欧美激情综合五月色丁香小说| 亚洲制服丝袜一区| 欧美伊人久久久久久午夜久久久久| 久久精品夜色噜噜亚洲a∨| 蜜桃精品在线观看| 午夜伊人狠狠久久| 中文字幕中文乱码欧美一区二区| 91在线小视频| 奇米精品一区二区三区在线观看 | 日韩你懂的在线播放| 日韩电影网1区2区| 亚洲精品午夜久久久| 精品三级av在线| 欧美日韩在线播放| av不卡一区二区三区| 国产在线视视频有精品| 日韩电影在线免费观看| 91在线播放网址| 欧美激情一区不卡| 国产91富婆露脸刺激对白| 午夜久久久影院| 亚洲欧美日韩一区二区 | 亚洲va韩国va欧美va| 欧洲日韩一区二区三区| 色拍拍在线精品视频8848| 成人av免费在线播放| 国产在线播精品第三| 国产成人精品免费| 播五月开心婷婷综合| 日本乱人伦一区| 精品视频色一区| 精品成人一区二区三区四区| 精品欧美一区二区三区精品久久| 精品区一区二区| 国产精品成人网| 日韩一卡二卡三卡| 日韩黄色小视频| 亚洲视频一区在线| 日韩一级二级三级精品视频| 亚洲午夜一区二区| 欧美一区二区成人6969| 精品国产伦一区二区三区观看方式 | 国产成人免费高清| 成人理论电影网| 日韩欧美亚洲国产精品字幕久久久| 国产无遮挡一区二区三区毛片日本| 亚洲欧洲精品一区二区精品久久久| 日本一区中文字幕| 91在线无精精品入口| 精品国产乱码久久久久久久久 | 成人伦理片在线| 色综合久久天天| 国产精品日产欧美久久久久| 蜜臀av一级做a爰片久久| 久久精品理论片| 精品国产免费一区二区三区四区| 午夜日韩在线观看| 欧美日韩一区二区欧美激情| 中文幕一区二区三区久久蜜桃| 奇米影视在线99精品| 欧美日韩黄色影视| 欧美一区二区视频在线观看2022| 欧美中文字幕久久| 91久久精品一区二区三| 精品国产精品网麻豆系列| 日韩福利视频导航| 日韩一区二区三区在线视频| 国内久久婷婷综合| 欧美精三区欧美精三区| 另类小说图片综合网| 欧美精品一区二区三区在线| 亚洲国产aⅴ成人精品无吗| 欧美理论片在线| 免费不卡在线视频| 欧美激情综合五月色丁香小说| 国产精品网站在线| 欧美在线免费观看视频| 亚洲日本电影在线| 日韩美一区二区三区| 国产成人免费视| 亚洲国产wwwccc36天堂| 欧美三电影在线| 黄色资源网久久资源365| 亚洲卡通欧美制服中文| 精品国产精品一区二区夜夜嗨| 国产精品18久久久久久久久 | 成人精品国产免费网站| 日本一区二区高清| 国产精品午夜久久| 成人黄色国产精品网站大全在线免费观看 | 国产馆精品极品| 国产欧美日韩在线视频| 日韩一级成人av| 另类小说一区二区三区| 欧美一卡二卡在线| 国产一区不卡在线| 中文字幕欧美一| 色婷婷av一区| 天堂av在线一区| 福利电影一区二区三区| 中文字幕亚洲欧美在线不卡| 成人视屏免费看| 亚洲午夜免费电影| 免费成人美女在线观看.| 欧美一区二区在线免费观看| 国产在线一区观看| 欧美96一区二区免费视频| 91精品一区二区三区久久久久久| 亚洲国产成人av网| 爽好多水快深点欧美视频| 亚洲区小说区图片区qvod| 麻豆freexxxx性91精品| 亚洲宅男天堂在线观看无病毒| 国产亚洲一本大道中文在线| 久久久久久久综合日本| 久久久亚洲午夜电影| 久久网站热最新地址| 2024国产精品| 国产调教视频一区| 欧美色综合天天久久综合精品| 日韩影院免费视频| 亚洲国产三级在线| 一区二区三区四区不卡在线 | 奇米精品一区二区三区在线观看一| 久久久久久久久免费| 欧美亚洲国产一卡| 色综合一个色综合亚洲| 国内一区二区视频| 国产一区欧美二区| 国内久久婷婷综合| 播五月开心婷婷综合| 成人国产在线观看| 一本一道久久a久久精品综合蜜臀| 国产成人午夜视频| 成人激情文学综合网| 成人免费一区二区三区在线观看| 国产精品美女www爽爽爽| 欧美激情在线一区二区三区| 欧美日韩另类一区| 成人免费在线视频| 99视频超级精品| 伊人婷婷欧美激情| 欧美日韩一区三区四区| 亚洲第一成年网| 制服视频三区第一页精品| 欧美在线色视频| 国内精品久久久久影院薰衣草| 亚洲一二三四区不卡| 精品少妇一区二区三区视频免付费| 成人深夜视频在线观看| 老司机一区二区| 国产一区二区三区黄视频| 国产99精品国产| 欧美不卡视频一区| 国产欧美日韩另类视频免费观看| 久久日韩粉嫩一区二区三区| 26uuu色噜噜精品一区二区| 国产欧美1区2区3区| 亚洲欧美一区二区三区极速播放| 亚洲精品视频一区| 精品亚洲国内自在自线福利| 日本在线播放一区二区三区| 狠狠色丁香久久婷婷综合丁香| 国产一区二区福利视频| 国产91丝袜在线观看| 天堂蜜桃91精品| 狠狠色丁香久久婷婷综| 国产精品77777竹菊影视小说| 国产福利一区二区| 欧美在线你懂的| 久久久久久**毛片大全| 欧美日韩一区视频| 色中色一区二区| 不卡av在线免费观看| 国产资源在线一区| 亚洲va欧美va人人爽| 亚洲欧美在线aaa| 久久久久久亚洲综合影院红桃| 欧美日韩高清在线| 欧美日韩在线直播| 在线视频亚洲一区| 色久优优欧美色久优优| 成人精品国产一区二区4080| 国产欧美日韩精品a在线观看| 亚洲精品国久久99热| 国产一本一道久久香蕉| 欧美日韩午夜影院| 亚洲男人天堂一区| 国产精品123区| 精品成人一区二区三区四区| 三级亚洲高清视频| 欧美日韩精品综合在线|