本篇内容介绍了“go rpc的基本使用方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:主机域名、网站空间、营销软件、网站建设、无棣网站维护、网站推广。
服务端
package main import ( "fmt" "net" "net/rpc" "net/rpc/jsonrpc" "os" "os/exec" "reflect" "time" "github.com/agiledragon/gomonkey" ) type Mock struct { } func (m *Mock) MockFunc(name string, reply *int) error { gomonkey.ApplyMethod(reflect.TypeOf(&exec.Cmd{}), "Output", func(c *exec.Cmd) ([]byte, error) { return []byte(c.String()), nil }) *reply = 1000 fmt.Println("name=>", name) return nil } func test() { cmd := &exec.Cmd{} b, err := cmd.Output() fmt.Println(b, err) } func main() { go A() time.Sleep(time.Minute) } func A() { mock := new(Mock) rpc.Register(mock) tcpAddr, err := net.ResolveTCPAddr("tcp", ":1234") if err != nil { fmt.Println("Fatal error ", err.Error()) os.Exit(1) } listener, err := net.ListenTCP("tcp", tcpAddr) if err != nil { fmt.Println("Fatal error ", err.Error()) os.Exit(1) } for { conn, err := listener.Accept() if err != nil { continue } jsonrpc.ServeConn(conn) } }
客户端
package main import ( "fmt" "log" "net/rpc/jsonrpc" ) func main() { client, err := jsonrpc.Dial("tcp", "127.0.0.1:1234") if err != nil { log.Fatal("dialing:", err) } var reply int err = client.Call("Mock.MockFunc", "exec.Cmd", &reply) if err != nil { log.Fatal("arith error:", err) } fmt.Println(reply) }
“go rpc的基本使用方法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!