开发者问题收集

Azure、Docker Compose:应用服务、Web 应用

2024-01-16
514

2024 年 1 月 30 日更新:现在可以正常工作。请参阅下面的回答

以下是起点

我尝试通过 Docker Compose 使用 Azure 托管 Web 应用程序。

当我在计算机上运行 sudo docker-compose up --build 时,一切正常。

但是当我尝试在 Azure 上运行它时,我在日志流中收到以下错误:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"/><title>502 - Web server received an invalid response while acting as a gateway or proxy server.</title><style type="text/css"><!--body{margin:0;font-size:.7em;font-family:Verdana, Arial, Helvetica, sans-serif;background:#EEEEEE;}fieldset{padding:0 15px 10px 15px;}h1{font-size:2.4em;margin:0;color:#FFF;}h2{font-size:1.7em;margin:0;color:#CC0000;}h3{font-size:1.2em;margin:10px 0 0 0;color:#000000;}#header{width:96%;margin:0 0 0 0;padding:6px 2% 6px 2%;font-family:"trebuchet MS", Verdana, sans-serif;color:#FFF;background-color:#555555;}#content{margin:0 0 0 2%;position:relative;}.content-container{background:#FFF;width:96%;margin-top:8px;padding:10px;position:relative;}--></style></head><body><div id="header"><h1>Server Error</h1></div><div id="content"><div class="content-container"><fieldset><h2>502 - Web server received an invalid response while acting as a gateway or proxy server.</h2><h3>There is a problem with the page you are looking for, and it cannot be displayed. When the Web server (while acting as a gateway or proxy) contacted the upstream content server, it received an invalid response from the content server.</h3></fieldset></div></div></body></html>

我用来在本地构建容器的 docker-compose.yml:

# docker compose file version
# It is a docker intrinsic number.
version: '3.8'

services:

  web:
    build:
      context: .
      dockerfile: Dockerfile
    image:
         # registry_path:tag (tag defines name in registry)  
         fastapiuploadfiles.azurecr.io/uploadfiles:web_app
    ports:
        # Host Port:Container Port
      - 80:8080
    command: uvicorn app.upload_file:app --host 0.0.0.0
    volumes:
      - .:/api_code
    environment:
      - CELERY_BROKER_URL=redis://redis:6379/0
      - CELERY_RESULT_BACKEND=redis://redis:6379/0
    depends_on:
      - redis

  
  worker:
    build:
      context: .
      dockerfile: Dockerfile   
    image: fastapiuploadfiles.azurecr.io/uploadfiles:worker_app
    command: celery --app=celery_task_app.worker.celery_app worker --loglevel=info --logfile=logs/celery.log
    volumes:
      - .:/api_code
    environment:
      - CELERY_BROKER_URL=redis://redis:6379/0
      - CELERY_RESULT_BACKEND=redis://redis:6379/0
    depends_on:
      - web
      - redis

  
  redis:
    image: redis:7


  dashboard:
    build: 
      context: .
      dockerfile: Dockerfile
    image: fastapiuploadfiles.azurecr.io/uploadfiles:dashboard_app
    command: celery --broker=redis://redis:6379/0 flower --port=8080
    ports:
      - 8080:8080
    environment:
      - CELERY_BROKER_URL=redis://redis:6379/0
      - CELERY_RESULT_BACKEND=redis://redis:6379/0
    depends_on:
      - web
      - redis
      - worker

我的 docker 文件:

# Start from the official Python base image.

FROM python:3.9


# Set the current working directory to "." (current directory)
# If you want to change set WORKDIR ./selected_dir
# This is where we'll put the requirements.txt file and the app directory.
WORKDIR /api_code

# set environment variables
ENV PYTHONDONTWRITEBYTECODE 1
ENV PYTHONUNBUFFERED 1

# install dependencies
RUN pip install --upgrade pip

# Copy the file with the requirements to the ./api_code directory.
# Copy only the file with the requirements first, not the rest of the code.
# As this file doesn't change often, Docker will detect it and use the cache for this step,
# enabling the cache for the next step too.
COPY ./requirements.txt /api_code/requirements.txt


# Install the package dependencies in the requirements file.
RUN pip install --no-cache-dir --upgrade -r /api_code/requirements.txt

