У меня есть приложение функций Azure, работающее на [email protected].
Мне нужно использовать модуль запросов, поэтому в верхней части файла .py я добавил «запросы на импорт». Я также добавил запросы в файл require.txt.
У меня настроен CI/CD с помощью действий GitHub. YML прилагается.
Насколько я понимаю, MS должна установить требования в файле require.txt и сделать их доступными, однако, когда я добавляю запросы на импорт в файл py. На портале Azure функции не отображаются. Если я удалю импорт, функции снова станут видимыми.
Возможно ли, что пакеты загружаются, но когда приложение-функция Python запускается, оно запускается из другой корзины, и в результате пакеты отсутствуют? Или я упускаю шаг/подход с моим yaml?
Как мне правильно загрузить файл require.txt? правильный ли у меня поток?
name: Build and deploy Python project to Azure Function App - scubashackchat
on:
push:
branches:
- master
workflow_dispatch:
env:
AZURE_FUNCTIONAPP_PACKAGE_PATH: '.' # set this to the path to your web app project, defaults to the repository root
PYTHON_VERSION: '3.11' # set this to the python version to use (supports 3.6, 3.7, 3.8)
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Setup Python version
uses: actions/setup-python@v1
with:
python-version: ${{ env.PYTHON_VERSION }}
- 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
- name: Zip artifact for deployment
run: zip release.zip ./* -r
- name: Upload artifact for deployment job
uses: actions/upload-artifact@v3
with:
name: python-app
path: |
release.zip
!venv/
deploy:
runs-on: ubuntu-latest
needs: build
# environment:
# name: 'Production'
# url: ${{ steps.deploy-to-function.outputs.webapp-url }}
permissions:
id-token: write #This is required for requesting the JWT
steps:
- name: Download artifact from build job
uses: actions/download-artifact@v3
with:
name: python-app
- name: Unzip artifact for deployment
run: unzip release.zip
- name: Login to Azure
uses: azure/login@v1
with:
client-id: red
tenant-id: red
subscription-id: red
- name: 'Deploy to Azure Functions'
uses: Azure/functions-action@v1
id: deploy-to-function
with:
app-name: 'scubashackchat'
slot-name: 'Production'
package: ${{ env.AZURE_FUNCTIONAPP_PACKAGE_PATH }}
scm-do-build-during-deployment: true
enable-oryx-build: true
отлично спасибо. Не было необходимости создавать venv, его нужно было установить в определенное место для видимости Azure, а мою команду zip нужно было настроить для включения скрытых папок. Если вы хотите ответить, я с радостью приму
Вы можете сослаться на этот пример . Короче говоря, вам не нужно создавать виртуальную среду и устанавливать пакеты. Вы можете использовать опцию --target
в pip install
для установки пакетов в определенное место (.python_packages/lib/site-packages) для видимости функции.
- name: 'Resolve Project Dependencies Using Pip'
shell: bash
run: |
pushd './${{ env.AZURE_FUNCTIONAPP_PACKAGE_PATH }}'
python -m pip install --upgrade pip
pip install -r requirements.txt --target = ".python_packages/lib/site-packages"
popd
Также стоит отметить, что вам нужно будет изменить сценарий zip, чтобы он включал скрытые каталоги.
- name: Zip artifact for deployment
run: zip -r release.zip . -x "venv/*" ".git/*" ".github/*" ".gitignore"
Обратитесь к этому. Вот как вы можете установить свои требования