Anteckning
Åtkomst till den här sidan kräver auktorisering. Du kan prova att logga in eller ändra kataloger.
Åtkomst till den här sidan kräver auktorisering. Du kan prova att ändra kataloger.
Den här artikeln innehåller stegvisa instruktioner för ett enkelt scenario med att skicka meddelanden till en Service Bus-kö och ta emot dem. Du hittar fördefinierade JavaScript- och TypeScript-exempel för Azure Service Bus i Azure SDK för Python-lagringsplatsen på GitHub.
I den här snabbstarten kommer du att göra följande:
Skapa ett Service Bus-namnområde med Azure Portal.
Skapa en Service Bus-kö med Azure Portal.
Skriv Python-kod för att använda azure-servicebus-paketet för att:
- Skicka en uppsättning meddelanden till kön.
- Ta emot dessa meddelanden från kön.
Om du är nybörjare på tjänsten kan du läsa Översikt över Service Bus innan du börjar.
Förutsättningar
En Azure-prenumeration För att slutföra den här snabbstarten behöver du ett Azure-konto. Du kan aktivera dina månatliga Azure-krediter för Visual Studio-prenumeranter eller registrera dig för ett kostnadsfritt konto.
Python 3.8 eller senare.
Så här använder du den här snabbstarten med ditt eget Azure-konto:
- Installera Azure CLI, som tillhandahåller lösenordslös autentisering till utvecklardatorn.
- Logga in med ditt Azure-konto i terminalen eller kommandotolken med
az login. - Använd samma konto när du lägger till lämplig dataroll i resursen.
- Kör koden i samma terminal eller kommandotolk.
- Observera könamnet för Service Bus-namnområdet. Du behöver det i koden.
Den här snabbstarten fungerar med exempel som du kan kopiera och köra med Python. Anvisningar om hur du skapar ett Python-program finns i Snabbstart: Distribuera en Python-webbapp till Azure App Service. Mer information om hur du installerar paket som används i den här snabbstarten finns i Installera Azure-bibliotekspaket för Python.
Skapa ett namnområde i Azure Portal
Om du vill börja använda Service Bus-meddelandeentiteter i Azure skapar du ett namnområde med ett namn som är unikt i Hela Azure. Ett namnområde tillhandahåller en omfångscontainer för Service Bus-resurser, till exempel köer och ämnen, i ditt program.
Så här skapar du ett namnområde:
Logga in på Azure-portalen.
Välj den utfällbara menyn längst upp till vänster och gå till sidan Alla tjänster.
I det vänstra navigeringsfältet väljer du Integrering.
Rulla ned till Messaging Services>Service Bus och välj Skapa.
Följ dessa steg på fliken Grundläggande på sidan Skapa namnområde :
För Prenumeration väljer du en Azure-prenumeration där du ska skapa namnrymden.
För Resursgrupp väljer du en befintlig resursgrupp eller skapar en ny.
Ange ett namnområdesnamn som uppfyller följande namngivningskonventioner:
- Namnet måste vara unikt i Hela Azure. Systemet kontrollerar omedelbart om namnet är tillgängligt.
- Namnlängden är minst 6 och högst 50 tecken.
- Namnet får endast innehålla bokstäver, siffror, bindestreck
-. - Namnet måste börja med en bokstav och sluta med en bokstav eller siffra.
- Namnet slutar inte med
-sbeller-mgmt.
För Plats väljer du den region som ska vara värd för ditt namnområde.
För Prisnivå väljer du prisnivån (Basic, Standard eller Premium) för namnområdet. För den här snabbstarten väljer du Standard.
Om du väljer Premium-nivå kan du aktivera geo-replikering för namnområdet. Geo-replikeringsfunktionen säkerställer att metadata och data i ett namnområde kontinuerligt replikeras från en primär region till en eller flera sekundära regioner.
Viktigt!
Om du vill använda ämnen och prenumerationer väljer du antingen Standard eller Premium. Ämnen och prenumerationer stöds inte på prisnivån Basic.
Om du har valt prisnivån Premium anger du antalet meddelandeenheter. Premium-nivån ger resursisolering på processor- och minnesnivå så att varje arbetsbelastning körs självständigt. Den här resurscontainern kallas för en meddelandefunktionsenhet. Ett premiumnamnområde har minst en meddelandeenhet. Du kan välja 1, 2, 4, 8 eller 16 meddelandeenheter för varje Service Bus Premium-namnområde. Mer information finns i Service Bus Premium-meddelandenivån.
Välj Granska + skapa längst ned på sidan.
På sidan Granska + skapa granskar du inställningarna och väljer Skapa.
När distributionen av resursen har slutförts väljer du Gå till resurs på distributionssidan.
Startsidan för din Service Bus-namnrymd visas.
Skapa en kö i Azure-portalen
På sidan Service Bus-namnområde expanderar du Entiteter på navigeringsmenyn till vänster och väljer Köer.
På sidan Köer, i verktygsfältet väljer du + Kö.
Ange ett namn för kön. Lämna de andra värdena med sina standardvärden.
Välj Skapa.
Autentisera appen till Azure
Den här artikeln visar två sätt att ansluta till Azure Service Bus: lösenordslös och anslutningssträng.
Det första alternativet visar hur du använder ditt säkerhetsobjekt i Microsoft Entra-ID och rollbaserad åtkomstkontroll (RBAC) för att ansluta till ett Service Bus-namnområde. Du behöver inte bekymra dig om att ha en hårdkodad anslutningssträng i koden, i en konfigurationsfil eller i en säker lagring som Azure Key Vault.
Det andra alternativet visar hur du använder en anslutningssträng för att ansluta till ett Service Bus-namnområde. Om du inte har använt Azure tidigare kan det vara enklare att följa anslutningssträng alternativet. Vi rekommenderar att du använder det lösenordslösa alternativet i verkliga program och produktionsmiljöer. Mer information finns i Service Bus-autentisering och auktorisering. Mer information om lösenordslös autentisering finns i Autentisera .NET-appar.
Tilldela roller till din Microsoft Entra-användare
När du utvecklar lokalt kontrollerar du att användarkontot som ansluter till Azure Service Bus har rätt behörigheter. Du behöver rollen Azure Service Bus-dataägare för att kunna skicka och ta emot meddelanden. Om du vill tilldela dig själv den här rollen behöver du rollen Administratör för användaråtkomst eller en annan roll som innehåller åtgärden Microsoft.Authorization/roleAssignments/write .
Du kan tilldela Azure RBAC-roller till en användare med hjälp av Azure Portal, Azure CLI eller Azure PowerShell. Mer information om tillgängliga omfång för rolltilldelningar finns i Förstå omfånget för Azure RBAC.
I följande exempel tilldelas Azure Service Bus Data Owner rollen till ditt användarkonto, vilket ger fullständig åtkomst till Azure Service Bus-resurser. I ett verkligt scenario följer du principen om minsta behörighet för att ge användarna endast de minsta behörigheter som krävs för en säkrare produktionsmiljö.
Inbyggda Azure-roller för Azure Service Bus
För Azure Service Bus skyddas redan hanteringen av namnområden och alla relaterade resurser via Azure Portal och Azure-resurshanterings-API:et med hjälp av Azure RBAC-modellen. Azure tillhandahåller följande inbyggda Azure-roller för att auktorisera åtkomst till ett Service Bus-namnområde:
- Azure Service Bus-dataägare: Ger dataåtkomst till Service Bus-namnområdet och dess entiteter, inklusive köer, ämnen, prenumerationer och filter. En medlem i den här rollen kan skicka och ta emot meddelanden från köer eller ämnen/prenumerationer.
-
Azure Service Bus-datasändare: Använd den här rollen för att ge
sendåtkomst till Service Bus-namnområdet och dess entiteter. -
Azure Service Bus-datamottagare: Använd den
receivehär rollen för att ge åtkomst till Service Bus-namnområdet och dess entiteter.
Om du vill skapa en anpassad roll läser du Rättigheter som krävs för Service Bus-åtgärder.
Lägga till Microsoft Entra-användare i rollen Som Azure Service Bus-ägare
Lägg till ditt Microsoft Entra-användarnamn i rollen Azure Service Bus-dataägare på Service Bus-namnområdesnivå. Med den här konfigurationen kan en app som körs i kontexten för ditt användarkonto skicka meddelanden till en kö eller ett ämne. Den kan ta emot meddelanden från en kö eller ett ämnesprenumeration.
Viktigt!
I de flesta fall tar det en minut eller två för rolltilldelningen att spridas i Azure. I sällsynta fall kan det ta upp till åtta minuter. Om du får autentiseringsfel när du först kör koden väntar du en stund och försöker igen.
Om du inte har sidan Service Bus-namnområde öppen i Azure Portal letar du upp Service Bus-namnområdet med hjälp av huvudsökfältet eller det vänstra navigeringsfältet.
På sidan Översikt väljer du Åtkomstkontroll (IAM) på den vänstra menyn.
På sidan Åtkomstkontroll (IAM) väljer du fliken Rolltilldelningar .
Välj + Lägg till på den översta menyn och sedan Lägg till rolltilldelning.
Använd sökrutan för att filtrera resultatet till önskad roll. I det här exemplet söker
Azure Service Bus Data Ownerdu efter och väljer matchande resultat. Välj sedan Nästa.Under Tilldela åtkomst till väljer du Användare, grupp eller tjänstens huvudnamn och sedan + Välj medlemmar.
I dialogrutan söker du efter ditt Microsoft Entra-användarnamn (vanligtvis din user@domain e-postadress) och väljer sedan Välj längst ned i dialogrutan.
Välj Granska + tilldela för att gå till den sista sidan och sedan Granska + tilldela igen för att slutföra processen.
Använda pip för att installera paket
Om du vill installera nödvändiga Python-paket för den här Service Bus-snabbstarten öppnar du ett kommandotolkfönster som har Python i sin sökväg.
Ändra katalogen till den mapp där du vill ha dina exempel.
Installera följande paket:
pip install azure-servicebus pip install azure-identity pip install aiohttp
Skicka meddelanden till en kö
Följande exempelkod visar hur du skickar ett meddelande till en kö. Öppna en textredigerare, till exempel Visual Studio Code, skapa en fil send.py och lägg till följande kod i den.
Lägg till importinstruktioner.
import asyncio from azure.servicebus.aio import ServiceBusClient from azure.servicebus import ServiceBusMessage from azure.identity.aio import DefaultAzureCredentialLägg till konstanter och definiera en autentiseringsuppgift.
FULLY_QUALIFIED_NAMESPACE = "FULLY_QUALIFIED_NAMESPACE" QUEUE_NAME = "QUEUE_NAME" credential = DefaultAzureCredential()Viktigt!
- Ersätt
FULLY_QUALIFIED_NAMESPACEmed det fullständigt kvalificerade namnområdet för Service Bus-namnområdet. - Ersätt
QUEUE_NAMEmed namnet på kön.
- Ersätt
Lägg till en metod för att skicka ett enda meddelande.
async def send_single_message(sender): # Create a Service Bus message and send it to the queue message = ServiceBusMessage("Single Message") await sender.send_messages(message) print("Sent a single message")Avsändaren är ett objekt som fungerar som en klient för kön som du skapade. Du skapar den senare och skickar den som ett argument till den här funktionen.
Lägg till en metod för att skicka en lista med meddelanden.
async def send_a_list_of_messages(sender): # Create a list of messages and send it to the queue messages = [ServiceBusMessage("Message in list") for _ in range(5)] await sender.send_messages(messages) print("Sent a list of 5 messages")Lägg till en metod för att skicka en batch med meddelanden.
async def send_batch_message(sender): # Create a batch of messages async with sender: batch_message = await sender.create_message_batch() for _ in range(10): try: # Add a message to the batch batch_message.add_message(ServiceBusMessage("Message inside a ServiceBusMessageBatch")) except ValueError: # ServiceBusMessageBatch object reaches max_size. # New ServiceBusMessageBatch object can be created here to send more data. break # Send the batch of messages to the queue await sender.send_messages(batch_message) print("Sent a batch of 10 messages")Skapa en Service Bus-klient och sedan ett kösändarobjekt för att skicka meddelanden.
async def run(): # create a Service Bus client using the credential async with ServiceBusClient( fully_qualified_namespace=FULLY_QUALIFIED_NAMESPACE, credential=credential, logging_enable=True) as servicebus_client: # get a Queue Sender object to send messages to the queue sender = servicebus_client.get_queue_sender(queue_name=QUEUE_NAME) async with sender: # send one message await send_single_message(sender) # send a list of messages await send_a_list_of_messages(sender) # send a batch of messages await send_batch_message(sender) # Close credential when no longer needed. await credential.close()runAnropa metoden och skriv ut ett meddelande.asyncio.run(run()) print("Done sending messages") print("-----------------------")
Ta emot meddelanden från en kö
Följande exempelkod visar hur du tar emot meddelanden från en kö. Koden som visas tar emot nya meddelanden tills den inte tar emot några nya meddelanden på 5 (max_wait_time) sekunder.
Öppna en textredigerare, till exempel Visual Studio Code, skapa en fil recv.py och lägg till följande kod i den.
På samma sätt som i send.py exempel lägger du till
importinstruktioner. Ersätt konstanterna med dina egna värden och definiera en autentiseringsuppgift.import asyncio from azure.servicebus.aio import ServiceBusClient from azure.identity.aio import DefaultAzureCredential FULLY_QUALIFIED_NAMESPACE = "FULLY_QUALIFIED_NAMESPACE" QUEUE_NAME = "QUEUE_NAME" credential = DefaultAzureCredential()Skapa en Service Bus-klient och sedan ett kömottagareobjekt för att ta emot meddelanden.
async def run(): # create a Service Bus client using the connection string async with ServiceBusClient( fully_qualified_namespace=FULLY_QUALIFIED_NAMESPACE, credential=credential, logging_enable=True) as servicebus_client: async with servicebus_client: # get the Queue Receiver object for the queue receiver = servicebus_client.get_queue_receiver(queue_name=QUEUE_NAME) async with receiver: received_msgs = await receiver.receive_messages(max_wait_time=5, max_message_count=20) for msg in received_msgs: print("Received: " + str(msg)) # complete the message so that the message is removed from the queue await receiver.complete_message(msg) # Close credential when no longer needed. await credential.close()runAnropa metoden.asyncio.run(run())
Kör appen
Öppna en kommandotolk som har Python i sökvägen och kör sedan koden för att skicka och ta emot meddelanden från kön.
python send.py; python recv.py
Du bör se följande utdata:
Sent a single message
Sent a list of 5 messages
Sent a batch of 10 messages
Done sending messages
-----------------------
Received: Single Message
Received: Message in list
Received: Message in list
Received: Message in list
Received: Message in list
Received: Message in list
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
Received: Message inside a ServiceBusMessageBatch
I Azure Portal navigerar du till service bus-namnområdet. På sidan Översikt kontrollerar du att antalet inkommande och utgående meddelanden är 16. Om du inte ser antalet väntar du några minuter och uppdaterar sedan sidan.
Välj kön på den här översiktssidan för att gå till sidan Service Bus-kö . Du kan också se antalet inkommande och utgående meddelanden på den här sidan. Du ser även annan information, till exempel köns aktuella storlek och antalet aktiva meddelanden.
Relaterat innehåll
Se följande dokumentation och exempel:
-
- Mappen sync_samples innehåller exempel som visar hur du interagerar med Service Bus på ett synkront sätt.
- Mappen async_samples innehåller exempel som visar hur du interagerar med Service Bus på ett asynkront sätt. I den här snabbstarten använde du den här metoden.