๐Ÿ“ฆ LuisSanchez / users-prototype

๐Ÿ“„ docker-compose.yml ยท 99 lines
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99services:
  user-service:
    networks:
      - app_net
    build:
      context: ./User
      dockerfile: Dockerfile
    ports:
      - "5050:80"
      - "7150:443"
    environment:
      - ASPNETCORE_ENVIRONMENT=Development
      - ASPNETCORE_URLS=http://+:80
      - ConnectionStrings__DefaultConnection=Host=db;Port=5432;Database=userdb;Username=postgres;Password=postgres
    volumes:
      - ./data/keys:/keys
    env_file: User/.env
    depends_on:
      db:
        condition: service_healthy
      keycloak:
        condition: service_healthy

  db:
    image: postgres:16
    environment:
      POSTGRES_PASSWORD: postgres
      POSTGRES_USER: postgres
      POSTGRES_DB: userdb
    volumes:
      - postgres_data:/var/lib/postgresql/data
    ports:
      - "5433:5432"
    healthcheck:
      test: ["CMD-SHELL", "pg_isready -U postgres"]
      interval: 5s
      timeout: 5s
      retries: 5

  keycloak-db:
    image: postgres:16
    networks:
      - app_net
    environment:
      POSTGRES_USER: keycloak
      POSTGRES_PASSWORD: password
      POSTGRES_DB: keycloak
    volumes:
      - keycloak_db_data:/var/lib/postgresql/data
    healthcheck:
      test: ["CMD-SHELL", "pg_isready -U keycloak -d keycloak && psql -U keycloak -d keycloak -c 'SELECT 1' -t -v ON_ERROR_STOP=1"]
      interval: 5s
      timeout: 5s
      retries: 10

  keycloak:
    networks:
      - app_net
    image: quay.io/keycloak/keycloak:24.0
    command: 
      - "start-dev"
      - "--import-realm"
    healthcheck:
      test: ["CMD", "curl", "-f", "http://localhost:8080"]
      interval: 20s
      timeout: 10s
      retries: 5
    volumes:
      - ./keycloak-realm.json:/opt/keycloak/data/import/realm.json
    environment:
      QUARKUS_DATASOURCE_JDBC_URL: "jdbc:postgresql://keycloak-db:5432/keycloak?sslmode=disable&connectTimeout=5&socketTimeout=5"
      QUARKUS_DATASOURCE_JDBC_MIN_SIZE: "2"
      QUARKUS_DATASOURCE_JDBC_MAX_SIZE: "10"
      QUARKUS_DATASOURCE_USERNAME: keycloak
      QUARKUS_DATASOURCE_PASSWORD: password
      QUARKUS_DATASOURCE_DB_KIND: postgresql
      KEYCLOAK_ADMIN: admin
      KEYCLOAK_ADMIN_PASSWORD: admin
      KC_DB_INITIALIZE: "true"
      KC_TRANSACTION_XA_ENABLED: "false"
      QUARKUS_DATASOURCE_JDBC_RECONNECT_INTERVAL: "2s"
      QUARKUS_DATASOURCE_JDBC_RECONNECT_ATTEMPTS: "10"
      QUARKUS_DATASOURCE_JDBC_VALIDATION_QUERY_SQL: "SELECT 1"
      QUARKUS_DATASOURCE_JDBC_VALIDATION_TIMEOUT: "5s"
      JAVA_OPTS: "-Dkc.db.tx.xa-enabled=false -Dkc.db.connections-initial-size=2 -Dkc.db.connections-min-size=2"
    ports:
      - "8080:8080"
    depends_on:
      keycloak-db:
        condition: service_healthy

volumes:
  postgres_data:
  keycloak_db_data:

networks:
  app_net:
    driver: bridge