亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

golang 監(jiān)聽服務(wù)的信號,實現(xiàn)平滑啟動,linux信號說明詳解

瀏覽:121日期:2024-04-21 11:57:54
監(jiān)聽服務(wù)的信號,實現(xiàn)平滑啟動,linux信號說明

golang 監(jiān)聽服務(wù)的信號,實現(xiàn)平滑啟動,linux信號說明詳解

package main import ('context''fmt''golang.org/x/sync/errgroup''net/http''os''os/signal''syscall') func main() { g, ctx := errgroup.WithContext(context.Background())fmt.Println('服務(wù)啟動start!')addr := ':9091's :=&http.Server{Addr: addr,Handler:http.DefaultServeMux,}g.Go(func() error {http.HandleFunc('/test1', func(writer http.ResponseWriter, request *http.Request) {fmt.Println('tes1')writer.Write([]byte('tes1'))})return s.ListenAndServe()})g.Go(func() error {exit := make(chan os.Signal)//監(jiān)聽 Ctrl+C 信號signal.Notify(exit, syscall.SIGINT, syscall.SIGTERM)select {case <-exit:fmt.Println('進程已被取消~')return s.Shutdown(ctx)}})err := g.Wait()if err != nil {fmt.Println(err)}fmt.Println('服務(wù)啟動成功!')if ctx.Err() !=nil {fmt.Println(ctx.Err())fmt.Println('服務(wù)關(guān)閉成功!')os.Exit(0)} }

補充:golang http服務(wù)實現(xiàn)平滑重啟

看代碼吧~

package main import ( 'context' 'encoding/json' 'fmt' 'math/rand' 'net/http' 'os' 'os/signal' 'time') var logChan = make(chan map[string]interface{}) var requestStatusMap = map[int]bool{} var done = make(chan bool, 1)var quit = make(chan os.Signal, 1) //為什么這樣可以平滑重啟?// 正常情況下是server.ListenAndServe() 這個位置hang住整個進程的// 可以把這個程序看成兩部分,1個是web服務(wù)的監(jiān)聽部分,一個是處理部分, 如果web服務(wù)器不開啟了,那么就不能處理新進來的請求了(可以理解為一個帶路的)// 真正讓這個請求斷掉 是因為主進程(main)被kill// 所以平滑重啟的原理就是,先kill掉web服務(wù)器,不讓新的請求進來,等現(xiàn)有的全部請求完了,然后結(jié)束當(dāng)前進程func main() { server := newServer() signal.Notify(quit, os.Interrupt) go monitorKill(server, quit) server.ListenAndServe() <-done} func newServer() *http.Server { router := http.NewServeMux() router.HandleFunc('/hello', sayHello) return &http.Server{Addr: ':8262',Handler: router, }} func monitorKill(server *http.Server, quit <-chan os.Signal) { <-quit go shutDown(server) for {if len(requestStatusMap) != 0 { fmt.Println('目前還有進行中的請求,請稍等') time.Sleep(time.Second * 1) continue} else { close(done) break} }} func shutDown(server *http.Server) { if err := server.Shutdown(context.Background()); err != nil {fmt.Println(err) }} func sayHello(w http.ResponseWriter, r *http.Request) { go WriteInfo()//請求寫日志 var uniqueId = GenerateRangeNum(1, 1000) requestStatusMap[uniqueId] = false url := r.URL.Path query := r.URL.RawQuery method := r.Method a := map[string] interface{}{'url' : url,'method' : method,'query' : query,'response': 'hello world!', } logChan<-a w.Write([]byte('hello world!')) time.Sleep(time.Second * 10) delete(requestStatusMap, uniqueId)} func WriteInfo() { info := <-logChan fileName := '/tmp/weekhomework.log' _, err := os.Stat(fileName) if err != nil || os.IsNotExist(err) {_, _ = os.Create(fileName) } f,err := os.OpenFile(fileName, os.O_WRONLY, 0644) defer f.Close() if err !=nil {fmt.Println(err.Error()) } else {//追加寫入 為什么O_APPEND 模式無法寫入? todon, _ := f.Seek(0, 2)infostr, _ := json.Marshal(info)_,err=f.WriteAt([]byte(string(infostr) +'n'), n) }} func GenerateRangeNum(min int, max int) int { if min == max {return min } rand.Seed(time.Now().Unix()) randNum := rand.Intn(max-min) + min return randNum}主要思路:

對于每個請求都做記錄,處理完成之后做刪除。 用一個協(xié)程去監(jiān)控中斷信號,有中斷信號先把http服務(wù)關(guān)閉。

如果這個時候還有請求沒有處理完,那么就輪訓(xùn)等待,等全部處理完那么就 發(fā)出終止信號結(jié)束main進程的執(zhí)行

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。如有錯誤或未考慮完全的地方,望不吝賜教。

標(biāo)簽: Linux系統(tǒng)
主站蜘蛛池模板: 国产精品福利视频萌白酱g 国产精品福利影院 | 一级一黄在线观看视频免费 | 国产又黄又爽又色视频观看免费 | 亚洲精品久中文字幕 | 亚洲一区精品视频在线 | 欧美一级大黄特黄毛片视频 | 免费精品在线 | 国产亚洲情侣一区二区无 | 精品国产成人a区在线观看 精品国产成人a在线观看 | 久久精品国产亚洲麻豆小说 | 天天影视色香欲综合免费 | 99超级碰碰成人香蕉网 | 日韩一区二区三区免费 | 国产三级大片 | 国产黄在线观看免费观看不卡 | 久久精品人人做人人 | 九九九在线视频 | 在线国产一区二区 | 三级视频网站在线观看播放 | 国产精品久久毛片蜜月 | 国产五月色婷婷六月丁香视频 | 久久亚洲国产成人影院 | 美女久久久久久久久久久 | 一级一片在线播放在线观看 | 国产午夜在线观看视频 | 国产成人91高清精品免费 | 国产一区二区欧美丝袜 | 国产一级簧片 | 羞羞色院91| 亚洲精品麻豆 | 亚洲一区二区三区日本久久九 | 特级片在线观看 | 色视频一区 | 青青热久免费精品视频在首页 | 五十路一区二区三区视频 | 国产精品线在线精品国语 | 欧美在线观看黄色 | 香蕉视频在线免费看 | 午夜激情网站 | 国产精品反差婊在线观看 | 欧美成人免费全部色播 |