RUN apt-get -y update && apt-get -y upgrade && apt-get install -y --no-install-recommends ffmpeg


# torch
#RUN pip install torch==1.13.0+cpu torchvision==0.14.0+cpu torchaudio==0.13.0 --extra-index-url https://download.pytorch.org/whl/cpu
RUN pip3 install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cpu


# whisper X
RUN pip install git+https://github.com/m-bain/whisperx.git


# Copy the ./app directory inside the ./api_code/app directory.
# As this has all the code which is what changes most
# frequently the Docker cache won't be used for this or
# any following steps easily.
# So, it's important to put this near the end of the
# Dockerfile, to optimize the container image build times.

COPY ./app /api_code/app

COPY ./logs /api_code/logs

COPY ./celery_task_app /api_code/celery_task_app

EXPOSE 80

以下是我关于 Azure 的步骤:

  1. 使用 bash 脚本将图像上传到 Azure 容器注册表:

    #!/bin/sh
    
    cat azure_pwd | docker login fastapiuploadfiles.azurecr.io -u fastapiuploadfiles --password-stdin
    
    cd dir_to_push
    
    docker-compose build --pull
    
    echo -ne "\ndocker ps:\n"
    
    docker ps
    
    echo -ne "\ndocker images:\n"
    
    docker images
    
    echo -ne "\n Start push:\n"
    
    docker-compose push
    

(2) 通过网站创建 Azure Web App。此时,我不确定 Azure 期望的 docker-compose.yml 文件应该是什么样子。我使用了上面的 yml,也使用了上面的 yml,但没有使用 build 参数。但这是真的吗?两者都给了我上面提到的相同错误。由于 此链接 ,我还对 Azure 使用了以下 yml:

# docker compose file version
# It is a docker intrinsic number.
version: '3.8'

services:

  web:
    image:
         # registry_path:tag (tag defines name in registry)  
         fastapiuploadfiles.azurecr.io/uploadfiles:web_app
    ports:
        # Host Port:Container Port
      - 80:8080
    command: uvicorn app.upload_file:app --host 0.0.0.0
    volumes:
      - .:/api_code
    environment:
      - CELERY_BROKER_URL=redis://redis:6379/0
      - CELERY_RESULT_BACKEND=redis://redis:6379/0
    

  
  worker:
    image: fastapiuploadfiles.azurecr.io/uploadfiles:worker_app
    command: celery --app=celery_task_app.worker.celery_app worker --loglevel=info --logfile=logs/celery.log
    volumes:
      - .:/api_code
    environment:
      - CELERY_BROKER_URL=redis://redis:6379/0
      - CELERY_RESULT_BACKEND=redis://redis:6379/0
    

  
  redis:
    image: redis:7


  dashboard:
    image: fastapiuploadfiles.azurecr.io/uploadfiles:dashboard_app
    command: celery --broker=redis://redis:6379/0 flower --port=8080
    ports:
      - 8080:8080
    environment:
      - CELERY_BROKER_URL=redis://redis:6379/0
      - CELERY_RESULT_BACKEND=redis://redis:6379/0

我试图找到解决方案,但所有告诉我 Azure 的 yml 文件应该是什么样子的模板都失败了。

更新

Azure 告诉我: (A)

Some container port settings were found from logs Exposed port by container
8080 Listening port by container Unknown

(B) 日志文件:

Ok 2024-01-16T17:35:08.023

INFO  - fe63dfc5d102 Extracting 294MB / 297MB
  Ok

2024-01-16T17:35:10.699
INFO  - fe63dfc5d102 Extracting 297MB / 297MB
  Ok

2024-01-16T17:35:10.851
INFO  - fe63dfc5d102 Pull complete
  Ok

2024-01-16T17:35:10.852
INFO  - 4e06fb156a35 Extracting 32KB / 141KB
  Ok

2024-01-16T17:35:10.892
INFO  - 4e06fb156a35 Extracting 141KB / 141KB
  Ok

2024-01-16T17:35:10.902
INFO  - 4e06fb156a35 Pull complete
  Ok

2024-01-16T17:35:10.904
INFO  - 2bbbb0546bb4 Extracting 13KB / 13KB
  Ok

2024-01-16T17:35:10.947
INFO  - 2bbbb0546bb4 Extracting 13KB / 13KB
  Ok

