golang 实现tcp server端和client端,并计算RTT时间操作
作者:YMY_mine 发布时间:2023-08-30 14:12:49
标签:golang,tcp,server,client,RTT
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


猜你喜欢
- 简介Python发送邮件的教程本人在网站搜索的时候搜索出来了一大堆,但是都是说了一大堆原理然后就推出了实现代码,我测试用给出的代码进行发送邮
- 对python网页请求模块urllib2进行简单的封装。例子:#!/usr/bin/python#coding: utf-8import b
- 去空格函数有如下两种:·LTRIM()LTRIM() 函数把字符串头部(左)的空格去掉,其语法如下:LTRIM (<character
- adodb.stream对象的方法/属性cancel 方法使用方法如下object.cancel说明:取消执行挂起的异步 execute 或
- Matplotlib 是 Python 的二维绘图库,用于生成符合出版质量或跨平台交互环境的各类图形。图形解析与工作流图形解析 工
- join用来连接字符串,split恰好相反,拆分字符串的。不用多解释,看完代码,其意自现了。>>>li = ['m
- 一、RESTful 概述REST(Representational State Transfer)风格是一种面向资源的 Web 应用程序设计
- 01 实现我们几乎每个人都用过计算器,大家对于计算器应该都是比较熟悉的,计算器整体也是比较简单的,主要包括:显示器、键盘、运算的逻辑处理等,
- 1、执行环境说明python版本3.7直接使用pip进行安装pywin32、pyinstallerpip install pywin32pi
- 1.复制表结构及数据到新表CREATE TABLE 新表SELECT * FROM 旧表 2.只复制表结构到新表CREATE TABLE 新
- 有表如下:如何获得如下结果:解法使用xml转换代码如下: CREATE TABLE body (
- 如何存放或更新缓存?缓存数据来源是预知的,我们可以预先定义哪些 mutation 是缓存相关的。我们期望这个过程更自然一点,通过某种变化自动
- Channel是Go中的一个核心类型,你可以把它看成一个管道,通过它并发核心单元就可以发送或者接收数据进行通讯(communication)
- 一:安装sql server 2005过程中出现如下问题:“选择的功能中没有任何功能可以安装或升级”:解决方案:Microsoft SQL
- 1、Dreamweaver中的复制我在网页中复制的文字,粘贴到Dreamweaver中时,它总是带有原来网页的格式,请问如何只复制其中的文本
- __isset() – 在对类中属性或者非类中属性使用isset()方法的时候如果没有或者非公有属性,则自动执行__isset(
- 下面列出Python正则表达式的几种匹配用法:此外,关于正则的一切http://deerchao.net/tutorials/regex/r
- docker安装mysqldocker search mysql 搜索docker pull mysql:5.6
- 本文实例讲述了Python读取Pickle文件信息并计算与当前时间间隔的方法。分享给大家供大家参考,具体如下:python—–读取Pickl
- 在许多用SQL Server实现的新的企业系统设计中,系统设计师需要在给数据结构和管理应用程序逻辑的定位上做出具有关键性意义的决定。SQL