欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Go語言net包RPC遠(yuǎn)程調(diào)用三種方式http與json-rpc及tcp

 更新時間:2021年11月16日 15:28:26   作者:秋天的春  
這篇文章主要為大家介紹了Go語言net包RPC遠(yuǎn)程調(diào)用三種方式分別使用http與json-rpc及tcp的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助

rpc有多種調(diào)用方式,http、json-rpc、tcp

一、服務(wù)端

在代碼中,啟動了三個服務(wù)

package main
import (
	"log"
	"net"
	"net/http"
	"net/rpc"
	"net/rpc/jsonrpc"
	"sync"
) 
//go對RPC的支持,支持三個級別:TCP、HTTP、JSONRPC
//go的RPC只支持GO開發(fā)的服務(wù)器與客戶端之間的交互,因為采用了gob編碼 
//注意字段必須是導(dǎo)出
type Params struct {
	Width, Height int
} 
type Rect struct{} 
//函數(shù)必須是導(dǎo)出的
//必須有兩個導(dǎo)出類型參數(shù)
//第一個參數(shù)是接收參數(shù)
//第二個參數(shù)是返回給客戶端參數(shù),必須是指針類型
//函數(shù)還要有一個返回值error
func (r *Rect) Area(p Params, ret *int) error {
	*ret = p.Width * p.Height
	return nil
} 
func (r *Rect) Perimeter(p Params, ret *int) error {
	*ret = (p.Width + p.Height) * 2
	return nil
} 
func main() {
	rect := new(Rect)
	//注冊一個rect服務(wù)
	rpc.Register(rect)
	var wg sync.WaitGroup
	wg.Add(3)
	go func() {
		//把服務(wù)處理綁定到http協(xié)議上
		rpc.HandleHTTP()
		err := http.ListenAndServe(":8080", nil)
		wg.Wait()
		if err != nil {
			log.Fatal(err)
			defer wg.Done()
		}
	}()
	log.Println("http rpc service start success addr:8080") 
	go func() {
 
		tcpaddr, _ := net.ResolveTCPAddr("tcp", "127.0.0.1:8081")
		tcplisten, err := net.ListenTCP("tcp", tcpaddr)
		if err != nil {
			log.Fatal(err)
			defer wg.Done()
		}
		for {
			conn, err3 := tcplisten.Accept()
			if err3 != nil {
				continue
			}
			go rpc.ServeConn(conn)  
		} 
	}()
	log.Println("tcp rpc service start success addr:8081")
 	go func() { 
		tcpaddr, _ := net.ResolveTCPAddr("tcp", "127.0.0.1:8082")
		tcplisten, err := net.ListenTCP("tcp", tcpaddr)
		if err != nil {
			log.Fatal(err)
			defer wg.Done()
		}
		for {
			conn, err3 := tcplisten.Accept()
			if err3 != nil {
				continue
			}
			go jsonrpc.ServeConn(conn)
		} 
	}()
	log.Println("tcp json-rpc service start success addr:8082") 
	wg.Wait()
}

二、http客戶端

package main
import (
	"net/rpc"
	"log"
	"fmt"
)
type Params struct {
	Width, Height int
}
func main() {
	//連接遠(yuǎn)程rpc服務(wù)
	rpc, err := rpc.DialHTTP("tcp", "127.0.0.1:8080")
	if err != nil {
		log.Fatal(err)
	}
	ret := 0;
	//調(diào)用遠(yuǎn)程方法
	//注意第三個參數(shù)是指針類型
	err2 := rpc.Call("Rect.Area", Params{50, 100}, &ret)
	if err2 != nil {
		log.Fatal(err2)
	}
	fmt.Println(ret)
	err3 := rpc.Call("Rect.Perimeter", Params{50, 100}, &ret)
	if err3 != nil {
		log.Fatal(err3)
	}
	fmt.Println(ret)
}

三、TCP客戶端

package main 
import (
	"net/rpc"
	"fmt"
	"log"
) 
type Params struct {
	Width, Height int
} 
func main() {
	//連接遠(yuǎn)程rpc服務(wù)
	//這里使用Dial,http方式使用DialHTTP,其他代碼都一樣
	rpc, err := rpc.Dial("tcp", "127.0.0.1:8081")
	if err != nil {
		log.Fatal(err)
	}
	ret := 0
	//調(diào)用遠(yuǎn)程方法
	//注意第三個參數(shù)是指針類型
	err2 := rpc.Call("Rect.Area", Params{50, 100}, &ret)
	if err2 != nil {
		log.Fatal(err2)
	}
	fmt.Println(ret)
	err3 := rpc.Call("Rect.Perimeter", Params{50, 100}, &ret)
	if err3 != nil {
		log.Fatal(err3)
	}
	fmt.Println(ret)
}