2024-01-16T17:35:10.953
INFO  - 2bbbb0546bb4 Pull complete
  Ok

2024-01-16T17:35:10.955
INFO  - ac86d66f05e7 Extracting 3KB / 3KB
  Ok

2024-01-16T17:35:10.959
INFO  - ac86d66f05e7 Extracting 3KB / 3KB
  Ok

2024-01-16T17:35:11.002
INFO  - ac86d66f05e7 Pull complete
  Ok

2024-01-16T17:35:11.088
INFO  -  Digest: sha256:b57a692c3859e204572a47aedb4602e2a4f6f2c85a8cbdc0e11cb1fa97579196
  Ok

2024-01-16T17:35:11.09
INFO  -  Status: Downloaded newer image for fastapiuploadfiles.azurecr.io/uploadfiles:web_app
  Ok

2024-01-16T17:35:11.102
INFO  - Pull Image successful, Time taken: 202 Seconds
  Ok

2024-01-16T17:35:11.111
INFO  - Starting container for site

  Warning
2024-01-16T17:35:11.111

INFO  - docker run -d -p 8603:8080 --name api-celery_web_0_306850dd -e WEBSITES_ENABLE_APP_SERVICE_STORAGE=false -e WEBSITE_SITE_NAME=api-celery -e WEBSITE_AUTH_ENABLED=False -e WEBSITE_ROLE_INSTANCE_ID=0 -e WEBSITE_HOSTNAME=api-celery.azurewebsites.net -e WEBSITE_INSTANCE_ID=7fad53901ff1c3f65572da614477223d2fcd732e602f4adf52edc818614e0589 -e HTTP_LOGGING_ENABLED=1 fastapiuploadfiles.azurecr.io/uploadfiles:web_app uvicorn app.upload_file:app --host 0.0.0.0
  Ok

2024-01-16T17:35:13.182
INFO  - Pulling image: fastapiuploadfiles.azurecr.io/uploadfiles:worker_app
  Ok

2024-01-16T17:35:13.432
INFO  - worker_app Pulling from uploadfiles
  Ok

2024-01-16T17:35:13.46
INFO  -  Digest: sha256:b57a692c3859e204572a47aedb4602e2a4f6f2c85a8cbdc0e11cb1fa97579196
  Ok

2024-01-16T17:35:13.461
INFO  -  Status: Downloaded newer image for fastapiuploadfiles.azurecr.io/uploadfiles:worker_app
  Ok

2024-01-16T17:35:13.473
INFO  - Pull Image successful, Time taken: 0 Seconds
  Ok

2024-01-16T17:35:13.481
INFO  - Starting container for site
  Ok

2024-01-16T17:35:13.481
INFO  - docker run -d  --name api-celery_worker_0_306850dd -e WEBSITES_ENABLE_APP_SERVICE_STORAGE=false -e WEBSITE_SITE_NAME=api-celery -e WEBSITE_AUTH_ENABLED=False -e WEBSITE_ROLE_INSTANCE_ID=0 -e WEBSITE_HOSTNAME=api-celery.azurewebsites.net -e WEBSITE_INSTANCE_ID=7fad53901ff1c3f65572da614477223d2fcd732e602f4adf52edc818614e0589 -e HTTP_LOGGING_ENABLED=1 fastapiuploadfiles.azurecr.io/uploadfiles:worker_app celery --app=celery_task_app.worker.celery_app worker --loglevel=info --logfile=logs/celery.log
  Ok

2024-01-16T17:35:13.503
INFO  - Pulling image: redis:7
  Warning
2024-01-16T17:35:14.112
ERROR - DockerApiException: Docker API responded with status code=InternalServerError, response={"message":"Head \"https://registry-1.docker.io/v2/library/redis/manifests/7\": unauthorized: incorrect username or password"}
  Ok

2024-01-16T17:35:14.112
  Ok

2024-01-16T17:35:14.112
ERROR - Pulling docker image redis:7 failed:
  Ok

2024-01-16T17:35:15.454
INFO  - 7 Pulling from library/redis
  Ok

2024-01-16T17:35:15.856
INFO  - 2f44b7a888fa Pulling fs layer
  Ok

2024-01-16T17:35:15.856
INFO  - c55535369ffc Pulling fs layer
  Ok

2024-01-16T17:35:15.856
INFO  - 3622841bf0aa Pulling fs layer
  Ok

