From 7fc5d30490f47b08fb9650510c8ca359d1a94a52 Mon Sep 17 00:00:00 2001 From: Shubham Sharma Date: Fri, 30 Jul 2021 23:15:05 +0530 Subject: [PATCH 1/6] Add or update the App Service deployment workflow configuration from Azure Portal. --- ...i-postgresql-azure-deploy_fastapi-srvc.yml | 62 +++++++++++++++++++ 1 file changed, 62 insertions(+) create mode 100644 .github/workflows/fastapi-postgresql-azure-deploy_fastapi-srvc.yml diff --git a/.github/workflows/fastapi-postgresql-azure-deploy_fastapi-srvc.yml b/.github/workflows/fastapi-postgresql-azure-deploy_fastapi-srvc.yml new file mode 100644 index 0000000..cbcf733 --- /dev/null +++ b/.github/workflows/fastapi-postgresql-azure-deploy_fastapi-srvc.yml @@ -0,0 +1,62 @@ +# Docs for the Azure Web Apps Deploy action: https://github.com/Azure/webapps-deploy +# More GitHub Actions for Azure: https://github.com/Azure/actions +# More info on Python, GitHub Actions, and Azure App Service: https://aka.ms/python-webapps-actions + +name: Build and deploy Python app to Azure Web App - fastapi-srvc + +on: + push: + branches: + - fastapi-postgresql-azure-deploy + workflow_dispatch: + +jobs: + build: + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v2 + + - name: Set up Python version + uses: actions/setup-python@v1 + with: + python-version: '3.8' + + - name: Create and start virtual environment + run: | + python -m venv venv + source venv/bin/activate + + - name: Install dependencies + run: pip install -r requirements.txt + + # Optional: Add step to run tests here (PyTest, Django test suites, etc.) + + - name: Upload artifact for deployment jobs + uses: actions/upload-artifact@v2 + with: + name: python-app + path: | + . + !venv/ + + deploy: + runs-on: ubuntu-latest + needs: build + environment: + name: 'production' + url: ${{ steps.deploy-to-webapp.outputs.webapp-url }} + + steps: + - name: Download artifact from build job + uses: actions/download-artifact@v2 + with: + name: python-app + path: . + + - name: 'Deploy to Azure Web App' + uses: azure/webapps-deploy@v2 + with: + app-name: 'fastapi-srvc' + slot-name: 'production' + publish-profile: ${{ secrets.AzureAppService_PublishProfile_1361b2e5e77346b9b77c4577c62cb96c }} \ No newline at end of file From 3ba2bcd2f11707b5a0dc1ddb81257756243529f2 Mon Sep 17 00:00:00 2001 From: Shubham Sharma Date: Fri, 30 Jul 2021 23:48:58 +0530 Subject: [PATCH 2/6] Update main.py --- main.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/main.py b/main.py index 021dff9..9e043f8 100644 --- a/main.py +++ b/main.py @@ -8,7 +8,7 @@ import os import urllib -#DATABASE_URL = "sqlite:///./test.db" +DATABASE_URL = "sqlite:///./test.db" host_server = os.environ.get('host_server', 'localhost') db_server_port = urllib.parse.quote_plus(str(os.environ.get('db_server_port', '5432'))) @@ -16,7 +16,7 @@ db_username = urllib.parse.quote_plus(str(os.environ.get('db_username', 'postgres'))) db_password = urllib.parse.quote_plus(str(os.environ.get('db_password', 'secret'))) ssl_mode = urllib.parse.quote_plus(str(os.environ.get('ssl_mode','prefer'))) -DATABASE_URL = 'postgresql://{}:{}@{}:{}/{}?sslmode={}'.format(db_username, db_password, host_server, db_server_port, database_name, ssl_mode) +#DATABASE_URL = 'postgresql://{}:{}@{}:{}/{}?sslmode={}'.format(db_username, db_password, host_server, db_server_port, database_name, ssl_mode) database = databases.Database(DATABASE_URL) @@ -31,8 +31,8 @@ ) engine = sqlalchemy.create_engine( - #DATABASE_URL, connect_args={"check_same_thread": False} - DATABASE_URL, pool_size=3, max_overflow=0 + DATABASE_URL, connect_args={"check_same_thread": False} + #DATABASE_URL, pool_size=3, max_overflow=0 ) metadata.create_all(engine) From ee277206654be061b1834780cbce624f2b2df58e Mon Sep 17 00:00:00 2001 From: Shubham Sharma Date: Fri, 30 Jul 2021 23:51:44 +0530 Subject: [PATCH 3/6] Add or update the App Service deployment workflow configuration from Azure Portal. --- .../workflows/fastapi-postgresql-azure-deploy_fastapi-srvc.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/fastapi-postgresql-azure-deploy_fastapi-srvc.yml b/.github/workflows/fastapi-postgresql-azure-deploy_fastapi-srvc.yml index cbcf733..eb96e06 100644 --- a/.github/workflows/fastapi-postgresql-azure-deploy_fastapi-srvc.yml +++ b/.github/workflows/fastapi-postgresql-azure-deploy_fastapi-srvc.yml @@ -59,4 +59,4 @@ jobs: with: app-name: 'fastapi-srvc' slot-name: 'production' - publish-profile: ${{ secrets.AzureAppService_PublishProfile_1361b2e5e77346b9b77c4577c62cb96c }} \ No newline at end of file + publish-profile: ${{ secrets.AzureAppService_PublishProfile_3ecad809485d4b61ab1bbb61a1abe8cd }} \ No newline at end of file From 86d784510be1e65d4e5658c0c9b05018c3ae60ce Mon Sep 17 00:00:00 2001 From: Shubham Sharma Date: Fri, 30 Jul 2021 23:52:51 +0530 Subject: [PATCH 4/6] Update main.py --- main.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/main.py b/main.py index 9e043f8..021dff9 100644 --- a/main.py +++ b/main.py @@ -8,7 +8,7 @@ import os import urllib -DATABASE_URL = "sqlite:///./test.db" +#DATABASE_URL = "sqlite:///./test.db" host_server = os.environ.get('host_server', 'localhost') db_server_port = urllib.parse.quote_plus(str(os.environ.get('db_server_port', '5432'))) @@ -16,7 +16,7 @@ db_username = urllib.parse.quote_plus(str(os.environ.get('db_username', 'postgres'))) db_password = urllib.parse.quote_plus(str(os.environ.get('db_password', 'secret'))) ssl_mode = urllib.parse.quote_plus(str(os.environ.get('ssl_mode','prefer'))) -#DATABASE_URL = 'postgresql://{}:{}@{}:{}/{}?sslmode={}'.format(db_username, db_password, host_server, db_server_port, database_name, ssl_mode) +DATABASE_URL = 'postgresql://{}:{}@{}:{}/{}?sslmode={}'.format(db_username, db_password, host_server, db_server_port, database_name, ssl_mode) database = databases.Database(DATABASE_URL) @@ -31,8 +31,8 @@ ) engine = sqlalchemy.create_engine( - DATABASE_URL, connect_args={"check_same_thread": False} - #DATABASE_URL, pool_size=3, max_overflow=0 + #DATABASE_URL, connect_args={"check_same_thread": False} + DATABASE_URL, pool_size=3, max_overflow=0 ) metadata.create_all(engine) From 2f752eef2e9dbecde028674b24a1bd8fe9ca35e9 Mon Sep 17 00:00:00 2001 From: Shubham Sharma Date: Sat, 31 Jul 2021 00:25:00 +0530 Subject: [PATCH 5/6] Update requirements.txt --- requirements.txt | 1 - 1 file changed, 1 deletion(-) diff --git a/requirements.txt b/requirements.txt index 0be2ca2..acecd98 100644 --- a/requirements.txt +++ b/requirements.txt @@ -8,5 +8,4 @@ psycopg2-binary==2.8.6 pydantic==1.7.3 SQLAlchemy==1.3.22 starlette==0.13.6 -uvicorn==0.13.3 websockets==8.1 From 72b41df44e9c3502977de1bd787fc9f0d86d8ffd Mon Sep 17 00:00:00 2001 From: Shubham Sharma Date: Sat, 31 Jul 2021 00:53:25 +0530 Subject: [PATCH 6/6] Update requirements.txt --- requirements.txt | 1 + 1 file changed, 1 insertion(+) diff --git a/requirements.txt b/requirements.txt index acecd98..a55da94 100644 --- a/requirements.txt +++ b/requirements.txt @@ -9,3 +9,4 @@ pydantic==1.7.3 SQLAlchemy==1.3.22 starlette==0.13.6 websockets==8.1 +uvicorn==0.14.0