golang之tcp自動(dòng)重連實(shí)現(xiàn)方法
操作系統(tǒng): CentOS 6.9_x64
go語(yǔ)言版本: 1.8.3
問(wèn)題描述
現(xiàn)有一個(gè)tcp客戶端程序,需定期從服務(wù)器取數(shù)據(jù),但由于種種原因(網(wǎng)絡(luò)不穩(wěn)定等)需要自動(dòng)重連。
測(cè)試服務(wù)器示例代碼:
/* tcp server for test */ package main import ( "fmt" "net" "os" "strings" "time" ) func checkError(err error) { if err != nil { fmt.Println(err) os.Exit(1) } } func handleClient(conn net.Conn) { conn.SetReadDeadline(time.Now().Add(3 * time.Minute)) request := make([]byte,1024) defer conn.Close() for { recv_len,err := conn.Read(request) if err != nil { fmt.Println(err) break } if recv_len == 0 { break } recvData := strings.TrimSpace(string(request[:recv_len])) fmt.Println("recv_len : ",recv_len) fmt.Println("recv_data : " + recvData) daytime := time.Now().String() conn.Write([]byte(daytime + "\n")) request = make([]byte,1024) } } func main() { bindInfo := ":12345" tcpAddr,err := net.ResolveTCPAddr("tcp4",bindInfo) checkError(err) listener,err := net.ListenTCP("tcp",tcpAddr) checkError(err) for { cc,err := listener.Accept() if err != nil { continue } go handleClient(cc) } }
解決方案
/* tcp client with reconnect */ package main import ( "net" "fmt" "bufio" "time" ) func doTask(conn net.Conn) { for { fmt.Fprintf(conn,"test msg\n") msg,err := bufio.NewReader(conn).ReadString('\n') if err != nil { fmt.Println("recv data error") break }else{ fmt.Println("recv msg : ",msg) } time.Sleep(1 * time.Second) } } func main() { hostInfo := "127.0.0.1:12345" for { conn,err := net.Dial("tcp",hostInfo) fmt.Print("connect (",hostInfo) if err != nil { fmt.Println(") fail") }else{ fmt.Println(") ok") defer conn.Close() doTask(conn) } time.Sleep(3 * time.Second) } }
運(yùn)行效果:
[root@local t1]# ./tcpClient1 connect (127.0.0.1:12345) ok recv msg : 2017-06-12 21:10:32.110977137 +0800 CST recv msg : 2017-06-12 21:10:33.111868746 +0800 CST recv data error connect (127.0.0.1:12345) fail connect (127.0.0.1:12345) fail connect (127.0.0.1:12345) ok recv msg : 2017-06-12 21:10:43.117203432 +0800 CST recv msg : 2017-06-12 21:10:44.11853427 +0800 CST
討論
這里只是個(gè)簡(jiǎn)單的示例代碼,實(shí)現(xiàn)了tcp自動(dòng)重連。
好,就這些了,希望對(duì)你有幫助。
以上這篇golang之tcp自動(dòng)重連實(shí)現(xiàn)方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- 利用Golang實(shí)現(xiàn)TCP連接的雙向拷貝詳解
- golang 實(shí)現(xiàn)tcp轉(zhuǎn)發(fā)代理的方法
- Golang 實(shí)現(xiàn)Socket服務(wù)端和客戶端使用TCP協(xié)議通訊
- golang中net的tcp服務(wù)使用
- Golang通過(guò)包長(zhǎng)協(xié)議處理TCP粘包的問(wèn)題解決
- Golang?編寫Tcp服務(wù)器的解決方案
- golang實(shí)現(xiàn)簡(jiǎn)單的tcp數(shù)據(jù)傳輸
- Golang實(shí)現(xiàn)自己的Redis(TCP篇)實(shí)例探究
- Golang TCP網(wǎng)絡(luò)編程的具體實(shí)現(xiàn)
相關(guān)文章
grpcurl通過(guò)命令行訪問(wèn)gRPC服務(wù)
這篇文章主要為大家介紹了grpcurl通過(guò)命令行訪問(wèn)gRPC服務(wù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06在Colaboratory上運(yùn)行Go程序的詳細(xì)過(guò)程
這篇文章主要介紹了在Colaboratory上運(yùn)行Go程序,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08解決Golang time.Parse和time.Format的時(shí)區(qū)問(wèn)題
這篇文章主要介紹了解決Golang time.Parse和time.Format的時(shí)區(qū)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-04-04goland遠(yuǎn)程調(diào)試k8s上容器的實(shí)現(xiàn)
本文主要介紹了goland遠(yuǎn)程調(diào)試k8s上容器的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02