Использование хранилища файлов Azure с kubernetes и службой контейнеров Azure (aks) - разрешение запрещено
У меня есть кластер службы Azure Container (AKS). Переносится до версии 1.8.1. Я пытаюсь развернуть базу данных Postgres и использовать AzureFileVolume
сохранить данные postgres.
По умолчанию, если я развертываю базу данных postgres без монтирования тома, все работает как исключение, то есть создается модуль pod и инициализируется база данных.
Когда я пытаюсь смонтировать том, используя приведенный ниже yaml, я получаю initdb: не удалось получить доступ к каталогу "/var/lib/postgresql/data": разрешение отклонено.
Я пробовал различные способы взлома, как было предложено в этом длинном потоке github, например: установка контекста безопасности для модуля или запуск команд chown в initContainers. Результат был тот же - разрешение отказано.
Любые идеи были бы хорошы.
apiVersion: v1
kind: Service
metadata:
labels:
app: myapp
component: test-db
name: test-db
spec:
ports:
- port: 5432
selector:
app: myapp
component: test-db
---
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: test-db
spec:
template:
metadata:
labels:
app: myapp
component: test-db
spec:
securityContext:
fsGroup: 999
runAsUser: 999
containers:
- name: test-db
image: postgres:latest
securityContext:
allowPrivilegeEscalation: false
ports:
- containerPort: 5432
env:
- name: POSTGRES_DB
value: myappdb
- name: POSTGRES_USER
value: myappdbuser
- name: POSTGRES_PASSWORD
value: qwerty1234
volumeMounts:
- name: azure
mountPath: /var/lib/postgresql/data
volumes:
- name: azure
azureFile:
secretName: azure-secret
shareName: acishare
readOnly: false
1 ответ
Мы столкнулись с такими же проблемами и нашли следующее решение:
Вместо использования AzureFileVolume мы использовали AzureDisk. Итак, что нам нужно в Kubernetes, это следующее...
Класс хранения
С именем вашей учетной записи Azure
Постоянное требование объема
Развертывание PostgreSQL Включите PVC в Развертывание Kubernetes
- name: postgres-db
persistentVolumeClaim:
claimName: pvc-postgresdb
Кроме того, нам нужно указать PGDATA var на подкаталог смонтированного каталога. Потому что Azure создает некоторые проблемы с типом AzureDisk в базовом каталоге.
#... evn definitions...
- name: PGDATA
value: /var/lib/postgresql/data/pgdata
volumeMounts:
- mountPath: /var/lib/postgresql/data/
name: postgres-db
Это не будет работать, вам нужно использовать диски Azure, потому что postgres использует жесткие ссылки, которые не поддерживаются файлами https://github.com/docker-library/postgres/issues/548