<!-- review: finished -->

<a id="docker-images"></a>

# Imagens Docker do Angie

Para executar o Angie em um contêiner
[Docker](https://docs.docker.com/engine/reference/commandline/cli/),
use as imagens do nosso registro: `docker.angie.software`.
Elas são construídas baseadas em nossos [pacotes binários](https://pt.angie.software//angie/docs/installation/oss_packages.md#oss-packages)
e nas imagens base oficiais de vários sistemas operacionais.

#### NOTE
Note também o módulo [Docker](https://pt.angie.software//angie/docs/configuration/modules/http/http_docker.md#http-docker),
que implementa atualização dinâmica de grupos de servidores upstream
baseada em rótulos de contêineres Docker.

<a id="minimal-images"></a>

## Imagens Mínimas

- `angie:minimal`:
  versão  baseada no Alpine 3.22.
- `angie:<VERSION>-minimal`:
  versão especificada baseada no Alpine 3.22.

Essas imagens incluem apenas o pacote `angie`.

<a id="docker-templated"></a>

## Imagens com Templates

- `angie:templated`:
  versão  baseada no Alpine 3.22.
- `angie:<VERSION>-templated`:
  versão especificada baseada no Alpine 3.22.

Essas imagens definem as seguintes variáveis de ambiente:

```docker
ENV ANGIE_BINARY="angie"
ENV ANGIE_CONFIG_TEMPLATE="/etc/angie/angie.conf.t"
ENV ANGIE_ERROR_LOG_SEVERITY="notice"
ENV ANGIE_FEATURE_RELOAD="on"
ENV ANGIE_FEATURE_TEMPLATE="on"
ENV ANGIE_LOAD_MODULES=""
ENV ANGIE_PID_FILE="/run/angie/angie.pid"
ENV ANGIE_WORKER_CONNECTIONS="65536"
ENV ANGIE_WORKER_RLIMIT_NOFILE="65536"
```

Essas variáveis podem ser usadas para personalizar o comportamento do contêiner:

- `ANGIE_BINARY`:
  Permite executar a [versão de debug](https://pt.angie.software//angie/docs/troubleshooting.md#debug-logging).
- `ANGIE_ERROR_LOG_SEVERITY`:
  Define o nível de severidade para entradas no arquivo principal de [log de erro](https://pt.angie.software//angie/docs/configuration/processing.md#logging).
- `ANGIE_LOAD_MODULES`:
  Carrega um ou mais módulos disponíveis (todos os módulos estão incluídos na imagem).
  Especifique uma lista de módulos separados por vírgula sem espaços.
- `ANGIE_PID_FILE`:
  Define um local alternativo para o arquivo de identificador de processo (PID).
- `ANGIE_FEATURE_TEMPLATE`:
  Gera [configuração do Angie](https://pt.angie.software//angie/docs/configuration/configfile.md#configfile) usando a
  ferramenta [gomplate](https://docs.gomplate.ca/) na inicialização do contêiner. Parâmetros
  usados: `--input-dir /etc/angie/templates` e
  `--output-dir /etc/angie`.
- `ANGIE_FEATURE_RELOAD`:
  Habilita o tratamento dos sinais `SIGHUP`, `SIGQUIT` e `SIGTERM`.

Essas incluem os seguintes
[pacotes](https://pt.angie.software//angie/docs/installation/external-modules/index.md#install-thirdpartymodules)
(se foram lançados para a [versão do Angie](https://pt.angie.software//angie/docs/oss_changes.md#oss-changes)
com a qual a imagem foi construída):

### Lista de Pacotes

- `angie-console-light`
- `angie-module-auth-jwt`
- `angie-module-auth-ldap`
- `angie-module-auth-pam`
- `angie-module-auth-spnego`
- `angie-module-auth-totp`
- `angie-module-brotli`
- `angie-module-cache-purge`
- `angie-module-cgi`
- `angie-module-combined-upstreams`
- `angie-module-dav-ext`
- `angie-module-dynamic-limit-req`
- `angie-module-echo`
- `angie-module-enhanced-memcached`
- `angie-module-eval`
- `angie-module-geoip2`
- `angie-module-headers-more`
- `angie-module-http-auth-radius`
- `angie-module-image-filter`
- `angie-module-keyval`
- `angie-module-lua`
- `angie-module-modsecurity`
- `angie-module-ndk`
- `angie-module-njs`
- `angie-module-opentracing`
- `angie-module-otel`
- `angie-module-perl`
- `angie-module-postgres`
- `angie-module-redis2`
- `angie-module-rtmp`
- `angie-module-set-misc`
- `angie-module-subs`
- `angie-module-testcookie`
- `angie-module-unbrotli`
- `angie-module-upload`
- `angie-module-vod`
- `angie-module-vts`
- `angie-module-wasm`
- `angie-module-wasmtime`
- `angie-module-xslt`
- `angie-module-zip`
- `angie-module-zstd`

<a id="examples-1"></a>

### Exemplos

A configuração usada em imagens com templates aplica as variáveis
aproximadamente da seguinte forma:

```none
...
{{- if has $modules "zstd"}}
# package: angie-module-zstd
load_module modules/ngx_http_zstd_filter_module.so;
load_module modules/ngx_http_zstd_static_module.so;
{{end}}

user  angie;
worker_processes  auto;
worker_rlimit_nofile {{.Env.ANGIE_WORKER_RLIMIT_NOFILE}};

error_log  /var/log/angie/error.log {{.Env.ANGIE_ERROR_LOG_SEVERITY}};
pid        {{.Env.ANGIE_PID_FILE}};

events {
    worker_connections  {{.Env.ANGIE_WORKER_CONNECTIONS}};
}

http {
    include       /etc/angie/mime.types;
    default_type  application/octet-stream;

    log_format  main  ...
```

Executando um contêiner com acesso ao shell:

```console
$ docker run -it --pull always --rm --entrypoint=sh \
  docker.angie.software/angie:templated
```

Execute o Angie com parâmetros de conexão personalizados e módulos
(o comando **angie -T** irá exibir a configuração completa):

```console
$ docker run -it --rm -e ANGIE_WORKER_CONNECTIONS=4 \
  -e ANGIE_LOAD_MODULES="auth-jwt,vod" \
  docker.angie.software/angie:templated angie -T
```

Inicie um contêiner com um nome especificado e módulos adicionais:

```console
$ docker run -it --rm --name angie-test \
  -e ANGIE_WORKER_CONNECTIONS=4 \
  -e ANGIE_LOAD_MODULES="auth-jwt,vod" \
  docker.angie.software/angie:templated
```

Recarregue a configuração de um contêiner em execução:

```console
$ docker kill -s HUP angie-test
```

<a id="images-with-extra-modules"></a>

## Imagens com Módulos Extras

- `angie:latest`:
  versão  baseada no Alpine 3.22.
- `angie:<VERSION>`,
  `angie:<VERSION>-alpine`:
  versão especificada baseada no Alpine 3.22.
- `angie:<VERSION>-debian`:
  versão especificada baseada no Debian 13.
- `angie:<VERSION>-rocky`:
  versão especificada baseada no Rocky Linux 9.
- `angie:<VERSION>-ubuntu`:
  versão especificada baseada no Ubuntu 24.04 LTS.

Essas incluem os seguintes
[pacotes](https://pt.angie.software//angie/docs/installation/external-modules/index.md#install-thirdpartymodules)
(se foram lançados para a [versão do Angie](https://pt.angie.software//angie/docs/oss_changes.md#oss-changes)
com a qual a imagem foi construída):

### Lista de Pacotes

- `angie-console-light`
- `angie-module-auth-jwt`
- `angie-module-auth-ldap`
- `angie-module-auth-pam`
- `angie-module-auth-spnego`
- `angie-module-auth-totp`
- `angie-module-brotli`
- `angie-module-cache-purge`
- `angie-module-cgi`
- `angie-module-combined-upstreams`
- `angie-module-dav-ext`
- `angie-module-dynamic-limit-req`
- `angie-module-echo`
- `angie-module-enhanced-memcached`
- `angie-module-eval`
- `angie-module-geoip2`
- `angie-module-headers-more`
- `angie-module-http-auth-radius`
- `angie-module-image-filter`
- `angie-module-keyval`
- `angie-module-lua`
- `angie-module-modsecurity`
- `angie-module-ndk`
- `angie-module-njs`
- `angie-module-opentracing`
- `angie-module-otel`
- `angie-module-perl`
- `angie-module-postgres`
- `angie-module-redis2`
- `angie-module-rtmp`
- `angie-module-set-misc`
- `angie-module-subs`
- `angie-module-testcookie`
- `angie-module-unbrotli`
- `angie-module-upload`
- `angie-module-vod`
- `angie-module-vts`
- `angie-module-wasm`
- `angie-module-wasmtime`
- `angie-module-xslt`
- `angie-module-zip`
- `angie-module-zstd`

<a id="running"></a>

## Execução

Para iniciar um contêiner com Angie na porta 8080,
fornecendo acesso somente leitura ao diretório de arquivos estáticos `/var/www/`
e ao arquivo de configuração `angie.conf` localizado no diretório de trabalho atual:

```console
$ docker run --rm --name angie -v /var/www:/usr/share/angie/html:ro \
    -v $(pwd)/angie.conf:/etc/angie/angie.conf:ro -p 8080:80 -d docker.angie.software/angie:latest

$ curl -I localhost:8080

    HTTP/1.1 200 OK
    Server: Angie/|version|
    Date: |sampledatelong| 10:42:54 GMT
    Content-Type: text/html
    Content-Length: 543
    Last-Modified: |sampledatelong| 09:12:23 GMT
    Connection: keep-alive
    ETag: "64c3ccc7-21f"
    Accept-Ranges: bytes
```

Tais configurações são adequadas para desenvolvimento local e configuração.

<a id="building-custom-images"></a>

## Construindo Imagens Personalizadas

Você também pode construir sua própria imagem
baseada em uma distribuição suportada,
adicionando a camada do Angie a partir de [pacotes](https://pt.angie.software//angie/docs/installation/oss_packages.md#oss-packages)
ou [código-fonte](https://pt.angie.software//angie/docs/installation/sourcebuild.md#sourcebuild).
Exemplos de arquivos `Dockerfile` correspondentes:

```dockerfile
FROM debian:13

LABEL org.opencontainers.image.authors="Release Engineering Team <devops@tech.wbsrv.ru>"

ARG DEBIAN_FRONTEND=noninteractive

RUN set -x \
     && apt-get update \
     && apt-get install --no-install-recommends --no-install-suggests -y \
          ca-certificates curl \
     && curl -o /etc/apt/trusted.gpg.d/angie-signing.gpg \
          https://angie.software/keys/angie-signing.gpg \
     && echo "deb https://download.angie.software/angie/$(. /etc/os-release && echo "$ID/$VERSION_ID $VERSION_CODENAME") main" \
          > /etc/apt/sources.list.d/angie.list \
     && apt-get update \
     && apt-get install --no-install-recommends --no-install-suggests -y \
          angie angie-module-geoip2 angie-module-njs \
     && rm -Rf /var/lib/apt/lists \
          /etc/apt/sources.list.d/angie.list \
          /etc/apt/trusted.gpg.d/angie-signing.gpg \
     && ln -sf /dev/stdout /var/log/angie/access.log \
     && ln -sf /dev/stderr /var/log/angie/error.log

EXPOSE 80

CMD ["angie", "-g", "daemon off;"]
```

```dockerfile
FROM alpine:3.22

LABEL org.opencontainers.image.authors="Release Engineering Team <devops@tech.wbsrv.ru>"

RUN set -x \
     && apk add --no-cache ca-certificates curl \
     && curl -o /etc/apk/keys/angie-signing.rsa https://angie.software/keys/angie-signing.rsa \
     && echo "https://download.angie.software/angie/alpine/v$(egrep -o \
          '[0-9]+\.[0-9]+' /etc/alpine-release)/main" >> /etc/apk/repositories \
     && apk add --no-cache angie angie-module-geoip2 angie-module-njs \
     && rm /etc/apk/keys/angie-signing.rsa \
     && ln -sf /dev/stdout /var/log/angie/access.log \
     && ln -sf /dev/stderr /var/log/angie/error.log

EXPOSE 80

CMD ["angie", "-g", "daemon off;"]
```

Para construir uma imagem `myangie` no diretório com tal `Dockerfile`
e iniciar um contêiner como mostrado acima:

```console
$ docker build -t myangie .
$ docker run --rm --name myangie -v /var/www:/usr/share/angie/html:ro \
    -v $(pwd)/angie.conf:/etc/angie/angie.conf:ro -p 8080:80 -d myangie
```
