- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
是否可以收到有关位于多个 Azure 订阅中的多个存储帐户中发生的 blobCreated 事件的通知?
我想处理在我的订阅中的中央 Azure 函数中的任意存储帐户中发生的 Blob 创建事件,但我希望客户能够将数据存储在他们自己的订阅中。
我正在考虑使用事件网格 Webhook 端点将事件路由到我的中央 Azure 函数。这是否是实现多订阅场景的可靠方法?
编辑:更准确地说,我需要它在不同的租户上工作(因为我们的客户会带来他们自己的订阅,我们需要集成它们而不将它们分配给我们的 AD 租户)
最佳答案
根据我们的讨论,以下屏幕片段显示了您的 Multi-Tenancy 粉丝场景。
跨 Azure 订阅( Multi-Tenancy )订阅分布式兴趣源是通过将主题映射到 Webhook 端点来完成的。请注意,该主题表示事件发布(发布)到 AEG 服务的位置的完整资源路径 (id)。该路径在当前租户的范围内,参见以下示例:
"topic": "/subscriptions/myID/resourceGroups/myRG/providers/microsoft.storage/storageaccounts/mySA"
"endpointBaseUrl": "https://myFnc.azurewebsites.net/runtime/webhooks/EventGrid?functionName=myEventGridTrigger&code=xxxx"
此映射在存储在与主题相同范围内的订阅元数据中声明。另一方面,Webhook 端点可以发布到此范围之外。
其他更复杂的解决方案以及使用扇出发布/订阅方式的事件分发与租户的完全隔离如以下屏幕片段所示:
在上述解决方案中,扇入订阅者可以将原始事件消息调解为正确的面向业务的事件消息,包括用于访问 blob 元数据和/或正文等的短 sasToken。
要使用 EventGridTrigger 函数的事件处理程序在租户中创建事件订阅,您可以使用 REST API call 等。 ,请参见以下示例:
PUT https://management.azure.com/subscriptions/myId/resourceGroups/myRG/providers/Microsoft.Storage/storageaccounts/mySA/providers/Microsoft.EventGrid/eventSubscriptions/mySubscription?api-version=2019-01-01
标题:
Authorization:Bearer eyJ0eXAiOiJKV1QiLCJhb....
主体(最小有效负载):
{
"properties": {
"destination": {
"endpointType": "WebHook",
"properties": {
"endpointUrl": "https://myFnc.azurewebsites.net/runtime/webhooks/EventGrid?functionName=myEventGridTrigger&code=xxxxxxxx..."
}
}
}
}
更新:
在隔离的 Multi-Tenancy 分布式事件架构中使用 Azure 事件网格 Pub/Sub 模型的另一种方式是其级联。逻辑事件管道可以通过级联 Azure 事件网格来构建,例如使用自定义主题将一个 Azure 事件网格订阅到另一个事件网格。
以下屏幕片段显示了 Azure 事件网格级联的示例:
基于扇入到扇出模式的级联概念是通过以标准 Pub/Sub 方式将自定义主题端点订阅到另一个事件网格模型的 WebHook 事件处理程序来启用的。
请注意,Azure 事件网格没有用于相互级联(包括验证事件环回)的内置终结点。但是,以下步骤可以允许相互级联 Azure 事件网格。
使用 CustomInputSchema 创建自定义主题端点,例如:
{
"properties": {
"inputSchema": "CustomEventSchema",
"inputSchemaMapping": {
"properties": {
"id": {
"sourceField": null
},
"topic": {
"sourceField": null
},
"eventTime": {
"sourceField": null
},
"eventType": {
"sourceField": "myEventType",
"defaultValue": "recordInserted"
},
"subject": {
"sourceField": "subject",
"defaultValue": "/myapp/vehicles/motorcycles"
},
"dataVersion": {
"sourceField": null,
"defaultValue": "1.0"
}
},
"inputSchemaMappingType": "Json"
}
}
}
请注意,主题属性必须具有"sourceField": null,这对于自定义主题来说是可以的(不适用于事件域)。
对于 Webhook 事件处理程序端点,请在 URL 查询字符串中使用 aeg-sas-key,例如:
https://myTopic.westus-1.eventgrid.azure.net/api/events?aeg-sas-key=xxxxxxxxxx
请注意,aeg-sas-key 值必须是 url 编码的字符串。
对于订阅验证,使用“即发即忘”方式的 validationUrl 握手。它可以在EventGridTrigger函数中实现并订阅自定义主题以实现级联目的。以下代码片段显示了此实现的示例:
#r "Newtonsoft.Json"
using System;
using System.Threading.Tasks;
using System.Text;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Web;
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
public static async Task Run(JObject eventGridEvent, ILogger log)
{
log.LogInformation(eventGridEvent.ToString());
string eventType = $"{eventGridEvent["data"]?["eventType"]?.Value<string>()}";
if(!string.IsNullOrEmpty(eventType) && eventType == "Microsoft.EventGrid.SubscriptionValidationEvent")
{
// manual validation
string validationUrl = $"{eventGridEvent["data"]?["data"]?["validationUrl"]?.Value<string>()}";
using (var client = new HttpClient())
{
var response = await client.GetAsync(validationUrl);
log.LogInformation(response.ToString());
}
}
else
{
// notifications
}
await Task.CompletedTask;
}
请注意,每次发布时,原始事件消息(原始源兴趣)都会级联(嵌套)在事件数据对象中
关于azure - 处理来自不同 AD 租户中多个 Azure 订阅中存储帐户的 Blob 事件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55342241/
我有一个场景,我们必须通过 Azure AD 对企业用户进行身份验证,但通过 Azure AD B2C 对外部用户进行身份验证——所有这些都来自同一个登录屏幕。 有一些 Web 应用程序将共享此功能。
在使用 Azure AD B2C 和 Azure AD B2B 之前,我通常会将应用程序添加到我们租户的 Azure AD 中,并且 Office 365 用户可以使用其帐户 (SSO) 访问应用程序
当 Azure Active Directory 信任访问本地 Active Directory 用户时,我们是否可以使用本地 AD 用户名(域限定的 sam 帐户名称,例如:cosmos\brahm
什么是在网站上展示广告的好托管广告管理器? 我听说过OpenX ,但从未使用过。 最佳答案 我们使用名为 Ad Serving Solutions http://www.adservingsoluti
是否可以将用户从云 Azure Active Directory 同步到本地 AD? On Premises 这里有点错误,因为它实际上是 Azure 中的虚拟网络,带有 Windows Server
我正在关注这里的答案:Multi-Tenant Azure AD Auth in Azure AD B2C with Custom Policies 以及这里的演练:https://github.co
我正在尝试使用/common Azure AD 端点在 Azure AD B2C 中使用 Azure AD Auth。根据How to sign in any Azure Active Directo
来自 Mercurial 文档: The manifest is the file that describes the contents of the repository at a particu
我正在尝试将 firebase admob 与 React Native 集成到我的应用程序中,一切都适用于 testID横幅 ('ca-app-pub-3940256099942544/293473
我有一个应用程序需要根据其本地 AD 通用名称来过滤权限。几点注意事项: Azure AD Connect 正在 OnPrem AD 和 Azure 之间同步数据 我已成功将登录用户的组信息从 Azu
我正在使用 blogspot 平台并在我的网站上使用了 Google Adsense。我想对齐一个自动 Adsense 广告,它根本不居中,而带有代码的广告则完全没有问题。它只是自动广告,有人可以帮助
为什么redirect URL必须完全匹配?在域级别进行匹配是否不足以提供适当的安全性? 如果我有数百条路径怎么办? 示例网址: https://myawesomesite.com https://m
我即将创建一个新的 Azure AKS 群集,并且希望将 AKS 与 Azure Key Vault 集成。几个月前,在学习阶段,我看到需要使用Azure AD pod管理的身份来做到这一点,但现在我
我正在尝试配置我的 Azure AD 以同步我的本地 AD DS,如果在 Microsoft Azure AD 中添加任何用户,它应该自动在我的本地 AD 中注册。 我已创建 Azure AD 并配置
我有大约 50 个用户的 Azure AD。这些用户是我们购买Office365时创建的。假设 Azure AD 上的域是 example.com。 ([email protected])在本地,我们
我正在尝试获取组 Azure AD 的名称,Azure 登录 (openId) 后的内部 token 我收到 json 格式的组 ID,但我需要组名称。 登录后的Json: Claims 尝试使用Gr
我们希望将 Azure AD B2C 用于我们的 Web 应用程序,以允许用户使用其公司 ADFS 帐户登录。 根据Azure Active Directory B2C: Add ADFS as a
首先,我无法了解为什么需要这些数据,也无法了解有关网络的细节。您必须相信我,除了运行 LDAP 查询的 PowerShell 脚本之外,没有其他方法可以获取这些数据。 我正在使用具有多个林和多个域的网
我是一个相当新的 PS 用户...正在寻求有关 powershell 脚本的帮助来获取用户所属的安全组列表。 描述我需要什么: 我有包含许多用户(samaccountnames)的输入列表(txt 文
我有两个要存储在目录中以供我的应用程序使用的声明。这些内容不可供用户编辑,但可用于应用程序从 token 中读取。 内置策略可以检索声明,但是,使用自定义策略检索这些声明没有取得任何成功。 通读文章“
我是一名优秀的程序员,十分优秀!