docker-compose.yml 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. version: '3.9'
  2. services:
  3. keycloak:
  4. build:
  5. context: .
  6. dockerfile: keycloak.Containerfile
  7. args:
  8. KC_DB_USERNAME: ${KC_DB_USERNAME}
  9. KC_DB_PASSWORD: ${KC_DB_PASSWORD}
  10. container_name: keycloak
  11. environment:
  12. KC_DB: postgres
  13. KC_DB_URL: jdbc:postgresql://keycloak-db:5432/keycloak
  14. KC_DB_USERNAME: ${KC_DB_USERNAME}
  15. KC_DB_PASSWORD: ${KC_DB_PASSWORD}
  16. KC_PROXY_HEADERS: xforwarded
  17. KC_PROXY_ADDRESS_FORWARDING: "true"
  18. KC_HTTP_ENABLED: "true"
  19. KC_HOSTNAME_STRICT: "false"
  20. KC_PROXY: edge
  21. KC_FEATURES: "token-exchange,scripts,preview,admin-api"
  22. KC_HEALTH_ENABLED: "true"
  23. KC_METRICS_ENABLED: "true"
  24. KC_HOSTNAME: https://auth.mrx8086.com
  25. KC_BOOTSTRAP_ADMIN_USERNAME: admin
  26. KC_BOOTSTRAP_ADMIN_PASSWORD: ${KEYCLOAK_ADMIN_PASSWORD}
  27. command: ["start-dev"] # Für Entwicklung; entferne "-dev" für Produktion
  28. ports:
  29. - "8080:8080"
  30. volumes:
  31. - ../config/keycloak/themes:/opt/keycloak/themes:ro
  32. networks:
  33. - keycloak-network
  34. depends_on:
  35. - keycloak-db
  36. extra_hosts:
  37. - "cloud.mrx8086.com:172.23.171.133"
  38. healthcheck:
  39. test: ["CMD", "curl", "-f", "http://localhost:8080/health"]
  40. interval: 30s
  41. timeout: 10s
  42. retries: 3
  43. keycloak-db:
  44. image: postgres:15
  45. container_name: keycloak-db
  46. environment:
  47. POSTGRES_DB: keycloak
  48. POSTGRES_USER: ${KC_DB_USERNAME}
  49. POSTGRES_PASSWORD: ${KC_DB_PASSWORD}
  50. volumes:
  51. - ../data/keycloak-db:/var/lib/postgresql/data
  52. networks:
  53. - keycloak-network
  54. restart: unless-stopped
  55. healthcheck:
  56. test: ["CMD-SHELL", "pg_isready -U ${KC_DB_USERNAME} -d keycloak"]
  57. interval: 10s
  58. timeout: 5s
  59. retries: 5
  60. # In docker-compose.yml ergänzen:
  61. nextcloud:
  62. image: nextcloud:latest
  63. container_name: nextcloud
  64. restart: unless-stopped
  65. ports:
  66. - "8081:80"
  67. volumes:
  68. - ../data/nextcloud:/var/www/html
  69. - ../config/nextcloud/config:/var/www/html/config
  70. - ../config/nextcloud/custom_apps:/var/www/html/custom_apps
  71. - ../data/nextcloud-db:/var/lib/mysql
  72. environment:
  73. - MYSQL_HOST=nextcloud-db
  74. - MYSQL_DATABASE=nextcloud
  75. - MYSQL_USER=${NEXTCLOUD_DB_USER}
  76. - MYSQL_PASSWORD=${NEXTCLOUD_DB_PASSWORD}
  77. - NEXTCLOUD_ADMIN_USER=${NEXTCLOUD_ADMIN_USER}
  78. - NEXTCLOUD_ADMIN_PASSWORD=${NEXTCLOUD_ADMIN_PASSWORD}
  79. - NEXTCLOUD_TRUSTED_DOMAINS=cloud.mrx8086.com
  80. - OVERWRITEPROTOCOL=https
  81. - OVERWRITEHOST=cloud.mrx8086.com
  82. - OVERWRITEWEBROOT=/
  83. - TRUSTED_PROXIES=172.19.0.0/16
  84. - NEXTCLOUD_URL=https://cloud.mrx8086.com
  85. - NEXTCLOUD_DEBUG=1
  86. - NEXTCLOUD_CONFIG_CUSTOM_SCOPE="openid profile groups-nextcloud"
  87. healthcheck:
  88. test: ["CMD", "curl", "-f", "http://localhost:80/"]
  89. interval: 30s
  90. timeout: 10s
  91. retries: 3
  92. networks:
  93. - nextcloud-network
  94. depends_on:
  95. - nextcloud-db
  96. extra_hosts:
  97. - "auth.mrx8086.com:172.23.171.133"
  98. dns:
  99. - 8.8.8.8
  100. - 8.8.4.4
  101. nextcloud-db:
  102. image: mariadb:10.6
  103. container_name: nextcloud-db
  104. restart: unless-stopped
  105. command: --transaction-isolation=READ-COMMITTED --log-bin=ROW
  106. environment:
  107. - MYSQL_ROOT_PASSWORD=${NEXTCLOUD_DB_ROOT_PASSWORD}
  108. - MYSQL_DATABASE=nextcloud
  109. - MYSQL_USER=${NEXTCLOUD_DB_USER}
  110. - MYSQL_PASSWORD=${NEXTCLOUD_DB_PASSWORD}
  111. volumes:
  112. - ../data/nextcloud-db:/var/lib/mysql
  113. networks:
  114. - nextcloud-network
  115. paperless:
  116. image: ghcr.io/paperless-ngx/paperless-ngx:latest
  117. container_name: paperless
  118. restart: unless-stopped
  119. ports:
  120. - "8000:8000"
  121. volumes:
  122. - ../data/paperless:/usr/src/paperless/data
  123. - ../config/paperless/media:/usr/src/paperless/media
  124. - ../config/paperless/export:/usr/src/paperless/export
  125. - ../config/paperless/consume:/usr/src/paperless/consume
  126. environment:
  127. # Basis-Konfiguration
  128. - PAPERLESS_ADMIN_USER=${PAPERLESS_ADMIN_USER}
  129. - PAPERLESS_ADMIN_PASSWORD=${PAPERLESS_ADMIN_PASSWORD}
  130. - PAPERLESS_SECRET_KEY=${PAPERLESS_SECRET_KEY}
  131. - PAPERLESS_URL=https://docs.mrx8086.com
  132. - PAPERLESS_ALLOWED_HOSTS=docs.mrx8086.com
  133. - PAPERLESS_REDIS=redis://paperless-redis:6379
  134. - PAPERLESS_LOGGING_DIR=/dev/stdout
  135. - PAPERLESS_LOGGING_LEVEL=DEBUG
  136. - DJANGO_LOG_LEVEL=DEBUG
  137. # OIDC Basis-Einstellungen
  138. - PAPERLESS_ENABLE_OIDC=true
  139. - PAPERLESS_OIDC_RP_PROVIDER_URL=https://auth.mrx8086.com/realms/office-automation
  140. - PAPERLESS_OIDC_RP_CLIENT_ID=paperless
  141. - PAPERLESS_OIDC_RP_CLIENT_SECRET=${PAPERLESS_CLIENT_SECRET}
  142. # OIDC Endpoints
  143. - PAPERLESS_OIDC_AUTH_ENDPOINT=https://auth.mrx8086.com/realms/office-automation/protocol/openid-connect/auth
  144. - PAPERLESS_OIDC_TOKEN_ENDPOINT=https://auth.mrx8086.com/realms/office-automation/protocol/openid-connect/token
  145. - PAPERLESS_OIDC_USERINFO_ENDPOINT=https://auth.mrx8086.com/realms/office-automation/protocol/openid-connect/userinfo
  146. - PAPERLESS_OIDC_JWKS_ENDPOINT=https://auth.mrx8086.com/realms/office-automation/protocol/openid-connect/certs
  147. # OIDC Claims und Scopes
  148. - PAPERLESS_OIDC_RP_SCOPE=openid profile email
  149. - PAPERLESS_OIDC_RP_USERNAME_CLAIM=preferred_username
  150. - PAPERLESS_OIDC_RP_NAME_CLAIM=name
  151. - PAPERLESS_OIDC_RP_EMAIL_CLAIM=email
  152. # OIDC Sicherheitseinstellungen
  153. - PAPERLESS_OIDC_RP_SIGN_ALGO=RS256
  154. - PAPERLESS_OIDC_RP_VERIFY_SSL=false
  155. - PAPERLESS_OIDC_USE_PKCE=true
  156. # OIDC Token-Management
  157. - PAPERLESS_OIDC_RP_RENEW_TOKEN_BEFORE_EXPIRY=true
  158. depends_on:
  159. - paperless-db
  160. - paperless-redis
  161. networks:
  162. - paperless-network
  163. extra_hosts:
  164. - "auth.mrx8086.com:172.23.171.133"
  165. healthcheck:
  166. test: ["CMD", "curl", "-f", "http://localhost:8000/"]
  167. interval: 30s
  168. timeout: 10s
  169. retries: 3
  170. paperless-db:
  171. image: postgres:15
  172. container_name: paperless-db
  173. restart: unless-stopped
  174. environment:
  175. POSTGRES_USER: ${PAPERLESS_DB_USER}
  176. POSTGRES_PASSWORD: ${PAPERLESS_DB_PASSWORD}
  177. POSTGRES_DB: paperless
  178. volumes:
  179. - ../data/paperless-db:/var/lib/postgresql/data
  180. networks:
  181. - paperless-network
  182. healthcheck:
  183. test: ["CMD-SHELL", "pg_isready -U ${PAPERLESS_DB_USER} -d paperless"]
  184. interval: 10s
  185. timeout: 5s
  186. retries: 5
  187. paperless-redis:
  188. image: redis:7
  189. container_name: paperless-redis
  190. restart: unless-stopped
  191. networks:
  192. - paperless-network
  193. healthcheck:
  194. test: ["CMD", "redis-cli", "ping"]
  195. interval: 10s
  196. timeout: 5s
  197. retries: 5
  198. networks:
  199. keycloak-network:
  200. driver: bridge
  201. nextcloud-network:
  202. driver: bridge
  203. paperless-network:
  204. driver: bridge