2024-01-16T17:35:15.856
INFO  - 91a62ca7377a Pulling fs layer
  Ok

2024-01-16T17:35:15.856
INFO  - fdd219d1f4ab Pulling fs layer
  Ok

2024-01-16T17:35:15.856
INFO  - fdf07fe2fb4c Pulling fs layer
  Ok

2024-01-16T17:35:15.856
INFO  - 4f4fb700ef54 Pulling fs layer
  Ok

2024-01-16T17:35:15.856
INFO  - fba604e70bfe Pulling fs layer
  Ok

2024-01-16T17:35:16.189
INFO  - 3622841bf0aa Downloading 721B / 875B
  Ok

2024-01-16T17:35:16.189
INFO  - 3622841bf0aa Downloading 875B / 875B
  Ok

2024-01-16T17:35:16.189
INFO  - 3622841bf0aa Verifying Checksum
  Ok

2024-01-16T17:35:16.189
INFO  - 3622841bf0aa Download complete
  Ok

2024-01-16T17:35:16.191
INFO  - fdf07fe2fb4c Downloading 96B / 96B
  Ok

2024-01-16T17:35:16.191
INFO  - fdf07fe2fb4c Verifying Checksum
  Ok

2024-01-16T17:35:16.191
INFO  - fdf07fe2fb4c Download complete
  Ok

2024-01-16T17:35:16.197
INFO  - c55535369ffc Downloading 1KB / 1KB
  Ok

2024-01-16T17:35:16.197
INFO  - c55535369ffc Verifying Checksum
  Ok

2024-01-16T17:35:16.198
INFO  - c55535369ffc Download complete
  Ok

2024-01-16T17:35:16.198
INFO  - fba604e70bfe Downloading 572B / 572B
  Ok

2024-01-16T17:35:16.198
INFO  - fba604e70bfe Verifying Checksum
  Ok

2024-01-16T17:35:16.198
INFO  - fba604e70bfe Download complete
  Ok

2024-01-16T17:35:16.205
INFO  - 91a62ca7377a Verifying Checksum
  Ok

2024-01-16T17:35:16.206
INFO  - 91a62ca7377a Download complete
  Ok

2024-01-16T17:35:16.208
INFO  - 4f4fb700ef54 Downloading 32B / 32B
  Ok

2024-01-16T17:35:16.209
INFO  - 4f4fb700ef54 Verifying Checksum
  Ok

2024-01-16T17:35:16.209
INFO  - 4f4fb700ef54 Download complete
  Ok

2024-01-16T17:35:16.359
INFO  - fdd219d1f4ab Verifying Checksum
  Ok

2024-01-16T17:35:16.36
INFO  - fdd219d1f4ab Download complete
  Ok

2024-01-16T17:35:16.483
INFO  - 2f44b7a888fa Verifying Checksum
  Ok

2024-01-16T17:35:16.483
INFO  - 2f44b7a888fa Download complete
  Ok

2024-01-16T17:35:16.651
INFO  - 2f44b7a888fa Extracting 3MB / 27MB
  Ok

2024-01-16T17:35:16.979
INFO  - 2f44b7a888fa Extracting 11MB / 27MB
  Ok

2024-01-16T17:35:17.081
INFO  - 2f44b7a888fa Extracting 15MB / 27MB
  Ok

2024-01-16T17:35:17.286
INFO  - 2f44b7a888fa Extracting 21MB / 27MB
  Ok

2024-01-16T17:35:17.514
INFO  - 2f44b7a888fa Extracting 26MB / 27MB
  Ok

2024-01-16T17:35:17.746
INFO  - 2f44b7a888fa Extracting 27MB / 27MB
  Ok

2024-01-16T17:35:17.788
INFO  - 2f44b7a888fa Pull complete
  Ok

2024-01-16T17:35:17.79
INFO  - c55535369ffc Extracting 1KB / 1KB
  Ok

2024-01-16T17:35:17.793
INFO  - c55535369ffc Extracting 1KB / 1KB
  Ok

2024-01-16T17:35:17.84
INFO  - c55535369ffc Pull complete
  Ok

2024-01-16T17:35:17.842
INFO  - 3622841bf0aa Extracting 875B / 875B
  Ok

