Skip to content

Latest commit

 

History

History
153 lines (128 loc) · 11.1 KB

GettingStarted.md

File metadata and controls

153 lines (128 loc) · 11.1 KB

Getting Started

NOTE In order to deploy and run this example, you'll need an Azure subscription with access enabled for the Azure OpenAI service. You can request access here.

Before to jumping to the Azure OpenAI API, this guide will show how to have access to Azure OpenAI services in your Azure Subscription as well the step by step on how to setup this service. here

Prerequisites

To Run Locally

Pre-build docker Image - API

Configure your .env as described in as described in Configuration. You can alternatively, copy .dockerenv.example to .env from api\Python folder

Then run:

docker run --env-file .env -p 7071:80 --name chataskapi -it akshata13/chataskapi:latest

Verify http://localhost:7071 to confirm the API is running locally.

Pre-build docker Image - Application

Configure your .env as described in as described in Configuration. You can alternatively, copy .dockerenv.example to .env from app\backend folder

Then run:

docker run --env-file .env --name chataskapp -it akshata13/chataskapp:latest

Verify http://localhost:5000 to confirm the App is running locally.

Installation

  1. Semi-Automated Installation
    1. Click Deployment to Azure to deploy following services
      1. Azure App Service Plan (Linux - B1 Tier)
      2. Cognitive Search Service (Standard Tier)
      3. Azure App Service (To Deploy backend service)
      4. Azure Function app (For all Python API)
      5. Storage Account (to store all your files) & Function storage account
      6. Azure Open AI Service
      7. Azure Application Insight
      8. Cognitive Services (Language and Speech Service)
      9. SQL Server and Database (Note - SQL Script - northwind.sql need to run manually once database is created)
      10. Note - Pinecone and Redis needs to be installed manually if you want vector database support.
      11. AWS Integration - None of the artifacts are deployed for AWS Integration. Scripts are available in Deployment\aws folder
    2. Fork the repo
      1. Note - Following information need to be performed only once
      2. Click on Actions and select "I understand my workflow, go ahead and enable them"
      3. Download the Publish Profile for the Azure Function App that is deployed
      4. Setup AZURE_FUNCTIONAPP_PUBLISH_PROFILE secret in your forked repository (Settings -> Secrets and Variables -> Actions -> New Repository Secret). Copy/Paste the content of the Publish profile
      5. Download the Publish Profile for your Azure Web App. You can download this file from the Overview page of your Web App in the Azure Portal.
      6. Create a secret in your repository named AZURE_WEBAPP_PUBLISH_PROFILE, paste the publish profile contents as the value of the secret. More Information
      7. Setup AZURE_FUNCTIONAPP_NAME secret in your forked repository as the name of your Function App
      8. Setup AZURE_WEBAPP_NAME secret in your forked repository as the name of your Azure App Service
      9. Setup DOCKER_HUB_USERNAME and DOCKER_HUB_ACCESS_TOKEN secret in your forked repository as the name of you docker user name and access token (Optional)
      10. Note You can disable the Docker Api and Docker App Actions if it's not required.
      11. Verify the Configuration settings are properly configured in Azure Function App and Azure App Service. THe default Upload and Admin password are P@ssw0rd. Make sure the right keys are configured for the set of the functionality.
    3. Successful execution of both workflow will deploy the Python API and Azure App Services (UI application)
    4. NOTE In case if you have FTP disabled due to policy on your subscription, you need to manually add following configuration and changes to YAML github action as deploy with Publish Profile will not work.
      1. Download Azure CLI from here, run az login to login with your Azure credentials.
      2. Select your subscription using az account set --subscription <subscription_name>
      3. Create Azure app registration and grant contributor access to Function app using az ad sp create-for-rbac --name "chatpdf" --role contributor --scopes /subscriptions/{subscription-id}/resourceGroups/{resource-group}/providers/Microsoft.Web/sites/{function-app-name} --sdk-auth
        1. Replace {subscription-id}, {resource-group}, {app-name} and {function-app-name} with the names of your subscription, resource group, Web app and Azure function app.
      4. Update Azure app registration and grant contributor access to Web app using az ad sp create-for-rbac --name "chatpdf" --role contributor --scopes /subscriptions/{subscription-id}/resourceGroups/{resource-group}/providers/Microsoft.Web/sites/{app-name} --sdk-auth
      5. The command should output a JSON object similar to this:
      6. { "clientId": "{GUID}", "clientSecret": "{GUID}", "subscriptionId": "{GUID}", "tenantId": "{GUID}", "activeDirectoryEndpointUrl": "https://login.microsoftonline.com", "resourceManagerEndpointUrl": "https://management.azure.com/", "activeDirectoryGraphResourceId": "https://graph.windows.net/", "sqlManagementEndpointUrl": "https://management.core.windows.net:8443/", "galleryEndpointUrl": "https://gallery.azure.com/", "managementEndpointUrl": "https://management.core.windows.net/" }
      7. Copy and paste the json response from above Azure CLI to your GitHub Repository > Settings > Secrets > Add a new secret > AZURE_RBAC_CREDENTIALS
      8. Replace pythonapi.yml file (stored in chatpdf/.github/workflows directory) with the content from here
      9. Trigger the workflow manually and verify the deployment is successful.
      10. Replace backendapp.yml file (stored in chatpdf/.github/workflows directory) with the content from here
      11. Trigger the workflow manually and verify the deployment is successful.

