In this requirement. Dedicated Application Gateways and App services are needed without the usage of staging slots as multiple hardening rules have to be tested where a dedicated application gateway is chosen so that no one will mess with the production application gateway for testing.
Pipelines are integrated with GitHub Repo for CI / CD, and it deploys to UAT where they can be tested if it gets approved after testing it will be deployed to Production.
- Implementing Application Gateway with Web Application Firewall – Azure365Pro.com
- Restricting App Service through Application Gateway – Azure365Pro.com
data:image/s3,"s3://crabby-images/6d5ba/6d5ba3bb8a63a7782cae4beb7f2255cc839343a7" alt=""
Let’s get started with a service connection. So that pipelines can have full permission over the subscription to modify resources in this case.
data:image/s3,"s3://crabby-images/42549/4254981fe74e659543829932965ae804e38283b6" alt=""
data:image/s3,"s3://crabby-images/a3185/a318507fbcb4c5810ffbfa56398ad9d93ff930f0" alt=""
data:image/s3,"s3://crabby-images/3b4ba/3b4badf632341e0cc16549f82e7c1daedf456a92" alt=""
data:image/s3,"s3://crabby-images/d099b/d099bd82af8bb92bc743aa917f71f027b8509fb9" alt=""
Add a Service Connection for GitHub –
data:image/s3,"s3://crabby-images/842fd/842fd00abdfbcf45eac8b3f184eb81e28ae57e8e" alt=""
Let’s create a new release pipeline.
data:image/s3,"s3://crabby-images/84f5e/84f5e63773c0c221b6da02dee9f7ba1865685f09" alt=""
Utilizing Source Type GitHub Artifact
data:image/s3,"s3://crabby-images/d729e/d729e1ecc418ac84e8a5537faeee3a9468f6b6c3" alt=""
For UAT App Service Deployment
data:image/s3,"s3://crabby-images/0e8b4/0e8b4972a84750c74bc9b812d2852ae859119411" alt=""
Post Deployment Approval is set
data:image/s3,"s3://crabby-images/6ba90/6ba90bb2f62789f1958a91bd322401f4c34eb959" alt=""
Scenario #1 – For Production App Service Deployment ( PHP 8.0- Web Application is used in this scenario)
data:image/s3,"s3://crabby-images/1e17a/1e17a2f2a31932160a6c856758e0158833ced240" alt=""
Scenario #2 – For Production App Service Deployment (Yii PHP Framework Web Application is used in this scenario collecting the files published from Artifact)
data:image/s3,"s3://crabby-images/121e1/121e199675a0bf2643ade653b209826190f8ad6a" alt=""
Let’s see how to Publish Artifacts So that Azure Pipelines can pick from above
data:image/s3,"s3://crabby-images/b48ce/b48cef86dbfbbc82a6b87fca9e79d028de3af991" alt=""
Installing composer for YII framework to use
composer install
composer dump-autoload
data:image/s3,"s3://crabby-images/40c3e/40c3e41e17f0f97fb3091621c6961c4f8633f5e1" alt=""
data:image/s3,"s3://crabby-images/5ab7f/5ab7fed43bb72b498a835204d4951ac97db96414" alt=""
data:image/s3,"s3://crabby-images/efcee/efceeac9958b761bca95d9e10a4a6652ab93221c" alt=""
data:image/s3,"s3://crabby-images/6d112/6d112bb609da56e910f73b980c7423606b618d06" alt=""
Scenario #3 – For Production App Service Deployment (Node Js Web Application Front End is used in this scenario)
data:image/s3,"s3://crabby-images/22a83/22a839e4faaac5d7eb5b51e0919a1a81aac11838" alt=""
Let’s see how to Publish Artifacts So that Azure Pipelines can pick from above
data:image/s3,"s3://crabby-images/aacfe/aacfe9c90a53a214943c1d5b5a77a5c2950ea2f9" alt=""
data:image/s3,"s3://crabby-images/5e2eb/5e2eb43991a9672d73567ebe875c597fdba72db7" alt=""
data:image/s3,"s3://crabby-images/94b50/94b502419b7bb52787043e1fde3eba796be4d7b1" alt=""
data:image/s3,"s3://crabby-images/eff7c/eff7c685ab7d69f276da87d660570e02bece4cbc" alt=""
$(Build.ArtifactStagingDirectory)/$(Build.BuildId).zip
data:image/s3,"s3://crabby-images/6d4a9/6d4a99515f6709a47f3a52c526bc181a5de88f99" alt=""
data:image/s3,"s3://crabby-images/374e3/374e3f6e3deb0020b80550d8f90b896de23682c7" alt=""
The artifact location and zip name can be found here.
data:image/s3,"s3://crabby-images/e8df5/e8df521161a2f15bbd7988e28e6fa0f1551e5956" alt=""
You can see releases shown below ,
data:image/s3,"s3://crabby-images/5c618/5c618c698ab4bb12f73581f860ed0c396debcf7c" alt=""
Now if you create a new release
First, it deploys to UAT, and after approval, it gets to the Prod App service
data:image/s3,"s3://crabby-images/5d064/5d0640eb2b2eae9fea1b95a6011824270615a926" alt=""