Observação
O acesso a essa página exige autorização. Você pode tentar entrar ou alterar diretórios.
O acesso a essa página exige autorização. Você pode tentar alterar os diretórios.
Este artigo apresenta os principais conceitos e funcionalidades associados aos tópicos do namespace.
Eventos
Um evento é a menor quantidade de informações que descreve por completo algo que aconteceu em um sistema. Muitas vezes, nós nos referimos a um evento, como um evento discreto, porque ele representa um fato distinto e independente sobre um sistema que fornece um insight que pode ser acionável. Todos os eventos apresentam informações comuns como a source do evento, a time em que o evento ocorreu e um identificador exclusivo. Cada evento também tem um type, que geralmente é um identificador exclusivo que descreve o tipo de anúncio para o qual o evento é usado.
Por exemplo, um evento sobre um novo arquivo que está sendo criado no Armazenamento do Azure traz detalhes sobre o arquivo, como o valor lastTimeModified. Um evento de Hubs de Eventos tem a URL do arquivo capturado. Um evento sobre um novo pedido no seu microsserviço de Pedidos pode ter um atributo orderId e um atributo URL com a representação do estado do pedido. Mais alguns exemplos de tipos de evento incluem: com.yourcompany.Orders.OrderCreated, org.yourorg.GeneralLedger.AccountChanged, io.solutionname.Auth.MaximumNumberOfUserLoginAttemptsReached.
Veja um exemplo de evento:
{
"specversion" : "1.0",
"type" : "com.yourcompany.order.created",
"source" : "/orders/account/123",
"subject" : "O-28964",
"id" : "A234-1234-1234",
"time" : "2018-04-05T17:31:00Z",
"comexampleextension1" : "value",
"comexampleothervalue" : 5,
"datacontenttype" : "application/json",
"data" : {
"orderId" : "O-28964",
"URL" : "https://com.yourcompany/orders/O-28964"
}
}
Outro tipo de evento
A comunidade de usuários também se refere a “eventos” como mensagens que carregam um ponto de dados, como uma leitura de dispositivo individual ou um clique em uma página de aplicativo Web. Esse tipo de evento costuma ser analisado em uma janela de tempo para obtenção de insights e execução de uma ação. Na documentação da Grade de Eventos, nós nos referimos a esse tipo de evento como ponto de dados, dados de streaming ou apenas telemetria. Entre outros tipos de mensagens, este tipo de eventos é usado com o recurso de agente de Message Queue Telemetry Transport (MQTT) da Grade de Eventos.
Suporte ao CloudEvents
Os tópicos do namespace da Grade de Eventos aceitam eventos que estão em conformidade com a especificação CloudEvents 1.0 padrão aberto do CNCF (Cloud Native Computing Foundation) usando a associação de protocolo HTTP com o formato JSON. Um CloudEvent é um tipo de mensagem que contém o que está sendo comunicado, conhecido como dados de evento e metadados sobre ele. Os dados de evento em arquiteturas controladas por eventos normalmente carregam as informações anunciando uma alteração de estado do sistema. Os metadados do CloudEvents são compostos por um conjunto de atributos que fornecem informações contextuais sobre a mensagem como de onde ela se originou (o sistema de origem), seu tipo etc.
Para obter mais informações, confira Suporte ao esquema do CloudEvents.
Publicadores
Um publicador é a aplicação que envia eventos para o Event Grid. Pode ser o mesmo aplicativo em que os eventos se originaram, a origem do evento. Você poderá publicar eventos por meio do seu aplicativo ao usar tópicos de namespace.
Origens de eventos
A origem de um evento é onde o evento acontece. Cada origem do evento dá suporte a um ou mais tipos de evento. Por exemplo, seu aplicativo é a origem do evento para eventos personalizados definidos pelo sistema. Ao usar tópicos de namespace, as fontes de evento compatíveis são seus próprios aplicativos.
Namespaces
Um namespace da Grade de Eventos é um contêiner de gerenciamento para os seguintes recursos:
| Recurso | Protocolo com suporte |
|---|---|
| Tópicos de namespace | HTTP |
| Espaços de tópicos | MQTT |
| Clientes | MQTT |
| Grupos de Clientes | MQTT |
| Certificados da Autoridade Certificadora | MQTT |
| Vinculações de permissão | MQTT |
Com um namespace da Grade de Eventos do Azure, você pode agrupar recursos relacionados e gerenciá-los como uma só unidade na sua assinatura do Azure. Ele fornece a você um FQDN (nome de domínio totalmente qualificado) único.
Um namespace expõe dois endpoints:
- Um endpoint HTTP para atender aos requisitos gerais de mensagens usando tópicos em namespace.
- Um ponto de extremidade MQTT para mensagens IoT ou soluções que usam o MQTT.
Um namespace também fornece pontos de extremidade de rede integrados ao DNS. Também fornece uma variedade de recursos de controle de acesso e gerenciamento de integração de rede, como filtragem de entrada de IP público e links privados. Também é o contêiner de identidades gerenciadas usado para os recursos contidos no namespace.
Veja a seguir mais algumas observações sobre namespaces:
- O namespace é um recurso acompanhado com as propriedades
tagselocatione, uma vez criado, ele pode ser encontrado emresources.azure.com. - O nome do namespace pode ter entre 3 e 50 caracteres. Ele pode incluir caracteres alfanuméricos e hífen (-) e não pode conter espaços.
- O nome precisa ser exclusivo por região.
Unidades de transferência
As TUs (unidades de produtividade) definem a capacidade de taxa de evento de entrada e saída em namespaces. Para obter mais informações, consulte Cotas e limites da Grade de Eventos do Azure.
Tópicos
Um tópico contém eventos que foram publicados na Grade de Eventos. Normalmente, você usa um recurso de tópico para uma coleção de eventos relacionados. Muitas vezes nos referimos a tópicos dentro de um namespace como tópicos de namespace.
Tópicos de namespace
Os tópicos de namespace são tópicos criados em um namespace da Grade de Eventos. Seu aplicativo publica eventos em um ponto de extremidade HTTP do namespace, especificando um tópico do namespace no qual os eventos publicados são logicamente agrupados. Quando você projeta seu aplicativo, tem precisa decidir quantos tópicos devem ser criados. Para soluções relativamente grandes, crie um tópico de namespace para cada categoria de eventos relacionados. Por exemplo, considere um aplicativo que gerencia contas de usuário e outro aplicativo sobre pedidos de clientes. É improvável que todos os assinantes de eventos queiram receber eventos dos dois aplicativos. Para separar as preocupações, crie dois tópicos de namespace: um para cada aplicativo. Permita que os consumidores de eventos assinem o tópico de acordo com seus requisitos. Para soluções pequenas, você pode preferir enviar todos os eventos para um único tópico.
Os tópicos de namespace dão suporte à entrega de pull e entrega de push. Confira quando usar a entrega push ou pull para ajudar a decidir se a entrega pull é a abordagem certa, considerando seus requisitos.
Inscrições em eventos
Uma assinatura de evento é um recurso de configuração associado a um só tópico. Entre outras coisas, você usa uma assinatura de evento para definir critérios de seleção de eventos a fim de definir a coleção de eventos disponível para um assinante do conjunto total de eventos disponíveis em um tópico. Você pode filtrar eventos de acordo com os requisitos do assinante. Por exemplo, você pode filtrar eventos por seu tipo de evento. Você também pode definir critérios de filtro em propriedades de dados de evento se estiver usando um objeto JSON como o valor da propriedade de dados. Para obter mais informações sobre as propriedades do recurso, procure por operações de plano de controle na API REST do Event Grid.
Para obter um exemplo de criação de assinaturas para tópicos de namespace, consulte Publicar e consumir mensagens usando tópicos de namespace usando a CLI.
Observação
As assinaturas de eventos em um tópico de namespace apresentam um modelo de recurso simplificado em comparação com o usado em tópicos personalizados, de domínio, de parceiro e do sistema (Event Grid Basic). Para obter mais informações, confira Criar, exibir e gerenciar assinaturas de eventos.
Entrega pull
Com a entrega de pull, seu aplicativo se conecta à Grade de Eventos para ler mensagens usando semântica semelhante à fila. À medida que os aplicativos se conectam ao Event Grid para consumir eventos, eles controlam a taxa de consumo dos eventos e o momento em que esse consumo ocorre. As aplicações cliente também podem usar pontos de extremidade privados ao se conectar ao Event Grid para ler eventos usando um espaço de IP privado.
A entrega de pull dá suporte às seguintes operações para ler mensagens e controlar o estado da mensagem: receber, confirmar, liberar, rejeitar e renovar bloqueio. Para obter mais informações, consulte Visão geral de entrega de pull.
Formato dos dados ao receber eventos com entrega por pull
Ao entregar eventos usando a entrega por extração, o Event Grid inclui uma matriz de objetos que, por sua vez, inclui os objetos event e brokerProperties. O valor da propriedade event é o CloudEvent entregue no modo de conteúdo estruturado. O objeto brokerProperties contém o token de bloqueio associado ao CloudEvent entregue. O seguinte objeto JSON é uma resposta de exemplo de uma operação receive que retorna dois eventos:
{
"value": [
{
"brokerProperties": {
"lockToken": "CiYKJDUwNjE4QTFFLUNDODQtNDZBQy1BN0Y4LUE5QkE3NjEwNzQxMxISChDXYS23Z+5Hq754VqQjxywE",
"deliveryCount": 2
},
"event": {
"specversion": "1.0",
"id": "A234-1234-1235",
"source": "/mycontext",
"time": "2018-04-05T17:31:00Z",
"type": "com.example.someeventtype",
"data": "some data"
}
},
{
"brokerProperties": {
"lockToken": "CiYKJDUwNjE4QTFFLUNDODQtNDZBQy1BN0Y4LUE5QkE3NjEwNzQxMxISChDLeaL+nRJLNq3/5NXd/T0b",
"deliveryCount": 1
},
"event": {
"specversion": "1.0",
"id": "B688-1234-1235",
"source": "/mycontext",
"type": "com.example.someeventtype",
"time": "2018-04-05T17:31:00Z",
"data": {
"somekey" : "value",
"someOtherKey" : 9
}
}
}
]
}
Entrega por push
Com a entrega de push, a Grade de Eventos envia eventos para um destino configurado em uma assinatura de evento push (modo de entrega). Ele fornece uma lógica de repetição robusta caso o destino não seja capaz de receber eventos.
Importante
Atualmente, a entrega por push dos namespaces do Azure Event Grid dá suporte a Hubs de Eventos do Azure como destino. No futuro, os namespaces da Grade de Eventos darão suporte a mais destinos, incluindo todos os destinos compatíveis com o Event Grid Basic.
Entrega de eventos do Event Hubs
O Event Grid usa o SDK do Event Hubs para enviar eventos ao Event Hubs usando AMQP. Os eventos são enviados como uma matriz de bytes com cada elemento na matriz que contém um CloudEvent.
Entrega push e pull
Usando o HTTP, a Grade de Eventos dá suporte às entregas push e pull de eventos. Com a entrega de push, você define um destino em uma assinatura de evento, um webhook ou um serviço do Azure para o qual a Grade de Eventos enviará os eventos. Com a entrega pull, os aplicativos assinantes se conectam à Grade de Eventos para consumir os eventos. A entrega de pull tem suporte para tópicos em um namespace da Grade de Eventos.
Importante
Event Hubs é compatível como destino para assinaturas de tópicos do namespace. Nas próximas versões, os Namespaces da Grade de Eventos darão suporte a todos os destinos atualmente disponíveis no Event Grid Básico, juntamente com destinos adicionais.
Quando usar entrega por push versus entrega por pull
As diretrizes gerais a seguir vão para ajudar você a decidir quando usar a entrega push ou pull.
Entrega pull
- Você precisa obter controle completo sobre quando os eventos serão recebidos. Por exemplo, seu aplicativo talvez não fique online o tempo todo, não seja estável o suficiente ou você processa os dados em determinados horários.
- Você precisa obter controle completo sobre o consumo de eventos. Por exemplo, um serviço downstream ou uma camada no seu aplicativo consumidor tem um problema que impede que você processe os eventos. Nesse caso, a API de entrega pull permite que o aplicativo consumidor libere um evento já lido novamente para o agente, de modo que ele possa ser entregue posteriormente.
- Você deseja usar links privados ao receber eventos, o que é possível apenas com a entrega de pull, não com a entrega de push.
- Você não consegue expor um endpoint e usar a entrega por push, mas pode se conectar ao Event Grid para consumir eventos.
Entrega por push
- Você deseja evitar a sondagem constante para determinar se ocorreu uma alteração de estado do sistema. Você prefere usar a Grade de Eventos para enviar eventos para você no momento em que as alterações de estado ocorrem.
- Você tem um aplicativo que não pode fazer chamadas de saída. Por exemplo, sua organização talvez esteja preocupada com a exfiltração dos dados. No entanto, seu aplicativo pode receber eventos por meio de um endpoint público.
Conteúdo relacionado
- Para ver uma introdução à Grade de Eventos, confira About Event Grid (Sobre a Grade de Eventos).
- Para começar a usar os tópicos de namespace, confira Publicar eventos usando tópicos de namespace.