Файлы MySQL Init SQL не монтируются

#mysql #kubernetes

#mysql #kubernetes

Вопрос:

У меня есть база данных MySQL в Kubernetes. Что я хочу сделать, так это запустить несколько SQL-скриптов для настройки базы данных. Я пытался смонтировать каталог хоста /docker-entrypoint-initdb.d , но когда я пытаюсь просмотреть содержимое этого каталога, он кажется пустым. Мой файл развертывания выглядит следующим образом:

 apiVersion: apps/v1
kind: Deployment
metadata:
  name: db
  labels:
    app: db
spec:
  replicas: 1
  selector:
    matchLabels:
      app: db
  template:
    metadata:
      labels:
        app: db
    spec:
      containers:
        - name: mysql
          image: mysql:5.7.31
          ports:
            - containerPort: 3306
          volumeMounts:
            - mountPath: /docker-entrypoint-initdb.d/
              name: initdb
            - mountPath: /var/lib/mysql
              subPath: mysql
              name: db-data
          env:
            - name: MYSQL_ROOT_PASSWORD
              valueFrom:
                secretKeyRef:
                  name: db-secrets
                  key: ROOT_PASSWORD
      volumes:
        - name: db-data
          persistentVolumeClaim:
            claimName: db-data-disk-claim
        - name: initdb
          hostPath:
            path: /home/fer/web/db/sqlscripts
            type: Directory
  

Комментарии:

1. Где вы храните SQL-скрипт?

Ответ №1:

Неважно, я решил это, создав ConfigMap и смонтировав его как том.

Я оставляю это здесь для дальнейшего использования