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()
}