Go语言网络编程

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 main

import (
    "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 main

import (
     "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()
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值