golang 实现tcp server端和client端,并计算RTT时间操作
作者:YMY_mine 时间:2023-08-30 14:12:49
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服务器接受客户端字符串信息
我就废话不多说了,大家还是直接看代码吧~
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,则成功创建
index := 1
for {
index++
con, _ := server.Accept()
fmt.Println("有一个客户连接" , index)
hand_conn(con)
}
} else {
return
}
}
以上为个人经验,希望能给大家一个参考
来源:https://blog.csdn.net/YMY_mine/article/details/87720736
标签:golang,tcp,server,client,RTT
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Mootools 1.2教程(17)——手风琴插件
2008-12-11 13:39:00
阿里云 CentOS7.4 安装 Python3.6的方法讲解
2022-06-12 23:56:13
Python用类实现扑克牌发牌的示例代码
2021-01-07 10:07:07
Centos中安装多个mysql数据的配置实例
2024-01-21 08:36:02
Pandas多列值合并成一列的实现
2023-02-13 08:39:44
![](https://img.aspxhome.com/file/2023/5/107195_0s.png)
PyQt打开保存对话框的方法和使用详解
2023-05-19 08:23:43
vue项目配置element-ui容易遇到的坑及解决
2024-04-29 13:10:25
![](https://img.aspxhome.com/file/2023/8/132908_0s.png)
解决os.path.isdir() 判断文件夹却返回false的问题
2022-11-07 18:11:37
Python selenium环境搭建实现过程解析
2023-10-06 06:18:48
![](https://img.aspxhome.com/file/2023/1/63271_0s.png)
H5+css3+js搭建带验证码的登录页面
2023-08-30 16:15:54
![](https://img.aspxhome.com/file/2023/2/56252_0s.jpg)
mysql中复制表结构的方法小结
2024-01-19 22:54:26
图文教程mssqlserver数据库导出到另外一个数据库的方法
2024-01-24 20:33:54
![](https://img.aspxhome.com/file/2023/8/108518_0s.png)
Django返回json数据用法示例
2022-05-25 21:00:52
如何基于python实现脚本加密
2021-10-07 19:23:05
![](https://img.aspxhome.com/file/2023/8/99308_0s.png)
都2019年了,还问http中GET和POST的区别
2023-03-26 10:24:17
![](https://img.aspxhome.com/file/2023/9/132289_0s.jpg)
Python采用raw_input读取输入值的方法
2021-09-08 03:19:05
vue中子组件调用兄弟组件方法
2024-04-30 10:24:44
Python简单实现图片转字符画的实例项目
2023-02-24 02:01:47
![](https://img.aspxhome.com/file/2023/2/90312_0s.png)
如何用Anaconda搭建虚拟环境并创建Django项目
2022-02-25 02:30:21
![](https://img.aspxhome.com/file/2023/0/80800_0s.png)
vs code开发中语法正确但显示报错问题分析解决
2023-08-05 11:54:26
![](https://img.aspxhome.com/file/2023/7/132427_0s.png)