Note - To debug and troubleshoot issues after the deployment, you can view the log in Live Metrics in application insights or enable running the Logs for the specific Azure Function.

  1. Alternatively deploy the following services manually
    1. OpenAI service. Please be aware of the model & region availability documented [here]. Once the service is created, deploy the model for gpt35-turbo(chat), text-davinci-003 (davinci) and text-ada-embedding-002. (https://learn.microsoft.com/en-us/azure/cognitive-services/openai/concepts/models#model-summary-table-and-region-availability)
    2. Storage Account and a container (chatpdf)
    3. One of the Document Store
      1. Pinecone Starter. Note Make sure you create the index in Pincone with dimensions as 1536 and metric as cosine
      2. Cognitive Search
      3. Redis
    4. Create Function App
    5. Create SQL Server and SQL Database and run northwind.sql script
    6. Create Speech Cognitive Service
    7. Create Language/Text Analytics Cognitive Service
    8. Create Application Insight service
    9. Create Azure Web App and App Service Plan
    10. Git clone the repo
    11. Open the cloned repo folder in VSCode
    12. Open new terminal and go to /app/frontend directory
    13. Run npm install to install all the packages
    14. Go to /api/Python directory
    15. Run pip install -r requirements.txt to install all required python packages
    16. Copy sample.settings.json to local.settings.json
    17. Update the configuration (Minimally you need OpenAi, one of the document store, storage account)
    18. Deploy the Azure Python API to Function app
    19. Open new terminal and go to /app/frontend directory
    20. Run npm run build for production build and copying static files to app/backend/static directory
    21. Open new terminal and go to /app/backend directory
    22. Copy env.example to .env file and edit the file to enter the Python localhost API and the storage configuration
    23. Deploy the app/backend Azure web app.
    24. Verify the Configuration settings are properly configured in Azure Function App and Azure App Service

Run Locally

  1. Git clone the repo
  2. Open the cloned repo folder in VSCode
  3. Open new terminal and go to /app/frontend directory
  4. Run npm install to install all the packages
  5. Go to /api/Python directory
  6. Run pip install -r requirements.txt to install all required python packages
  7. Copy sample.settings.json to local.settings.json
  8. Update the configuration (Minimally you need OpenAi, one of the document store, storage account)
  9. Start the Python API by running func host start
  10. Open new terminal and go to /app/backend directory
  11. Copy env.example to .env file and edit the file to enter the Python localhost API and the storage configuration
  12. Run py app.py to start the backend locally (on port 5000)
  13. Open new terminal and go to /app/frontend directory
  14. Run npm run dev to start the local server (on port 5173) !5. Browse the localhost:5173 to open the web app.

Once in the web app:

  • Try different topics in chat or Q&A context. For chat, try follow up questions, clarifications, ask to simplify or elaborate on answer, etc.
  • Explore citations and sources
  • Click on "settings" to try different options, tweak prompts, etc.