Azure OpenAI schalen voor JavaScript met Azure API Management
Meer informatie over het toevoegen van taakverdeling op bedrijfsniveau aan uw toepassing om de chat-app uit te breiden buiten het Azure OpenAI-token en de quotumlimieten voor modellen. Deze benadering maakt gebruik van Azure API Management om op intelligente wijze verkeer te leiden tussen drie Azure OpenAI-resources.
Voor dit artikel moet u twee afzonderlijke voorbeelden implementeren:
Chat-app
- Als u de chat-app nog niet hebt geïmplementeerd, wacht u totdat het voorbeeld van de load balancer is geïmplementeerd.
- Als u de chat-app al eenmaal hebt geïmplementeerd, wijzigt u de omgevingsvariabele om een aangepast eindpunt voor de load balancer te ondersteunen en opnieuw te implementeren.
Load balancer met Azure API Management
Notitie
In dit artikel worden een of meer AI-app-sjablonen gebruikt als basis voor de voorbeelden en richtlijnen in het artikel. AI-app-sjablonen bieden u een goed onderhouden, eenvoudig te implementeren referentie-implementaties die u helpen een startpunt van hoge kwaliteit voor uw AI-apps te garanderen.
Architectuur voor taakverdeling van Azure OpenAI met Azure API Management
Omdat de Azure OpenAI-resource specifieke token- en modelquotumlimieten heeft, is een chat-app met één Azure OpenAI-resource gevoelig voor gespreksfouten vanwege deze limieten.
Als u de chat-app wilt gebruiken zonder deze limieten te bereiken, gebruikt u een oplossing met gelijke taakverdeling met Azure API Management. Deze oplossing maakt naadloos één eindpunt van Azure API Management beschikbaar voor uw chat-app-server.
De Azure API Management-resource bevindt zich als API-laag voor een set Azure OpenAI-resources. De API-laag is van toepassing op twee scenario's: normaal en beperkt. Tijdens een normaal scenario waarin token- en modelquota beschikbaar zijn, retourneert de Azure OpenAI-resource een 200 terug via de API-laag en de back-end-app-server.
Wanneer een resource wordt beperkt vanwege quotumlimieten, kan de API-laag een andere Azure OpenAI-resource onmiddellijk opnieuw proberen om te voldoen aan de oorspronkelijke aanvraag voor de chat-app.
Vereisten
Azure-abonnement. Maak er gratis een
Toegang verleend tot Azure OpenAI in het gewenste Azure abonnement.
Op dit moment wordt alleen toegang tot deze service verleend door een aanvraag te doen. U kunt toegang tot Azure OpenAI aanvragen door het formulier in te vullen op https://aka.ms/oai/access.
Dev-containers zijn beschikbaar voor beide voorbeelden, waarbij alle afhankelijkheden vereist zijn om dit artikel te voltooien. U kunt de dev-containers uitvoeren in GitHub Codespaces (in een browser) of lokaal met behulp van Visual Studio Code.
- Alleen een GitHub-account is vereist voor het gebruik van Codespaces
Voorbeeld-app voor lokale balancer van Azure API Management openen
GitHub Codespaces voert een ontwikkelcontainer uit die wordt beheerd door GitHub met Visual Studio Code voor het web als de gebruikersinterface. Voor de eenvoudigste ontwikkelomgeving gebruikt u GitHub Codespaces zodat u de juiste ontwikkelhulpprogramma's en afhankelijkheden vooraf hebt geïnstalleerd om dit artikel te voltooien.
Belangrijk
Alle GitHub-accounts kunnen Codespaces elke maand maximaal 60 uur gratis gebruiken met 2 kernexemplaren. Zie GitHub Codespaces maandelijks inbegrepen opslag- en kernuren voor meer informatie.
Azure API Management-load balancer implementeren
Als u de load balancer wilt implementeren in Azure, meldt u zich aan bij Azure Developer CLI (AZD).
azd auth login
Voltooi de aanmeldingsinstructies.
Implementeer de load balancer-app.
azd up
U moet een abonnement en regio voor de implementatie selecteren. Dit hoeft niet hetzelfde abonnement en dezelfde regio te zijn als de chat-app.
Wacht tot de implementatie is voltooid voordat u doorgaat. Dit kan tot 30 minuten duren.
Load balancer-eindpunt ophalen
Voer de volgende bash-opdracht uit om de omgevingsvariabelen van de implementatie te bekijken. U hebt deze informatie later nodig.
azd env get-values | grep APIM_GATEWAY_URL
Chat-app opnieuw implementeren met load balancer-eindpunt
Deze zijn voltooid in het voorbeeld van de chat-app.
Open de dev-container van de chat-app met behulp van een van de volgende opties.
Taal Codespaces Visual Studio Code .NET JavaScript Python Meld u aan bij Azure Developer CLI (AZD).
azd auth login
Voltooi de aanmeldingsinstructies.
Maak een AZD-omgeving met een naam, zoals
chat-app
.azd env new <name>
Voeg de volgende omgevingsvariabele toe, waarmee de back-end van de Chat-app een aangepaste URL voor de OpenAI-aanvragen moet gebruiken.
azd env set OPENAI_HOST azure_custom
Voeg de volgende omgevingsvariabele toe, waarmee de back-end van de Chat-app wordt aangegeven wat de waarde is van de aangepaste URL voor de OpenAI-aanvraag.
azd env set AZURE_OPENAI_CUSTOM_URL <APIM_GATEWAY_URL>
Implementeer de chat-app.
azd up
De tokens per minuutquotum (TPM) configureren
Standaard wordt elk van de OpenAI-exemplaren in de load balancer geïmplementeerd met 30.000 TPM-capaciteit (tokens per minuut). U kunt de chat-app gebruiken met het vertrouwen dat deze is gebouwd om te schalen voor veel gebruikers zonder dat er geen quotum meer is. Wijzig deze waarde wanneer:
- U krijgt fouten in de implementatiecapaciteit: verlaag deze waarde.
- Het plannen van een hogere capaciteit, verhoogt de waarde.
Gebruik de volgende opdracht om de waarde te wijzigen.
azd env set OPENAI_CAPACITY 50
Implementeer de load balancer opnieuw.
azd up
Resources opschonen
Wanneer u klaar bent met zowel de chat-app als de load balancer, moet u de resources opschonen. De Azure-resources die in dit artikel zijn gemaakt, worden gefactureerd voor uw Azure-abonnement. Als u deze resources in de toekomst niet meer nodig hebt, verwijdert u deze om te voorkomen dat er meer kosten in rekening worden gebracht.
Resources voor chat-apps opschonen
Ga terug naar het artikel van de chat-app om deze resources op te schonen.
Load balancer-resources opschonen
Voer de volgende Azure Developer CLI-opdracht uit om de Azure-resources te verwijderen en de broncode te verwijderen:
azd down --purge --force
De schakelopties bieden:
purge
: Verwijderde resources worden onmiddellijk verwijderd. Hiermee kunt u de TPM van Azure OpenAI opnieuw gebruiken.force
: het verwijderen gebeurt op de achtergrond, zonder dat hiervoor toestemming van de gebruiker is vereist.
GitHub Codespaces opschonen
Als u de GitHub Codespaces-omgeving verwijdert, zorgt u ervoor dat u de hoeveelheid gratis rechten per kernuren kunt maximaliseren die u voor uw account krijgt.
Belangrijk
Zie GitHub Codespaces maandelijks inbegrepen opslag- en kernuren voor meer informatie over de rechten van uw GitHub-account.
Meld u aan bij het GitHub Codespaces-dashboard (https://github.com/codespaces).
Zoek uw momenteel uitgevoerde Codespaces die afkomstig zijn uit de
azure-samples/openai-apim-lb
GitHub-opslagplaats.Open het contextmenu voor het codespaces-item en selecteer vervolgens Verwijderen.
Hulp vragen
Als u problemen ondervindt bij het implementeren van de Load Balancer van Azure API Management, meldt u het probleem aan bij de problemen van de opslagplaats.
Voorbeeldcode
Voorbeelden die in dit artikel worden gebruikt, zijn:
Volgende stap
- Diagnostische gegevens van Azure API Management weergeven in Azure Monitor
- Azure Load Testing gebruiken om uw chat-app te testen met