golang中rpc

c客户端和服务端处理方式要一致否则客户端访问不了

复制代码
	rpc.RegisterName("HelloService", new(HelloService))
	rpc.HandleHTTP() //客户端使用rpc.DialHTTP
	if err := http.ListenAndServe("127.0.0.1:8080", nil); err != nil {
		log.Fatal("serve error:", err)
	}

上面的的rpc服务的启动是http工具封装后的等价于以下方式:

复制代码
	rpc.RegisterName("HelloService", new(HelloService))
	rpc.HandleHTTP() //客户端使用rpc.DialHTTP
    listener, err := net.Listen("tcp", "127.0.0.1:8080")
	if err != nil {
		log.Fatal("ListenTCP error:", err)
	}
	fmt.Println("服务已启动")
	http.Serve(listener, nil)

他们的底层都是net网络包的功能。

注意的是当服务端使用rpc.HandleHTTP()方式处理时客户但必须使用rpc.DialHTTP方式拨号,用rpc.Dial无法远程访问,

Server有多种Socket监听的方式:

`Accept`用来处理一个监听器,一直在监听客户端的连接,客户端断开服务端停止,如下使zh

cpp 复制代码
Server有多种Socket监听的方式:
 func (server *Server) Accept(lis net.Listener)
 func (server *Server) HandleHTTP(rpcPath, debugPath string)
 func (server *Server) ServeCodec(codec ServerCodec)
 func (server *Server) ServeConn(conn io.ReadWriteCloser)
 func (server *Server) ServeHTTP(w http.ResponseWriter, req *http.Request)
 func (server *Server) ServeRequest(codec ServerCodec) error
cpp 复制代码
fmt.Println("等待客户端连接")
conn, err := listener.Accept()
if err != nil {
	log.Fatal("Accept error:", err)
}
fmt.Println("服务已经启动")
rpc.ServeConn(conn)

问题拨号的方式rpc.Dial("tcp","ip")

相关推荐
我不会编程55514 小时前
Python Cookbook-5.1 对字典排序
开发语言·数据结构·python
李少兄14 小时前
Unirest:优雅的Java HTTP客户端库
java·开发语言·http
无名之逆14 小时前
Rust 开发提效神器:lombok-macros 宏库
服务器·开发语言·前端·数据库·后端·python·rust
似水এ᭄往昔14 小时前
【C语言】文件操作
c语言·开发语言
啊喜拔牙15 小时前
1. hadoop 集群的常用命令
java·大数据·开发语言·python·scala
xixixin_15 小时前
为什么 js 对象中引用本地图片需要写 require 或 import
开发语言·前端·javascript
W_chuanqi15 小时前
安装 Microsoft Visual C++ Build Tools
开发语言·c++·microsoft
anlogic15 小时前
Java基础 4.3
java·开发语言
A旧城以西16 小时前
数据结构(JAVA)单向,双向链表
java·开发语言·数据结构·学习·链表·intellij-idea·idea
Liudef0616 小时前
deepseek v3-0324实现SVG 编辑器
开发语言·javascript·编辑器·deepseek