好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > golang 監聽服務的信號,實現平滑啟動,linux信號說明詳解

golang 監聽服務的信號,實現平滑啟動,linux信號說明詳解

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

監聽服務的信號,實現平滑啟動,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("服務啟動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)
		//監聽 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("服務啟動成功!")
	if ctx.Err() !=nil {
		fmt.Println(ctx.Err())
		fmt.Println("服務關閉成功!")
		os.Exit(0)
	}
 
}

補充:golang http服務實現平滑重啟

看代碼吧~

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服務的監聽部分,一個是處理部分, 如果web服務器不開啟了,那么就不能處理新進來的請求了(可以理解為一個帶路的)
// 真正讓這個請求斷掉  是因為主進程(main)被kill
// 所以平滑重啟的原理就是,先kill掉web服務器,不讓新的請求進來,等現有的全部請求完了,然后結束當前進程
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 模式無法寫入? todo
        n, _ := 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
}

主要思路:

對于每個請求都做記錄,處理完成之后做刪除。 用一個協程去監控中斷信號,有中斷信號先把http服務關閉。

如果這個時候還有請求沒有處理完,那么就輪訓等待,等全部處理完那么就 發出終止信號結束main進程的執行

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

您可能感興趣的文章:
  • Linux進程間通信--使用信號
  • 詳解Linux進程間通信——使用信號量
  • 詳解Linux多線程使用信號量同步
  • Linux下的信號詳解及捕捉信號
  • linux下基于C語言的信號編程實例
  • Linux線程同步之信號C語言實例
  • linux多線程編程詳解教程(線程通過信號量實現通信代碼)
  • Linux下semop等待信號時出現Interrupted System Call錯誤(EINTR)解決方法
  • 淺談Linux信號機制

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

巨人網絡通訊聲明:本文標題《golang 監聽服務的信號,實現平滑啟動,linux信號說明詳解》,本文關鍵詞  golang,監聽,服務,的,信號,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang 監聽服務的信號,實現平滑啟動,linux信號說明詳解》相關的同類信息!
  • 本頁收集關于golang 監聽服務的信號,實現平滑啟動,linux信號說明詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 18hdxxxx日本护士| A片毛片无遮挡全程水多| 成人免费高清视频| 龚玥菲三级| 日本国产精品aV免费爽爽| 妺妺窝人体色www看美女学生| 美女被日在线观看| 欧美理伦| 最近韩国电影在线观看视频| 三台县| 山野村妇| 爆乳上司JULIA中文字幕99| 色悠久久久久伊| 性free欧美乌克兰| 上校他体力太好h御书屋| 搡老女人多毛老妇女中国| 在线免费观看污污视频| 超肉超欲的h文知青| free嫩白的12sex性自由| 空中宝贝1(法国)| 调教高h各种play文| 在野外被三个男人躁爽白浆视频| 美女被暴羞羞免费视频| 国产精品一区二| 中文字日产幕乱五区| 国产hd老头老太婆| 狼人亚洲精品456在线播放第一页| 娇妻在厨房被胯下挺进漫画| 王语嫣跪趴高撅翘臀含白浆| 乌克兰18性hd| 泳池水下泳衣乳揉捏小说| 水多多老gg导航福利视频| 免费又爽又黄1000部视频网站| 黄轩《院线上新》| 操空姐的逼| 欧美特级特黄a大片免费| 艳肉乱痕1一12章精汁欲液| 免费真人视频网站| 精品91?海角乱在线观看 | 古代高H啪肉Np文纵欲视频| 狼人香蕉香蕉在线28 - 百度|