Go语言网络编程

来源:互联网 发布:虎鲸vs大白鲨 知乎 编辑:程序博客网 时间:2024/05/21 20:30

1.Dial函数
(1)函数原型
func Dial(net,addr string) (Conn,error)
net:网络协议的名字
addr:IP地址或域名,端口号以”:”的形式跟随在地址或域名后
例子:
TCP链接
conn,err:=net.Dial(“tcp”,”192.158.0.10:2100”)
UDP链接
conn.err:=net.Dial(“udp”,”192.168.0.12:975”)
ICMP链接
conn,err:=net.Dial(“ip4:icmp”,”www.baidu.com”)

2.关于RPC编程
定义:RPC是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络细节的应用程序通信协议。RPC协议构建于TCP或UDP,或者是HTTP之上,允许开发者直接调用另一台计算机上的程序,而开发者无需额外为这个调用过程编写网络通信相关代码,使得开发包括网络分布式程序在内的应用程序更加容易。

架构:C/S架构
(1)客户端程序发出带有参数的调用信息到服务端等待服务端响应
(2)服务进程保持睡眠状态直到客户端的调用信息到服务端

RPC服务端,可以将一个对象注册为可访问的服务,之后该对象的公开方法就能够以远程的方式提供访问
可以注册多个不同类型的对象,但是不允许注册同一类型的多个对象
对象中的方法需要满足的条件:
(1)必须是对象外部可公开调用的方法(首字母大写)
(2)必须有两个参数,且参数的类型都必须是包外部可以访问的类型或者是Go内建支持的类型
(3)第二个参数必须是一个指针
(4)方法必须返回一个error类型的值
func (t *T) MethodName(argType T1,replyType *T2) error

一个简易客户端服务器同信的实现:
服务端
(1)调用net.Listen(“tcp”,”192.168.1.11:6500”)以tcp协议监听192.168.1.11的6500端口
(2)调用之前获取的listener.Accept()监听并接收客户端发来的链接
(3)用成功接收返回的conn.Read()进行读取

package mainimport (    "fmt"    "net")func ServerBase() {      fmt.Println("Starting the server...")      //create listener      listener, err := net.Listen("tcp", "192.168.1.11:6500")      if err != nil {          fmt.Println("Error listening:", err.Error())          return      }    // listen and accept connections from clients:    for {        conn, err := listener.Accept()        if err != nil {            fmt.Println("Error accepting:", err.Error())            return        }        //create a goroutine for each request.        go doServerStuff(conn)    }}func doServerStuff(conn net.Conn) {    fmt.Println("new connection:", conn.LocalAddr())    for {        buf := make([]byte, 1024)        length, err := conn.Read(buf)        if err != nil {            fmt.Println("Error reading:", err.Error())            return        }        fmt.Println("Receive data from client:", string(buf[:length]))    }}func main(){ ServerBase()}

客户端
(1) conn, err := net.Dial(“tcp”, “192.168.1.11:6500”)调用此函数对指定目标进行指定协议的链接
(2)成功链接以后用conn.Write()进行写操作

package mainimport (     "fmt"     "net"     "os"     "bufio"     "strings")func ClientBase() {    //open connection:    conn, err := net.Dial("tcp", "192.168.1.11:6500")    if err != nil {         fmt.Println("Error dial:", err.Error())        return    }    inputReader := bufio.NewReader(os.Stdin)      fmt.Println("Please input your name:")      clientName, _ := inputReader.ReadString('\n')      inputClientName := strings.Trim(clientName, "\n")      //send info to server until Quit      for {          fmt.Println("What do you send to the server? Type Q to quit.")          content, _ := inputReader.ReadString('\n')          inputContent := strings.Trim(content, "\n")          if inputContent == "Q" {              return          }          _, err := conn.Write([]byte(inputClientName + " says " + inputContent))          if err != nil {              fmt.Println("Error Write:", err.Error())              return          }      }  }func main(){ClientBase()}
0 0
原创粉丝点击