推送通知和 Spring Cloud Bus
许多源代码存储库提供商(例如 Github、Gitlab、Gitea、Gitee、Gogs 或 Bitbucket)通过 Webhook 通知您存储库中的更改。
您可以通过提供商的用户界面将 Webhook 配置为 URL 和您感兴趣的一组事件。
例如,Github 对 Webhook 使用 POST,其中包含包含提交列表和标头 (X-Github-Event
) 设置为push
.
如果您在spring-cloud-config-monitor
库并在 Config Server 中激活 Spring Cloud Bus,然后/monitor
endpoint 已启用。
激活 webhook 后,Config Server 会发送一个RefreshRemoteApplicationEvent
针对它认为可能已更改的应用程序。
可以制定更改检测策略。
但是,默认情况下,它会在文件中查找与应用程序名称匹配的更改(例如foo.properties
以foo
application,而application.properties
面向所有应用程序)。
当您想要覆盖行为时,要使用的策略是PropertyPathNotificationExtractor
,它接受请求标头和正文作为参数,并返回已更改的文件路径列表。
默认配置与 Github、Gitlab、Gitea、Gitee、Gogs 或 Bitbucket 开箱即用。
除了来自 Github、Gitlab、Gitee 或 Bitbucket 的 JSON 通知外,您还可以通过对/monitor
其中表单编码的 body 参数采用path={application}
.
这样做会广播到与{application}
pattern(可以包含通配符)。
这RefreshRemoteApplicationEvent 仅当spring-cloud-bus 在 Config Server 和 Client 端应用程序中激活。 |
默认配置还会检测本地 git 存储库中的文件系统更改。在这种情况下,不使用 Webhook。但是,一旦您编辑了配置文件,就会广播刷新。 |