2024-01-16T17:35:17.845
INFO  - 3622841bf0aa Extracting 875B / 875B
  Ok

2024-01-16T17:35:17.888
INFO  - 3622841bf0aa Pull complete
  Ok

2024-01-16T17:35:17.89
INFO  - 91a62ca7377a Extracting 32KB / 1MB
  Ok

2024-01-16T17:35:17.979
INFO  - 91a62ca7377a Extracting 1MB / 1MB
  Ok

2024-01-16T17:35:17.981
INFO  - 91a62ca7377a Extracting 1MB / 1MB
  Ok

2024-01-16T17:35:17.988
INFO  - 91a62ca7377a Pull complete
  Ok

2024-01-16T17:35:18.159
INFO  - fdd219d1f4ab Extracting 1MB / 19MB
  Ok

2024-01-16T17:35:18.464
INFO  - fdd219d1f4ab Extracting 8MB / 19MB
  Ok

2024-01-16T17:35:18.969
INFO  - fdd219d1f4ab Extracting 19MB / 19MB
  Ok

2024-01-16T17:35:18.986
INFO  - fdd219d1f4ab Pull complete
  Ok

2024-01-16T17:35:18.988
INFO  - fdf07fe2fb4c Extracting 96B / 96B
  Ok

2024-01-16T17:35:18.991
INFO  - fdf07fe2fb4c Extracting 96B / 96B
  Ok

2024-01-16T17:35:19.036
INFO  - fdf07fe2fb4c Pull complete
  Ok

2024-01-16T17:35:19.038
INFO  - 4f4fb700ef54 Extracting 32B / 32B
  Ok

2024-01-16T17:35:19.04
INFO  - 4f4fb700ef54 Extracting 32B / 32B
  Ok

2024-01-16T17:35:19.083
INFO  - 4f4fb700ef54 Pull complete
  Ok

2024-01-16T17:35:19.085
INFO  - fba604e70bfe Extracting 572B / 572B
  Ok

2024-01-16T17:35:19.094
INFO  - fba604e70bfe Extracting 572B / 572B
  Ok

2024-01-16T17:35:19.141
INFO  - fba604e70bfe Pull complete
  Ok

2024-01-16T17:35:19.173
INFO  -  Digest: sha256:b5ddcd52d425a8e354696c022f392fe45fca928f68d6289e6bb4a709c3a74668
  Ok

2024-01-16T17:35:19.174
INFO  -  Status: Downloaded newer image for redis:7
  Ok

2024-01-16T17:35:19.185
INFO  - Pull Image successful, Time taken: 5 Seconds
  Ok

2024-01-16T17:35:19.197
INFO  - Starting container for site
  Ok

2024-01-16T17:35:19.197
INFO  - docker run -d  --name api-celery_redis_0_306850dd -e WEBSITES_ENABLE_APP_SERVICE_STORAGE=false -e WEBSITE_SITE_NAME=api-celery -e WEBSITE_AUTH_ENABLED=False -e WEBSITE_ROLE_INSTANCE_ID=0 -e WEBSITE_HOSTNAME=api-celery.azurewebsites.net -e WEBSITE_INSTANCE_ID=7fad53901ff1c3f65572da614477223d2fcd732e602f4adf52edc818614e0589 -e HTTP_LOGGING_ENABLED=1 redis:7 
  Ok

2024-01-16T17:35:20.429
INFO  - Pulling image: fastapiuploadfiles.azurecr.io/uploadfiles:dashboard_app
  Ok

2024-01-16T17:35:20.641
INFO  - dashboard_app Pulling from uploadfiles
  Ok

2024-01-16T17:35:20.651
INFO  -  Digest: sha256:b57a692c3859e204572a47aedb4602e2a4f6f2c85a8cbdc0e11cb1fa97579196
  Ok

2024-01-16T17:35:20.652
INFO  -  Status: Downloaded newer image for fastapiuploadfiles.azurecr.io/uploadfiles:dashboard_app
  Ok

2024-01-16T17:35:20.667
INFO  - Pull Image successful, Time taken: 0 Seconds
  Ok

2024-01-16T17:35:21.101
INFO  - Starting container for site
  Ok

