go net包简记
TCP服务端
go语言中可以每次建立一次链接就创建一个goroutine去处理,使用goroutine实现并发非常方便和高效。
TCP服务端程序的一般处理流程
1.建立并绑定 Socket:首先服务端使用 socket() 函数建立网络套接字,然后使用 bind() 函数为套接字绑定指定的 IP 和端口;
2.监听请求:接下来,服务端使用 listen() 函数监听客户端对绑定 IP 和端口的请求;
3.接收连接:如果有请求过来,并通过三次握手成功建立连接,则使用 accept() 函数接收该链接;
4.创建goroutine去处理链接:服务端通过 read() 函数从上述已建立连接读取客户端发送的请求数据,经过处理后再通过 write() 函数将响应数据发送给客户端
TCP客户端的一般处理流程
1.建立 Socket:客户端同样使用 socket()函数建立网络套接字;
2.建立连接:建立连接:然后调用 connect() 函数传入 IP 和端口号建立与指定服务端网络程序的连接;
3.发送请求与接收响应:连接建立成功后,客户端就可以通过 write() 函数向服务端发送数据,并使用 read() 函数从服务端接收响应。
TCP服务器
package main import ( "fmt" "log" "net" ) func chkError(err error) { if err != nil { log.Fatal(err); } } func main() { //创建一个TCP服务端 tcpaddr, err := net.ResolveTCPAddr("tcp4", "127.0.0.1:8081"); chkError(err); //监听端口 tcplisten, err2 := net.ListenTCP("tcp", tcpaddr); chkError(err2); fmt.Println("Server Start") //.建立链接并处理 go func(){ for { //如果有客户端链接过来,阻塞会返回 conn, err := tcplisten.AcceptTCP() if err != nil { fmt.Println("Accept err", err) continue } //已经与客户端建立链接,处理业务 go func() { for { buf := make([]byte, 512) cnt, err := conn.Read(buf) if err != nil { fmt.Println("recv buf err", err) continue } //回显功能 if _, err := conn.Write(buf[:cnt]); err != nil { fmt.Println("write bak buf err", err) continue } } }() } }() //阻塞状态 select {} }
TCP客户端
package main import ( "fmt" "net" "time" ) func main(){ //1.创建链接远程链接服务器,得到一个conn链接 conn,err := net.Dial("tcp","127.0.0.1:8081") if err != nil { fmt.Println("client start err,exit!") return } i := 1 for { //2.调用链接Write写数据 _,err := conn.Write([]byte(fmt.Sprintf("%s:%d", "Hello Server", i))) if err != nil { fmt.Println("write conn err", err) return } buf := make([]byte,512) cnt,err := conn.Read(buf) if err != nil{ fmt.Println("read buf err") return } fmt.Printf("Server call back:%s,cnt = %d\n",buf,cnt) i++ time.Sleep(1) }