как сохранить брелок в кубернетес пользовательских темах - PullRequest
0 голосов
/ 07 марта 2020

Я пытался сохранить пользовательские темы через gcepersistentdisk, но когда я вхожу в консоль администрирования, она ничего не загружает, и проверка папки /opt/jboss/keycloak/themes пуста.

Также попробуйте создать пользовательскую docker image (Dockerfile), добавив следующую строку для копирования пользовательских тем.

COPY /source-folder/login /opt/jboss/keycloak/themes/login

, хотя в папке /opt/jboss/keycloak/themes я вижу новую папку входа в систему, когда я получаю доступ консоль администрирования. Я не вижу входа в пользовательскую тему.

Я могу просматривать пользовательскую тему только при выполнении следующих команд kube rnet:

  1. kubectl exec POD --namespace keycloak - mkdir /opt/jboss/keycloak/themes/login

  2. kubectl cp keycloak/login keycloak/POD:/opt/jboss/keycloak/themes/login

С помощью предыдущих команд, если я вижу пользовательскую тему, войдите в консоль администрирования

Я попытался использовать gcePersistentDisk следующим образом:

spec:
  containers:
    - name: keycloak
   ...
   volumeMounts:
     - mountPath: /opt/jboss/keycloak/themes
       name: test-volume

  volumes:
    - name: test-volume
      gcePersistentDisk:
        pdName: pd-name
        fsType: ext4

Каким образом я могу сохранить пользовательские темы при перезагрузке модуля?

Ответы [ 2 ]

1 голос
/ 09 марта 2020

Как я понимаю, каждая тема должна иметь собственную папку. Это должно быть themes/mytheme/login вместо themes/login. Например, ваша локальная структура может выглядеть следующим образом:

Dockerfile
themes
|-mytheme
  |-account
  |-admin
  |-login
    |-resources 
      |-css
      |-img
    |-theme.properties
  |-welcome

Docker файл может выглядеть следующим образом:

FROM jboss/keycloak:8.0.1
ADD ./themes /opt/jboss/keycloak/themes/

Создать docker образ, запустить, затем go в Realm Settings -> Themes и выберите свою тему.

0 голосов
/ 07 марта 2020

Создание StorageClass и PersistentVolumeClaim

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: nfs-pvc
spec:
  accessModes:
    - ReadWriteOnce
  storageClassName: ssd-sc  # specify the storage class created below
  resources:
    requests:
      storage: 10Gi

---

apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
  name: ssd-sc 
provisioner: kubernetes.io/gce-pd
reclaimPolicy: Retain # Retain storage even if we delete PVC
parameters:
  type: pd-ssd # ssd

Создание модуля для использования PersistentVolumeClaim

apiVersion: v1
kind: Pod
metadata:
  name: task-pv-pod
spec:
  volumes:
    - name: task-pv-storage
      persistentVolumeClaim:
        claimName: nfs-pvc
  containers:
    - name: task-pv-container
      image: nginx
      ports:
        - containerPort: 80
          name: "http-server"
      volumeMounts:
        - mountPath: "/usr/share/nginx/html"
          name: task-pv-storage
...