本篇內容介紹了“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的基本使用方法”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。