caddy中怎么添加自定义插件

发布时间:2021-06-22 15:31:13 作者:Leah
来源:亿速云 阅读:182

这期内容当中小编将会给大家带来有关caddy中怎么添加自定义插件,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

创建一个 Go Package

首先为 caddy 创建一个 插件的 Go Package ,你可以新建一个文件夹达到这个效果。比如

├── caddy-plugin
│   ├── gizmo.go
│   └── setup.go

这里分为了两个 Go 文件,接下来详细讲每一个 Go 文件的作用。

<a name="nmOnZ"></a>

代码????:注册 caddy plugin

首先我们看到 setup.go

<a name="HXIC2"></a>

setup.go

创建 setup.go 文件并写入以下信息

import "github.com/mholt/caddy"

func init() {
    caddy.RegisterPlugin("gizmo", caddy.Plugin{
        ServerType: "http",
        Action:     setup,
    })
}

这里是 建立了一个新插件,caddy 包来做到插件的注册。

  1. 注意到 “gizmo” 这是 插件的名字,同时也是指令的名字,请为你的插件取一个独一无二的名字吧。(注意:名字需要是单词小写哦。)

  2. 因为是针对 HTTP 服务器的插件,所以 ServerType 字段值是 “http”

  3. 另一个设置的字段是 setup ,实际上,我们接下来会填充这个函数的逻辑。它的作用就是将我们插件的处理逻辑安装到 Caddy 中。

<a name="6sJEa"></a>

setup

现在我们来实现 setup 函数 <br /> <br />假如我们希望在Caddyfile中有一行这样的行:

gizmo foobar

<br />我们可以得到刚才所说的 c.Next() 第一个参数(“foobar”)的值,如下所示:

for c.Next() {              // skip the directive name
    if !c.NextArg() {       // expect at least one value
        return c.ArgErr()   // otherwise it's an error
    }
    value := c.Val()        // use the value
}

我们首先注意到, c.Next() 是真正我们读取 caddyfile 逻辑的地方,caddyfile 就是配置服务器的配置文件的名字。我们注意到,这里的操作实际上是使用 caddy.Controller 来实现的。它的存在 让编写插件的开发者只需要关注如何使用它来执行你的命令,这是一项优秀的设计,有兴趣可以看我的源码阅读部分关于 Plugin 的具体实现。

在 Caddy 解析了Caddyfile之后,它将迭代每个指令名(按照服务器类型规定的顺序),并在每次遇到指令名时调用指令的setup函数。setup函数的职责是解析指令的标识并配置自己。<br /> <br />您可以通过遍历c.Next()来解析为指令提供的标识,只要有更多的标识需要解析,那么c.Next()就会返回true。由于一个指令可能出现多次,你必须遍历c.Next()以获得所有出现的指令并使用第一个标识(即指令名)。<br />有关caddyfile包,请参阅godoc以了解如何更充分地使用分发器,并查看任何其他现有插件。

<a name="fzu7b"></a>

代码 ????:Handler 实现

<a name="iyY6W"></a>

gizmo.go:

查看httpserver包的godoc。最重要的两种类型是httpserver.Handler和httpserver.Middleware。

  1. Handler是一个处理HTTP请求的函数。

  2. Middleware是一种连接Handler的方式。

Caddy将负责为你设置HTTP服务器的所有簿记(bookkeeping)工作,但是你需要实现这两种类型。<br />

<a name="sPXzP"></a>

Struct

httpserver.Handler是一个几乎和http.Handler完全一样的接口,除了ServeHTTP方法返回(int, error)。<br />这个方法签名遵循Go语言博客中关于与中间件相关的错误处理的建议。<br />int是HTTP状态码,error应该被处理和/或记录。有关这些返回值的详细信息,请参阅godoc。<br /> <br />Handler通常是一个结构体,至少包含一个Next字段,用来链接下一个Handler

type gizmoHandler struct {
	next httpserver.Handler
}

<br />除了这些之外,可以添加一些自己使用的参数,考虑 grpc 的 plugin 实现,解释放在代码块中的注释中

type server struct {
	backendAddr       string // 监听地址
	next              httpserver.Handler // 作为中间件必须有的字段
    backendIsInsecure bool // 是否启用 Insecure() 选项,是 grpc 的一项配置
	backendTLS        *tls.Config // 关于 TLS 的使用的证书文件
	wrappedGrpc       *grpcweb.WrappedGrpcServer // 通过 grpcweb 的 协议实现 HTTP 请求等
}

这就是参考的一个 字段的使用。可以根据自己的需要,调整在 caddyfile 中读取的指令应该如何配置。

<a name="K5EDA"></a>

httpserver.Handler

为了实现httpserver.Handler接口,我们需要编写一个名为ServeHTTP的方法。这个方法是实际的处理程序函数,除非它自己处理完毕请求,否则它应该调用链中的下一个Handler:即使用 g.next.ServeHTTP(w, r)

func (g gizmoHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error) {
	return g.next.ServeHTTP(w, r)
}

这里只是框架,具体逻辑可以自行填充,可以参照已有的 Plugin 实现。<br />

<a name="RiOqc"></a>

第二步,注册 Middleware

然后我们可以进行第二步,将这个 handler 注册到整个 caddy 的 http 调用链上。

我们需要回到 刚才的 setup.go 文件中,<br />回到设置函数。你刚刚解析了标识并使用所有适当的配置设置了中间件处理程序:

func setup(c *caddy.Controller) error {
	g := gizmoHandler{} // 用来实现 HTTPHandler 的 next 的结构,用来构建 中间件。也可以加入一些自己的字段

    for c.Next() {
        // 获取配置文件,并处理
    }
    // 现在开始注册中间件
	httpserver.GetConfig(c).AddMiddleware(func(next httpserver.Handler) httpserver.Handler {
		g.next = next
		return g
	})
	
	return nil
}

这样,代码部分就全部完成了。

下面我们查看需要注意的事项。实际上是关乎于怎样将写好的插件集成在 caddy 中。

<a name="WTOo3"></a>

排序

要做的事情是告诉服务器类型在进程的什么地方执行你的指令。这一点很重要,因为其他指令可能会设置你所依赖的更原始的配置,因此执行指令的顺序不能是随意的。<br /> <br />每个服务器类型都有一个字符串列表,其中每个项都是一个指令的名称。例如,查看HTTP服务器支持的指令列表。将指令添加到适当的位置。<br />

<a name="c75IF"></a>

插入你的插件

最后,不要忘记导入你的插件包!Caddy必须导入插件来注册并执行它。这通常是在run.go的import部分的尾部完成的:<br />

_ "your/plugin/package/here"

请注意:包名前的_是必需的。

<a name="1aHEv"></a>

上述就是小编为大家分享的caddy中怎么添加自定义插件了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。

推荐阅读:
  1. caddy 反代wordpress + ssl证书生成
  2. PHP Smarty 模板 自定义插件

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

caddy

上一篇:service nginx reload|restart|upgrade 命令流程是什么

下一篇:Disruptor-06 中有哪些等待策略

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》