当前位置: 首页 > 软件库 > 程序开发 > 常用工具包 >

Pingo

Go 的插件化开发
授权协议 MIT
开发语言 Google Go
所属分类 程序开发、 常用工具包
软件类型 开源软件
地区 不详
投 递 者 吕皓
操作系统 跨平台
开源组织
适用人群 未知
 软件概览

Pingo 是一个用来为 Go 程序编写插件的简单独立库,因为 Go 本身是静态链接的,因此所有插件都以外部进程方式存在。Pingo 旨在简化标准 RPC 包,支持 TCP 和 Unix 套接字作为通讯协议。当前还不支持远程插件,如果有需要,远程插件很快会提供。

使用 Pingo 创建一个插件非常简单,首先新建目录,如 "plugins/hello-world" ,然后在该目录下编写 main.go:

// Always create a new binary
package main

import "github.com/dullgiulio/pingo"

// Create an object to be exported
type MyPlugin struct{}

// Exported method, with a RPC signature
func (p *MyPlugin) SayHello(name string, msg *string) error {
    *msg = "Hello, " + name
    return nil
}

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

    // Register the objects to be exported
    pingo.Register(plugin)
    // Run the main events handler
    pingo.Run()
}

编译:

$ cd plugins/hello-world
$ go build

接下来就可以调用该插件:

package main

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

func main() {
    // Make a new plugin from the executable we created. Connect to it via TCP
    p := pingo.NewPlugin("tcp", "plugins/hello-world/hello-world")
    // Actually start the plugin
    p.Start()
    // Remember to stop the plugin when done using it
    defer p.Stop()

    var resp string

    // Call a function from the object we created previously
    if err := p.Call("MyPlugin.SayHello", "Go developer", &resp); err != nil {
        log.Print(err)
    } else {
        log.Print(resp)
    }
}
  • 数据导入Pingo数据库 alter table dw.acoustics.2050_mea_f_t_zongbiao_analysisdata add if not exists partition(date='20191130' ,hour='00'); insert overwrite table dw.acoustics.2050_mea_f_t_zongbiao_analysisdat

  • Pingo 是一个用来为 Go 程序编写插件的简单独立库,因为 Go 本身是静态链接的,因此所有插件都以外部进程方式存在。Pingo 旨在简化标准 RPC 包,支持 TCP 和 Unix 套接字作为通讯协议。当前还不支持远程插件,如果有需要,远程插件很快会提供。 使用 Pingo 创建一个插件非常简单,首先新建目录,如 "plugins/hello-world" ,然后在该目录下编写 main.g

  • package pingo import (     "fmt"     "math/rand"     "strings" ) type meta string //定义 自定义数据类型 //输出包含自身在内的参数字符串 func (h meta) output(key, val string) {     fmt.Printf("%s: %s: %s\n", string(h), key,

  • 首先在palo数据库中建立表格 CREATE TABLE `sfc_2050_mea_f_t_zongbiao_total_analysisdata` ( `zp_carrier_code_1` varchar(200) COMMENT "", `test_id` bigint(20) COMMENT "", `sn` varchar

  • Pingo工作空间建表方式一: CREATE TABLE `dw.acoustics`.`test20191220` (`prod_code` string , `ball_code` string COMMENT '', `circle_code` string

  • Pingo 是一个用来为Go语言程序编写插件的简单独立库,因为 Go 本身是静态链接的,因此所有插件都以外部进程方式存在。Pingo 旨在简化标准 RPC 包,支持 TCP 和 Unix 套接字作为通讯协议。当前还不支持远程插件,如果有需要,远程插件很快会提供。 使用 Pingo 创建一个插件非常简单,首先新建目录,如 "plugins/hello-world" ,然后在该目录下编写 main.g

 相关资料
  • 这些插件在您的软件开发过程中提供帮助. Table 22.6. Software development plugins Plugin Id 自动应用 协同工作 描述 build-dashboard reporting-base - 生成构建仪表板报告. build-init wrapper - 对Gradle初始化一个新构建提供支持.将一个Maven构建转换为Gradle构建 cnuit - -

  • 本文向大家介绍JavaScript插件化开发教程(五),包括了JavaScript插件化开发教程(五)的使用技巧和注意事项,需要的朋友参考一下 一,开篇分析 Hi,大家好!前两篇文章我们主要讲述了以“jQuery的方式如何开发插件”,以及过程化设计与面向对象思想设计相结合的方式是如何设计一个插件的,两种方式各有利弊取长补短,嘿嘿嘿,废话少说,进入正题。直接上实际效果图:   大家看到了吧,这是一个

  • 本文向大家介绍JavaScript插件化开发教程(六),包括了JavaScript插件化开发教程(六)的使用技巧和注意事项,需要的朋友参考一下 一,开篇分析 今天这篇文章我们说点什么那?嘿嘿嘿。我们接着上篇文章对不足的地方进行重构,以深入浅出的方式来逐步分析,让大家有一个循序渐进提高的过程。废话少说,进入正题。让我们先来回顾一下之前的 Js部分的代码,如下:   效果如下图所示:   a)----

  • 上一节,我们看到了一个完整的 Kibana 插件的官方用例。一般来说,我们不太会需要自己从头到尾写一个 angular app 出来。最常见的情况,应该是在 Kibana 功能的基础上做一定的二次开发和扩展。其中,可视化效果应该是重中之重。本节,以一个红绿灯效果,演示如何开发一个 Kibana 可视化插件。 插件目录生成 Kibana 开发组提供了一个简单的工具,辅助我们生成一个 Kibana 插

  • FIS3 是以 File 对象为中心构建编译的,每一个 File 都要经历编译、打包、发布三个阶段。运行原理讲述了 FIS3 中的插件扩展点;那么本节就将说明一个插件如何开发; 如上图,编译起初,扫描项目目录下的所有文件(不包含指定排除文件),后实例化 File 对象,并对 File 内容进行编译分析; 编译阶段插件 在编译阶段,文件是单文件进行编译的,这个阶段主要是对文件内容的编译分析;这个阶段

  • 插件需要 export 一个函数,函数会接收到两个参数,第一个是 build-scripts 提供的 pluginAPI,第二个是用户传给插件的自定义参数,如下: module.exports = (pluginAPI, options) => { const { context, log, onHook } = pluginAPI; }; pluginAPI

  • 初始化插件 你可以通过 create-umi 直接创建一个 umi 插件的脚手架: $ yarn create umi --plugin 在 umi 中,插件实际上就是一个 JS 模块,你需要定义一个插件的初始化方法并默认导出。如下示例: export default (api, opts) => { // your plugin code here }; 需要注意的是,如果你的插件需要发

  • 插件开发 消费器插件 继承AbstractDataConsumer类 通过spring.factories发布: cn.vbill.middleware.porter.core.task.consumer.DataConsumer=xxx 通过配置文件生效: porter.task[index].consumer.consumerName=pluginName EventConverte