四、json客戶端

package main 
import ( 
	"fmt"
	"log"
	"net/rpc/jsonrpc"
) 
type Params struct {
	Width, Height int
} 
func main() {
	//連接遠(yuǎn)程rpc服務(wù)
	rpc, err := jsonrpc.Dial("tcp", "127.0.0.1:8082")
	if err != nil {
		log.Fatal(err)
	}
	ret := 0
	//調(diào)用遠(yuǎn)程方法
	//注意第三個參數(shù)是指針類型
	err2 := rpc.Call("Rect.Area", Params{150, 100}, &ret)
	if err2 != nil {
		log.Fatal(err2)
	}
	fmt.Println(ret)
	err3 := rpc.Call("Rect.Perimeter", Params{150, 100}, &ret)
	if err3 != nil {
		log.Fatal(err3)
	}
	fmt.Println(ret)
}

五、運(yùn)行結(jié)果

以上就是Go語言net包RPC遠(yuǎn)程調(diào)用三種方式http與json-rpc及tcp的詳細(xì)內(nèi)容,更多關(guān)于Go語言net包RPC遠(yuǎn)程調(diào)用方式的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • golang內(nèi)存對齊詳解

    golang內(nèi)存對齊詳解

    在golang中,每一種數(shù)據(jù)類型都有其對應(yīng)的數(shù)據(jù)類型大小,也就是占用了多少內(nèi)存空間,我們可以通過unsafe.Sizeof函數(shù),來確定一個變量占用的內(nèi)存字節(jié)數(shù),本文將詳細(xì)給大家介紹golang內(nèi)存對齊,需要的朋友可以參考下
    2023-10-10
  • Go語言官方依賴注入工具Wire的使用教程

    Go語言官方依賴注入工具Wire的使用教程

    依賴注入是一種實現(xiàn)控制反轉(zhuǎn)且用于解決依賴性問題的設(shè)計模式。Golang?中常用的依賴注入工具主要有?Inject?、Dig?等。但是今天主要介紹的是?Go?團(tuán)隊開發(fā)的?Wire,一個編譯期實現(xiàn)依賴注入的工具,感興趣的可以了解一下
    2022-09-09
  • 一文詳解golang延時任務(wù)的實現(xiàn)

    一文詳解golang延時任務(wù)的實現(xiàn)

    這篇文章主要為大家介紹了golang延時任務(wù)的實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • Go語言集成開發(fā)環(huán)境IDE詳細(xì)安裝教程

    Go語言集成開發(fā)環(huán)境IDE詳細(xì)安裝教程

    VSCode是免費(fèi)開源的現(xiàn)代化輕量級代碼編輯器,支持幾乎所有主流的開發(fā)語言,內(nèi)置命令行工具和 Git 版本控制系統(tǒng),支持插件擴(kuò)展,這篇文章主要介紹了Go語言集成開發(fā)環(huán)境IDE詳細(xì)安裝教程,需要的朋友可以參考下
    2021-11-11
  • 解決golang post文件時Content-Type出現(xiàn)的問題

    解決golang post文件時Content-Type出現(xiàn)的問題

    這篇文章主要介紹了解決golang post文件時Content-Type出現(xiàn)的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-05-05
  • Golang如何讀取單行超長的文本詳解

    Golang如何讀取單行超長的文本詳解

    這篇文章主要給大家介紹了關(guān)于Golang如何讀取單行超長文本的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2021-12-12
  • golang中值類型/指針類型的變量區(qū)別總結(jié)

    golang中值類型/指針類型的變量區(qū)別總結(jié)

    golang的值類型和指針類型receiver一直是大家比較混淆的地方,下面這篇文章主要給大家總結(jié)介紹了關(guān)于golang中值類型/指針類型的變量區(qū)別的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下。
    2017-12-12
  • golang使用net/rpc庫實現(xiàn)rpc

    golang使用net/rpc庫實現(xiàn)rpc

    這篇文章主要為大家詳細(xì)介紹了golang如何使用net/rpc庫實現(xiàn)rpc,文章的示例代碼講解詳細(xì),具有一定的借鑒價值,需要的小伙伴可以參考一下
    2024-01-01
  • GO語言類型查詢類型斷言示例解析

    GO語言類型查詢類型斷言示例解析

    這篇文章主要為大家介紹了GO語言類型判斷及類型斷言,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-04-04
  • golang抓取網(wǎng)頁并分析頁面包含的鏈接方法

    golang抓取網(wǎng)頁并分析頁面包含的鏈接方法

    今天小編就為大家分享一篇golang抓取網(wǎng)頁并分析頁面包含的鏈接方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-08-08

最新評論