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

相关推荐
酷爱码32 分钟前
如何通过python连接hive,并对里面的表进行增删改查操作
开发语言·hive·python
画个大饼33 分钟前
Go语言实战:快速搭建完整的用户认证系统
开发语言·后端·golang
喵先生!2 小时前
C++中的vector和list的区别与适用场景
开发语言·c++
Thomas_YXQ2 小时前
Unity3D Lua集成技术指南
java·开发语言·驱动开发·junit·全文检索·lua·unity3d
xMathematics3 小时前
计算机图形学实践:结合Qt和OpenGL实现绘制彩色三角形
开发语言·c++·qt·计算机图形学·cmake·opengl
yuanManGan5 小时前
C++入门小馆: 深入了解STLlist
开发语言·c++
北极的企鹅885 小时前
XML内容解析成实体类
xml·java·开发语言
BillKu5 小时前
Vue3后代组件多祖先通讯设计方案
开发语言·javascript·ecmascript
Python自动化办公社区5 小时前
Python 3.14:探索新版本的魅力与革新
开发语言·python
逐光沧海5 小时前
STL常用算法——C++
开发语言·c++