佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > golang 實現(xiàn)tcp server端和client端,并計算RTT時間操作

golang 實現(xiàn)tcp server端和client端,并計算RTT時間操作

熱門標(biāo)簽:AI電銷 百度競價排名 服務(wù)外包 鐵路電話系統(tǒng) 呼叫中心市場需求 地方門戶網(wǎng)站 Linux服務(wù)器 網(wǎng)站排名優(yōu)化

server端代碼:

package main 
import (
 "fmt"
 "net"
 "log"
 "os"
)
 
func main() {
 addr := "0.0.0.0:8787"
 tcpAddr, err := net.ResolveTCPAddr("tcp",addr)
 if err != nil {
 log.Fatalf("net.ResovleTCPAddr fail:%s", addr) //等價于print err后,再os.Exit(1)
 }
 
 listener, err := net.ListenTCP("tcp", tcpAddr)
 if err != nil {
 log.Fatalf("listen %s fail: %s", addr, err)
 }else {
 
 log.Println("rpc listening", addr)
 }
 
 for {
 conn, err := listener.Accept()
 if err != nil {
 log.Println("listener.Accept error:", err)
 continue
 }
 
 go handle_Client(conn)
 }
} 
 
func handle_Client(conn net.Conn) {
 defer conn.Close()
 
 var write_buffer []byte = []byte("ok")
 read_buffer := make([]byte, 128)
 
 n, err1 := conn.Read(read_buffer)
 if err1 != nil {
 fmt.Println("ser Read failed:", err1)
 os.Exit(1)
 }
 
 m, err2 := conn.Write(write_buffer)
 if err2 != nil {
 fmt.Println("ser send error:", err2)
 os.Exit(1)
 }
 
 fmt.Println("ser read cli send data count:", n, "msg:", string(read_buffer))
 fmt.Println("ser send data to cli count:", m, "msg:", string(write_buffer)) 
 fmt.Println("********one connetion end*********")
}

client端代碼:

package main 
import (
 "fmt"
 "net"
 "os"
 "time"
)
 
func main() {
 conn, err := net.Dial("tcp", "127.0.0.1:8787")
 if err != nil {
 fmt.Println("dial failed:", err)
 os.Exit(1)
 }
 defer conn.Close() 
 
 var write_buffer []byte = []byte("Hi,server. I'm client.")
 read_buffer := make([]byte, 128)
 
 start_time := time.Now()
 n, err2 := conn.Write(write_buffer)
 if err2 != nil {
 fmt.Println("cli send error:", err2)
 os.Exit(1)
 }
 
 m, err1 := conn.Read(read_buffer)
 if err1 != nil {
 fmt.Println("cli Read failed:", err1)
 os.Exit(1)
 }
 response_time := time.Since(start_time)
 RTT_time := float64(response_time.Nanoseconds()) / 1e+06 //ns-->ms 
 fmt.Println(RTT_time) 
 fmt.Println("cli send data to ser count:", n, "msg:", string(write_buffer)) 
 fmt.Println("cli read ser data count:", m, "msg:", string(read_buffer))
}

補充:go 語言 TCP服務(wù)器接受客戶端字符串信息

我就廢話不多說了,大家還是直接看代碼吧~

func hand_conn(conn net.Conn) ([]byte){
  defer conn.Close()
  //clientarr := conn.RemoteAddr() //獲取連接到的對像的IP地址
  result := bytes.NewBuffer(nil)
  var buf [512]byte
  for {
    n, err := conn.Read(buf[0:])
    result.Write(buf[0:n])
    if err != nil {
      if err == io.EOF {
       break
      }
    }
  }
  //explan_rec_infos(string(result.Bytes()))
  return result.Bytes()
}
func main() {
 fmt.Println("Hello World! go server")
  server, err := net.Listen("tcp", ":9993")
  if err == nil { //若果err為nil,則成功創(chuàng)建
    index := 1
    for {
      index++
      con, _ := server.Accept()
      fmt.Println("有一個客戶連接" , index)
      hand_conn(con)
    }
  } else {
    return
  }
}

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

您可能感興趣的文章:
  • golang在GRPC中設(shè)置client的超時時間
  • 解決golang時間字符串轉(zhuǎn)time.Time的坑
  • golang時間處理工具箱now的使用詳解
  • golang time包做時間轉(zhuǎn)換操作
  • golang時間字符串和時間戳轉(zhuǎn)換的案例
  • golang 實現(xiàn)時間戳和時間的轉(zhuǎn)化

標(biāo)簽:衡水 湖南 湘潭 崇左 黃山 銅川 蘭州 仙桃

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《golang 實現(xiàn)tcp server端和client端,并計算RTT時間操作》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    湖南省| 德安县| 吉林省| 桐庐县| 长寿区| 克拉玛依市| 漾濞| 青海省| 哈巴河县| 都安| 通化市| 运城市| 八宿县| 海南省| 金坛市| 齐齐哈尔市| 化隆| 孟津县| 泾源县| 方城县| 房山区| 墨玉县| 外汇| 沿河| 襄垣县| 胶州市| 孟州市| 兴化市| 淮滨县| 新沂市| 桃源县| 渭南市| 武功县| 齐齐哈尔市| 大港区| 横山县| 梅州市| 上饶市| 大同县| 白银市| 新干县|