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()}
- Go语言网络编程
- go语言网络编程
- 《go语言网络编程》笔记
- Go语言网络编程示例-客户端篇
- go语言网络编程之tcp
- GO语言网络编程之TCP (v1)
- GO语言网络编程之TCP (v2)
- Go语言TCP网络编程(详细)
- Go语言TCP网络编程(详细)
- Go网络编程
- Go 网络编程简介
- Goolge Go编程语言
- Go编程语言简介
- Go 编程语言规范
- Go编程语言简介
- GO语言tcpip 编程
- Go 编程语言入门教程
- Go 语言编程
- 1014 装箱问题
- Android systrace使用
- Parameter index out of range (1 > number of parameters,which is 0).
- 奥迪宝马爆奔驰?
- dubbo组成原理-http服务消费端如何调用
- Go语言网络编程
- sublime text 3 录制并使用宏 自动在行尾加分号
- 写给大数据开发初学者的话 | 附教程
- 关于lucas的应用
- Java中Properties类
- 详细记录python的range()函数用法
- c++作业五
- 【Python】获取两个日期之间的所有日期的列表
- 红黑树