2024-01-16T17:35:21.101
INFO  - docker run -d  --name api-celery_dashboard_0_306850dd -e WEBSITES_ENABLE_APP_SERVICE_STORAGE=false -e WEBSITE_SITE_NAME=api-celery -e WEBSITE_AUTH_ENABLED=False -e WEBSITE_ROLE_INSTANCE_ID=0 -e WEBSITE_HOSTNAME=api-celery.azurewebsites.net -e WEBSITE_INSTANCE_ID=7fad53901ff1c3f65572da614477223d2fcd732e602f4adf52edc818614e0589 -e HTTP_LOGGING_ENABLED=1 fastapiuploadfiles.azurecr.io/uploadfiles:dashboard_app celery --broker=redis://redis:6379/0 flower --port=8080

更新 17.01.2024

我用 docker tag redis:7 fastapiuploadfiles.azurecr.io/uploadfiles:redis_app 。所以我能够推送所有容器 - 包括 redis。当我使用 Suresh Chikkam 的 yml 文件启动容器并尝试打开指向我的应用程序前端的链接(web_app 标签)时,我收到以下日志流输出:

Error occurred, type: error, text: Response Content-Length mismatch: too many bytes written (94517 of 66268)., stackTrace: at Microsoft.AspNetCore.Server.Kestrel.Core.Internal.Http.HttpProtocol.VerifyAndUpdateWrite(Int32 count)at Microsoft.AspNetCore.Server.Kestrel.Core.Internal.Http.HttpProtocol.WritePipeAsync(ReadOnlyMemory 1 data, CancellationToken cancellationToken)at Microsoft.AspNetCore.Server.Kestrel.Core.Internal.Http.HttpResponseStream.WriteAsync(ReadOnlyMemory 1 source, CancellationToken cancellationToken)at Microsoft.AspNetCore.Http.StreamCopyOperationInternal.CopyToAsync(Stream source, Stream destination, Nullable`1 count, Int32 bufferSize, CancellationToken cancel)at Microsoft.AspNetCore.Internal.FileResultHelper.WriteFileAsync(HttpContext context, Stream fileStream, RangeItemHeaderValue range, Int64 rangeLength)at Microsoft.AspNetCore.Mvc.Infrastructure.FileResultExecutorBase.WriteFileAsync(HttpContext context, Stream fileStream, RangeItemHeaderValue range, Int64 rangeLength)at Microsoft.AspNetCore.Mvc.Infrastructure.FileStreamResultExecutor.ExecuteAsync(ActionContext context, FileStreamResult result)at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.g__Awaited|30_0[TFilter,TFilterAsync](ResourceInvoker invoker, Task lastTask, State next, Scope scope, Object state, Boolean isCompleted)at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.Rethrow(ResultExecutedContextSealed context)at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.ResultNext[TFilter,TFilterAsync](State& next, Scope& scope, Object& state, Boolean& isCompleted)at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.g__Awaited|28_0(ResourceInvoker invoker, Task lastTask, State next, Scope scope, Object state, Boolean isCompleted)at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.g__Awaited|25_0(ResourceInvoker invoker, Task lastTask, State next, Scope scope, Object state, Boolean isCompleted)at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.Rethrow(ResourceExecutedContextSealed context)at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.Next(State& next, Scope& scope, Object& state, Boolean& isCompleted)at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.g__Awaited|20_0(ResourceInvoker invoker, Task lastTask, State next, Scope scope, Object state, Boolean isCompleted)at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.g__Awaited|17_0(ResourceInvoker invoker, Task task, IDisposable scope)at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.g__Awaited|17_0(ResourceInvoker invoker, Task task, IDisposable scope)at Microsoft.AspNetCore.Builder.RouterMiddleware.Invoke(HttpContext httpContext)at Kudu.Services.Web.Tracing.TraceMiddleware.Invoke(HttpContext context) in /tmp/KuduLite/Kudu.Services.Web/Tracing/TraceMiddleware.cs:line 95

启动容器后:

docker run -d --name api-celery_dashboard_0_4022f740 -e WEBSITES_ENABLE_APP_SERVICE_STORAGE=false -e WEBSITE_SITE_NAME=api-celery -e WEBSITE_AUTH_ENABLED=False -e WEBSITE_ROLE_INSTANCE_ID=0 -e WEBSITE_HOSTNAME=api-celery.azurewebsites.net -e WEBSITE_INSTANCE_ID=7fad53901ff1c3f65572da614477223d2fcd732e602f4adf52edc818614e0589 -e HTTP_LOGGING_ENABLED=1 fastapiuploadfiles.azurecr.io/uploadfiles:dashboard_app celery --broker=redis://redis:6379/0 flower --port=8080/home/LogFiles/2024_01_17_ln0xsdlwk000019_redis_docker.log ( https://api-celery.scm.azurewebsites.net/api/vfs/LogFiles/2024_01_17_ln0xsdlwk000019_redis_docker.log )/home/LogFiles/2024_01_17_ln0xsdlwk000019_web_docker.log ( https://api-celery.scm.azurewebsites.net/api/vfs/LogFiles/2024_01_17_ln0xsdlwk000019_web_docker.log )/home/LogFiles/2024_01_17_ln0xsdlwk000019_worker_docker.log ( https://api-celery.scm.azurewebsites.net/api/vfs/LogFiles/2024_01_17_ln0xsdlwk000019_worker_docker.log )Ending Log Tail of existing logs ---Starting Live Log Stream ---

30.01.2024:现在可以正常工作。请参阅下面的回答

2个回答

502 - Web server received an invalid response while acting as a gateway or proxy server

这通常意味着部署在 Azure 应用服务中的应用程序无法按预期工作。

  • 这里 @Zori 也对这些问题提供了一些有价值的见解,在 Azure docker-compose.yml 中存在 build: 的情况下,从此文件中删除了 build: 部分,因为 Azure 需要预构建的图像。

公开这些端口而不是端口 8080。

docker-compose.yml:

services:
  web:
    ports:
      - 80:8080
  • 使用特定的将 Redis 映像推送到 Azure 容器注册表 (ACR)标签。
docker tag docker.io/redis:7 fastapiuploadfiles.azurecr.io/redis:7
docker push fastapiuploadfiles.azurecr.io/redis:7

docker-compose.yml

version: '3.8'

services:

  web:
    image: fastapiuploadfiles.azurecr.io/uploadfiles:web_app
    ports:
      - 80:8080
    command: uvicorn app.upload_file:app --host 0.0.0.0
    environment:
      - CELERY_BROKER_URL=redis://redis:6379/0
      - CELERY_RESULT_BACKEND=redis://redis:6379/0
    depends_on:
      - redis

  worker:
    image: fastapiuploadfiles.azurecr.io/uploadfiles:worker_app
    command: celery --app=celery_task_app.worker.celery_app worker --loglevel=info --logfile=logs/celery.log
    environment:
      - CELERY_BROKER_URL=redis://redis:6379/0
      - CELERY_RESULT_BACKEND=redis://redis:6379/0
    depends_on:
      - web

  redis:
    image: fastapiuploadfiles.azurecr.io/redis:7

  dashboard:
    image: fastapiuploadfiles.azurecr.io/uploadfiles:dashboard_app
    command: celery --broker=redis://redis:6379/0 flower --port=8080
    ports:
      - 8080:8080
    environment:
      - CELERY_BROKER_URL=redis://redis:6379/0
      - CELERY_RESULT_BACKEND=redis://redis:6379/0
    depends_on:
      - web
      - redis
  • 您可以检查已成功构建并推送到 ACR 的图像。

在此处输入图像描述

Suresh Chikkam
2024-01-17

现在可以正常工作了。

(1) 用于构建容器的 docker-compose.yml:

version: '3.8'

services:

  web:
    build: 
      context: .
      dockerfile: Dockerfile
    image: # registry_path:tag (tag defines name in registry)  
        fastapiuploadfiles.azurecr.io/uploadfiles:web_app_2.4
    ports:
        # Host Port:Container Port
      - 80:8000
    command: uvicorn app.upload_file:app --host 0.0.0.0
    volumes:
      - type: bind
        source: /home/tw/wav_data_host
        target: /api_code/app/wav_data
    environment:
      - CELERY_BROKER_URL=redis://redis:6379/0
      - CELERY_RESULT_BACKEND=redis://redis:6379/0
    depends_on:
      - redis

  
  worker:
    build:
      context: .
      dockerfile: Dockerfile
    image: fastapiuploadfiles.azurecr.io/uploadfiles:worker_app_2.4
    command: > 
             celery
             --app=celery_task_app.worker.celery_app worker
             --loglevel=info
             --logfile=logs/celery.log
    volumes:
      - type: bind
        source: /home/tw/wav_data_host
        target: /api_code/app/wav_data
    environment:
      - CELERY_BROKER_URL=redis://redis:6379/0
      - CELERY_RESULT_BACKEND=redis://redis:6379/0
    depends_on:
      - web
      - redis

  
  redis:
    image: redis:7


  dashboard:
    build: 
      context: .
      dockerfile: Dockerfile
    image: fastapiuploadfiles.azurecr.io/uploadfiles:dashboard_app_2.4
    command: celery --broker=redis://redis:6379/0 flower --port=5555
    ports:
      - 8080:5555
    environment:
      - CELERY_BROKER_URL=redis://redis:6379/0
      - CELERY_RESULT_BACKEND=redis://redis:6379/0
    depends_on:
      - web
      - redis
      - worker

(2) Dockerfile:

FROM python:3.9

WORKDIR /api_code

# set environment variables
ENV PYTHONDONTWRITEBYTECODE 1
ENV PYTHONUNBUFFERED 1

# install dependencies
RUN pip install --upgrade pip

COPY ./requirements.txt /api_code/requirements.txt

# Install the package dependencies in the requirements file.
RUN pip install --no-cache-dir --upgrade -r /api_code/requirements.txt

RUN apt-get -y update && apt-get -y upgrade && apt-get install -y --no-install-recommends ffmpeg


# torch
torchaudio==0.13.0 --extra-index-url https://download.pytorch.org/whl/cpu
RUN pip3 install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cpu


# whisper X
RUN pip install git+https://github.com/m-bain/whisperx.git

COPY ./app /api_code/app

COPY ./logs /api_code/logs

COPY ./celery_task_app /api_code/celery_task_app

(3) 推送到 Azure 容器注册表:

#!/bin/sh
    
set -e

cat azure_pwd | docker login registry_name.azurecr.io -u 
registry_name --password-stdin

cd dir_to_push

docker-compose build --pull

echo -e "\ndocker ps:\n"

docker ps

echo -e "\ndocker images:\n"

docker images

echo -e "\nRetag redis image:\n"

docker tag redis:7 
registry_name.azurecr.io/repository_name:redis_app_2.4

echo -e "\ndocker images retagged:\n"

docker images

echo -e "\n Start push (except redis):\n"

docker-compose push

echo -e "\n Start push redis:\n"

docker push registry_name.azurecr.io/repository_name:redis_app_2.4

(4) 用于多容器 Web 应用的 Azure yaml 文件:

version: '3.8'

services:

  web:
    image: # registry_path:tag (tag defines name in registry)  
        registry_name.azurecr.io/repository_name:web_app_2.4
    ports:
        # Host Port:Container Port
      - 80:8000
    command: uvicorn app.upload_file:app --host 0.0.0.0
    volumes:
      - type: bind
        source: ${WEBAPP_STORAGE_HOME}/site/wwwroot/wav_data
        target: /api_code/app/wav_data
    environment:
      - CELERY_BROKER_URL=redis://redis:6379/0
      - CELERY_RESULT_BACKEND=redis://redis:6379/0
    depends_on:
      - redis

  
  worker:
    image: registry_name.azurecr.io/repository_name:worker_app_2.4
    command: > 
             celery
             --app=celery_task_app.worker.celery_app worker
             --loglevel=info
             --logfile=logs/celery.log
    volumes:
      - type: bind
        source: ${WEBAPP_STORAGE_HOME}/site/wwwroot/wav_data
        target: /api_code/app/wav_data
    environment:
      - CELERY_BROKER_URL=redis://redis:6379/0
      - CELERY_RESULT_BACKEND=redis://redis:6379/0
    depends_on:
      - web
      - redis

  
  redis:
    image: registry_name.azurecr.io/repository_name:redis_app_2.4

  dashboard:
    image: registry_name.azurecr.io/repository_name:dashboard_app_2.4
    command: celery --broker=redis://redis:6379/0 flower --port=5555
    ports:
      - 443:5555
    environment:
      - CELERY_BROKER_URL=redis://redis:6379/0
      - CELERY_RESULT_BACKEND=redis://redis:6379/0
    depends_on:
      - web
      - redis
      - worker
Tütü
2024-01-30