1.使用 golang-plugins 时要避免的源码事情
使用 golang-plugins 时要避免的事情
在计划开源项目时,我们需要处理与golang-plugins相关的源码一系列挑战。由于公司对授权逻辑代码的源码特殊需求,我们计划在保持功能的源码同时,移除这部分定制代码,源码产品对比网站源码以便用户可以独立实现自己的源码源码编辑器素材大全逻辑而无需重新编译整个程序。 我们的源码代码基于Go语言,golang-plugins提供了通过go build -buildmode=plugin构建插件的源码解决方案。然而,源码在实践过程中,源码我们遇到了几个关键问题:不同Go版本兼容性:插件和主应用必须使用完全相同的源码Go工具链版本,否则会报错。源码目前尚无官方解决方案,源码源码编译成库 版权因为插件和主程序的源码二进制文件必须%兼容。
GOPATH一致性:同样,源码插件和主应用的GOPATH路径需一致,否则会遇到包版本冲突。机构内部副图源码用法官方建议使用docker镜像中的标准GOPATH。
vendor文件夹问题:使用vendor文件夹时,可能会导致接口转换错误,1.8版本后这个问题依然存在。梦想逍遥游整套源码解决办法是复制vendor内容到GOPATH中。
公共依赖项版本一致性:插件依赖需与主应用完全匹配,避免不同版本冲突。
静态二进制文件构建限制:golang-plugins不支持构建静态二进制,这限制了使用场景,特别是对于最小化docker镜像的需求。
这些挑战表明golang-plugins并不成熟,它增加了主应用和插件之间的耦合度,维护成本较高。因此,我们最终选择了一个基于RPC通信的hashicorp插件包,尽管它有局限,但问题相对更容易解决。 为了便于测试上述问题,你可以在这里找到相关源码。本文由Alper Köse撰写,翻译和校对工作由herowk和polaris完成,由GCTT原创编译并由Go语言中文网推出。