From 9cf8085895848411b3fbe5af9b2f562379529df9 Mon Sep 17 00:00:00 2001 From: Jeff Handley Date: Thu, 22 Feb 2024 16:47:56 -0800 Subject: [PATCH] Refresh documentation and add a disaster recovery doc --- Documentation/Disaster-Recovery.md | 54 ++++++++++++++++++++++++++++++ Documentation/Implementation.md | 14 ++++---- Documentation/README.md | 21 +++++++----- 3 files changed, 73 insertions(+), 16 deletions(-) create mode 100644 Documentation/Disaster-Recovery.md diff --git a/Documentation/Disaster-Recovery.md b/Documentation/Disaster-Recovery.md new file mode 100644 index 0000000..f31ea12 --- /dev/null +++ b/Documentation/Disaster-Recovery.md @@ -0,0 +1,54 @@ +# Issue Labeler Disaster Recovery Instructions + +In events where all service instances need to be re-deployed, the following steps will guide you through the process. + +1. Open and build the `issue-labeler.sln` solution to ensure a baseline build + - There will be build messages and warnings, but there should be no errors +2. Make the changes necessary + - If any package versions need to be bumped, the `eng\Versions.props` file controls all package versions +3. Rebuild the solution +4. Publish the `IssueLabelerService` project to the `dispatcher-app` service instance + - Right click on the `IssueLabelerService` project and choose **Publish...** + - If you don't yet have a publish profile saved, you will be guided through creating one + - Target: **Azure** + - Specific Target: **Azure App Service (Windows)** + - Subscription Name: **DDFun IaaS Dev Shared Public** + - Choose the `dispatcher-app` App Service instance from the `GitHubIssueLabeller` folder + ![Choose the App Service](img/publish1.png) + - **Check the 'Deploy as ZIP package' box** + - Deployment type: **Publish (generates pubxml file)** + - Click Finish and close the window when it's complete + - In the Settings screen click one of the pencil icons to edit the Settings and make sure the following are set: + ![Publish Configuration](img/publish2.png) + - **Configuration**: Release + - **Target framework**: net7.0 + - **Deployment mode**: Self-contained + - **Target Runtime**: win-x64 + - Click **Save** + - Click **Publish** (this will build the app and upload to Azure, and can take a few minutes) +5. Publish the `PredictionService` project to all of the other service instances + - Right click on the `PredictionService` project and choose **Publish...** + - If you don't yet have a publish profile saved, you will be guided through creating one + - Target: **Azure** + - Specific Target: **Azure App Service (Windows)** + - Subscription Name: **DDFun IaaS Dev Shared Public** + - Choose the App Service instance from the `GitHubIssueLabeller` folder, e.g. `nuget-home-labeler` + ![Choose the App Service](img/publish1.png) + - **Check the 'Deploy as ZIP package' box** + - Deployment type: **Publish (generates pubxml file)** + - Click Finish and close the window when it's complete + - In the Settings screen click one of the pencil icons to edit the Settings and make sure the following are set: + ![Publish Configuration](img/publish2.png) + - **Configuration**: Release + - **Target framework**: net7.0 + - **Deployment mode**: Self-contained + - **Target Runtime**: win-x64 + - Click **Save** + - Click **Publish** (this will build the app and upload to Azure, and can take a few minutes) + - Once finished, a browser window will open for the App Service instance, + - Repeat these steps of publishing the `PredictionService` to each of the remaining App Service instances by clicking **+ New profile** + - Be careful not to deploy the `PredictionService` to the `dispatcher-app` instance + - Be sure to edit the publish configuration for each profile created +6. Test the deployments + - Right-click on the `test/IssueLabelerService.DeploymentTests` project and **Run Tests** + - The `IssueLabelingTests.cs` file includes detailed notes for how to get full application logs should any tests fail diff --git a/Documentation/Implementation.md b/Documentation/Implementation.md index 663ee62..2996684 100644 --- a/Documentation/Implementation.md +++ b/Documentation/Implementation.md @@ -9,7 +9,7 @@ We use GraphQL and [Octokit](https://www.nuget.org/packages/Octokit/) to downloa ## ModelCreator -The [ModelCreator](https://github.com/dotnet/issue-labeler/tree/master/src/ModelCreator) project is responsible for: +The [ModelCreator](https://github.com/dotnet/issue-labeler/tree/main/src/ModelCreator) project is responsible for: 1. Downloading GitHub issues and pull requests 2. Specifying which data to download (title, description, labels, author, mentions, PR file names, optionally PR diff etc.) @@ -33,17 +33,17 @@ This console application consumes the ZIP files produced by `ModelCreator` and u After uploading new models to Azure and configuring the `PredictionService` to use the new models, the `ModelWarmup` console application can be used to load and warm up the models by issuing requests to the `PredictionService` for all of the repositories' models hosted by that service. -## PredictionService +## PredictionService (Deployed as several instances) -The [PredictionService](https://github.com/dotnet/issue-labeler/tree/master/src/PredictionService) project is the web application that uses ML models created using `ModelCreator` to predict area labels. Given repository owner/name/number combination, the `PredictionService` app provides an API returning top three predictions along with their confidence score. This information is computed using the ML models loaded in memory uploaded from Azure Blob Storage, which we produced in `ModelCreator` project. +The [PredictionService](https://github.com/dotnet/issue-labeler/tree/main/src/PredictionService) project is the web application that uses ML models created using `ModelCreator` to predict area labels. Given repository owner/name/number combination, the `PredictionService` app provides an API returning top three predictions along with their confidence score. This information is computed using the ML models loaded in memory uploaded from Azure Blob Storage, which we produced in `ModelCreator` project. Since dotnet/runtime has a big set of area owners and contributors, we decided to use an automatic assignment for issues and PRs. In order to achieve automatic label assignments, a GitHub app listens to all issue and PR creations via a webhook setting and gets the top three predictions from the `PredictionService` and only when the top prediction score has above 40% confidence, then this labeler app is allowed to automatically add that area label name to the newly created issue or PR. -For dotnet/aspnetcore however, this webhook is not active and instead, the aspnetcore repository uses the https://hubbup.io web app to allow for manual area label assignment. Rather than doing automatic assignments, the hubbup app provides a nice UI for the prediction results it receives from [PredictionService](https://github.com/dotnet/issue-labeler/tree/master/src/PredictionService). +For dotnet/aspnetcore however, this webhook is not active and instead, the aspnetcore repository uses the https://hubbup.io web app to allow for manual area label assignment. Rather than doing automatic assignments, the hubbup app provides a nice UI for the prediction results it receives from [PredictionService](https://github.com/dotnet/issue-labeler/tree/main/src/PredictionService). -## IssueLabelerService +## IssueLabelerService (Deployed as a single `dispatcher-app` instance) -The [IssueLabelerService](https://github.com/dotnet/issue-labeler/tree/master/src/IssueLabelerService) project is the GitHub app that gets installed into repositories that opt into automatic issue labeling. +The [IssueLabelerService](https://github.com/dotnet/issue-labeler/tree/main/src/IssueLabelerService) project is the GitHub app that gets installed into repositories that opt into automatic issue labeling. The GitHub app receives webhoook events for issue and pull request events, queries the top three predictions in a distributed way from the various `PredictionService` deployments (with routing based on org and repo), and updates the issues and pull requests with labels and comments per each repo's configuration. @@ -55,4 +55,4 @@ The GitHub App is configured as the [dotnet-issue-labeler](https://github.com/ap ## IssueLabelerService.DeploymentTests -The [IssueLabelerService.DeploymentTests](https://github.com/dotnet/issue-labeler/tree/master/test/IssueLabelerService.DeploymentTests) test project will make requests to the production deployment of the `IssueLabelerService` (`dispatcher-app`) to verify that the service is responding to simulated webhook events. +The [IssueLabelerService.DeploymentTests](https://github.com/dotnet/issue-labeler/tree/main/test/IssueLabelerService.DeploymentTests) test project will make requests to the production deployment of the `IssueLabelerService` (`dispatcher-app`) to verify that the service is responding to simulated webhook events. diff --git a/Documentation/README.md b/Documentation/README.md index 318268a..035e212 100644 --- a/Documentation/README.md +++ b/Documentation/README.md @@ -118,16 +118,18 @@ Follow these steps to create a new labeler app: 1. Publish the labeler app from Visual Studio - Clone the https://github.com/dotnet/issue-labeler repo - Open the **issue-labeler.sln** solution in Visual Studio - - Check that you can build the **Microsoft.DotNet.Github.IssueLabeler** project - - Right-click on the **PredictionService** project and select **Publish...** - - Create a new Publish Profile and select **Azure** as the target, then pick **Azure App Service (Windows)** as the specific target - - Select the **DDFun IaaS Dev Shared Public** subscription (formerly known as **DDITPublic**) - - Select the App Service instance that you created earlier (for example, `nuget-home-labeler` or `dispatcher-app`), check the "Deploy as ZIP package" box, and click **Next**
- ![keyvault configration](img/publish1.png) - - Deployment type: Publish - - Click **Finish**, then **Close** + - Check that you can build the solution (there will be build warnings, but there should be no errors) + - Right-click on the **PredictionService** project and select **Publish...** to create a publish profile + - Target: **Azure** + - Specific Target: **Azure App Service (Windows)** + - Subscription Name: **DDFun IaaS Dev Shared Public** + - Choose the App Service instance from the `GitHubIssueLabeller` folder, e.g. `nuget-home-labeler` + ![Choose the App Service](img/publish1.png) + - **Check the 'Deploy as ZIP package' box** + - Deployment type: **Publish (generates pubxml file)** + - Click Finish and close the window when it's complete - In the Settings screen click one of the pencil icons to edit the Settings and make sure the following are set:
- ![keyvault configration](img/publish2.png) + ![Publish Configuration](img/publish2.png) - **Configuration**: Release - **Target framework**: net7.0 - **Deployment mode**: Self-contained @@ -248,3 +250,4 @@ With the new configuration settings in place, the `dotnet-issue-labeler` app als ## Further reading * [Implementation details](./Implementation.md) - more details on how certain projects in this repo work +* [Disaster Recovery](./Disaster-Recovery.md) - how to perform a full deployment of services