Go語言(Pingo)外掛化開發

2020-07-16 10:05:17
Pingo 是一個用來為Go語言程式編寫外掛的簡單獨立庫,因為 Go 本身是靜態連結的,因此所有外掛都以外部進程方式存在。Pingo 旨在簡化標準 RPC 包,支援 TCP 和 Unix 通訊端作為通訊協定。當前還不支援遠端外掛,如果有需要,遠端外掛很快會提供。

使用 Pingo 建立一個外掛非常簡單,首先新建目錄,如 "plugins/hello-world" ,然後在該目錄下編寫 main.go:
// 建立新的二進位制檔案
package main

import "github.com/dullgiulio/pingo"

// 建立要匯出的物件
type MyPlugin struct{}

// 匯出的方法,帶有rpc簽名
func (p *MyPlugin) SayHello(name string, msg *string) error {
    *msg = "Hello, " + name
    return nil
}

func main() {
    plugin := &MyPlugin{}

    // 註冊要匯出的物件
    pingo.Register(plugin)
    // 執行主程式
    pingo.Run()
}
使用 go build 命令編譯並生成可執行檔案:

cd plugins/hello-world
go build

接下來就可以呼叫該外掛:
package main

import (
    "log"
    "github.com/dullgiulio/pingo"
)

func main() {
    // 從建立的可執行檔案中建立一個新外掛。通過 TCP 連線到它
    p := pingo.NewPlugin("tcp", "plugins/hello-world/hello-world")
    // 啟動外掛
    p.Start()
    // 使用完外掛後停止它
    defer p.Stop()

    var resp string

    // 從先前建立的物件呼叫函數
    if err := p.Call("MyPlugin.SayHello", "Go developer", &resp); err != nil {
        log.Print(err)
    } else {
        log.Print(resp)
    }
}
執行結果如下:

go run main.go
2019/12/17 18:00:20 Hello, Go developer