Найти в Дзене
ИТ разнообразно

Развёртывание мультиконтейнерного приложения с использованием Podman и Quadlet. Часть 5.

Настраиваем WordPress (продолжение)

Вы можете настроить Envoy Proxy с помощью ConfigMap, определённого в отдельном файле YAML с именем envoy-proxy-configmap.yml:

apiVersion: v1
kind: ConfigMap
metadata:
name: envoy-proxy-config
data:
envoy.yaml: |
admin:
address:
socket_address:
address: 0.0.0.0
port_value: 9901
static_resources:
listeners:
- name: listener_0
address:
socket_address:
address: 0.0.0.0
port_value: 8080
filter_chains:
- filters:
- name: envoy.filters.network.http_connection_manager
typed_config:
"@type": type.googleapis.com/envoy.extensions.filters.network.http_connection_manager.v3.HttpConnectionManager
stat_prefix: ingress_http
codec_type: AUTO
route_config:
name: local_route
virtual_hosts:
- name: local_service
domains: ["*"]
routes:
- match:
prefix: "/"
route:
cluster: backend
http_filters:
- name: envoy.filters.http.router
typed_config:
"@type": type.googleapis.com/envoy.extensions.filters.http.router.v3.Router
transport_socket:
name: envoy.transport_sockets.tls
typed_config:
"@type": type.googleapis.com/envoy.extensions.transport_sockets.tls.v3.DownstreamTlsContext
common_tls_context:
tls_certificates:
- certificate_chain:
filename: /etc/envoy-certificates/certificate.pem
private_key:
filename: /etc/envoy-certificates/certificate.key
clusters:
- name: backend
connect_timeout: 5s
type: STATIC
dns_refresh_rate: 1800s
lb_policy: ROUND_ROBIN
load_assignment:
cluster_name: backend
endpoints:
- lb_endpoints:
- endpoint:
address:
socket_address:
address: 127.0.0.1
port_value: 80

Когда у вас будут готовы все файлы конфигурации пода, вы можете связать их вместе, используя файл Quadlet .kube, quadlet-demo.kube:

[Install]
WantedBy=default.target
[Unit]
Requires=quadlet-demo-mysql.service
After=quadlet-demo-mysql.service
[Kube]
# Point to the yaml file in the same directory
Yaml=quadlet-demo.yml
# Use the quadlet-demo network
Network=quadlet-demo.network
# Publish the envoy proxy data port
PublishPort=8000:8080
# Publish the envoy proxy admin port
PublishPort=9000:9901
# Use the envoy proxy config map in the same directory
ConfigMap=envoy-proxy-configmap.yml

Раздел Kube устанавливает следующие ключи:

  • Yaml: задаём YAML-файл Kubernetes
  • Network: задаём имя сети для ранее определённого файла .network, предписывая Quadlet создать зависимость systemd между юнит-файлами
  • PublishPort: задаём сопоставление TCP-портов для каждого контейнера

- порт приложения 8080 в контейнере WordPress публикуется на порту 8000

- административный порт Envoy 9901 публикуется на порту 9000

  • ConfigMap: загружаем ConfigMap, определённый в дополнительном YAML-файле Kubernetes.

Обратите внимание, что Quadlet поддерживает пути относительно местоположения юнит-файла. Таким образом, значения ключей Yaml и ConfigMap указывают на файлы, которые находятся в том же каталоге, что и юнит-файл.

Кроме того, поскольку приложению WordPress требуется служба базы данных, этот юнит зависит от службы, созданной юнитом .container. Для достижения этой цели этот юнит-файл устанавливает зависимость Requires для соответствующего юнита службы базы данных вместо юнита контейнера.

Продолжение следует...

Перевод с некоторыми авторскими заголовками.

Автор оригинала: Ygal Blum (Red Hat).