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")

相关推荐
飞滕人生TYF1 分钟前
Java retainAll() 详解
java·开发语言·windows·java基础
西北大程序猿1 分钟前
C++ ──── set和map的模拟实现
开发语言·数据结构·c++
sc写算法3 分钟前
C++ 类型转换
开发语言·c++·类型转换
江河湖海15 分钟前
使用Python编写一个简单的网站爬虫,从网站上抓取新闻标题和链接。
开发语言·爬虫·python
Likelong~30 分钟前
RPC框架负载均衡
网络协议·rpc·负载均衡
0号——开拓者43 分钟前
Python函数——函数的传入参数
开发语言·python
YRr YRr1 小时前
理解 Python 解释器:CPython 与 IPython 的比较及选择指南
开发语言·python·ipython
予安灵1 小时前
Python中exifread库使用
开发语言·python·exifread
lsx2024061 小时前
迭代器模式
开发语言
环境感知1 小时前
基于MATLAB的激光雷达与相机联合标定原理及实现方法——以标定板为例
开发语言·人工智能·数码相机·算法·matlab