• go语言插件平台的实现思路


        最近在准备给物联网平台添加插件模块,然后在准备做插件的时候,发现实现Golang的插件遇到问题了,不知道要怎么来实现这个插件的功能,因为找来找去,发现golang插件有很多的问题,比如没有办法实现跨平台,没有办法实现跨语言支持,比如我用c编译成so文件或者dll文件,然后给go进行直接调用,这些都比较麻烦,然后go官方的实现插件必须要插件和主程序的版本一致,代码一致,依赖一致等,这样做的插件将会带来很多的麻烦问题,比如插件的版本管理,升级这些都是问题。

    然后看到网上的插件处理目前主要有两种方式,一种是通过rpc或grpc进行支持,另外一种则是编译型插件,编译型插件的话,就是通过编译源码的方式进行插件的加入,然后通过配置文件,进行插件的启用和关停。

    然后通过总结和反思,我思考了一下,目前主要有以下几种实现思路:

    • 1.本地socket (如果为unix系统操作系统的话,就要使用UNIX Domain Socket, 非Unix系列系统的话,就用本地网络比如:127.0.0.1来实现),当然可以的话,还是用UNIX Domain Socket,使用它作为IPC的话有以下几点优点:
    • 不需要经过网络协议栈
    • 不需要打包拆包、计算校验和、维护序号和应答等,可靠性更强
    • 2.使用共享内存+消息队列:先开辟出一块内存池用于消息的收发,一边将数据放入内存,然后将内存地址信息通过消息队列的形式通知对方,然后做超时机制,比如1分钟之后,不管对方有没有接收,都对消息进行回收。
    • 3.通过cgo的形式进行实现。
    • 4.通过解释性语言插件进行支持。

    经过综合评估之后,我觉得通过socket通信的方式来进行插件的实现还是比较好的思路,毕竟不管是2还是3,功能也都能实现,也能跨语言,跨系统就不一定了,然后还有就是时间问题,以及成本问题,毕竟我们大部分人都是打工人,都是要生活的,没有那么多的时间和精力来搞这些没有多大意义的东西,4的话,后期看吧,打算是支持lua语言的。

  • 相关阅读:
    使用yield实现一个协成
    串讲-Python基础练习
    Linux练习
    列表生成式
    Jupyter Notebook的快捷键帮助文档
    mysql字段类型
    爬取12306火车票信息
    【Lodop】02 C-Lodop手册阅读上手
    【Lodop】01 Lodop手册阅读上手
    【Redis】06 事务
  • 原文地址:https://www.cnblogs.com/kmust/p/16421217.html
Copyright © 2020-2023  润新知