74 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| version: "3.7"
 | |
| 
 | |
| services:
 | |
|   halo:
 | |
|     image: halohub/halo:2.15.0
 | |
|     container_name: halo
 | |
|     restart: unless-stopped
 | |
|     depends_on:
 | |
|       halodb:
 | |
|         condition: service_healthy
 | |
|     networks:
 | |
|       - tipi_main_network
 | |
|     volumes:
 | |
|       - ${APP_DATA_DIR}:/root/.halo2
 | |
|     ports:
 | |
|       - ${APP_PORT}:8090
 | |
|     healthcheck:
 | |
|       test:
 | |
|         ["CMD", "curl", "-f", "http://localhost:8090/actuator/health/readiness"]
 | |
|       interval: 30s
 | |
|       timeout: 5s
 | |
|       retries: 5
 | |
|       start_period: 30s
 | |
|     command:
 | |
|       - --spring.r2dbc.url=r2dbc:pool:postgresql://halodb/halo
 | |
|       - --spring.r2dbc.username=halo
 | |
|       - --spring.r2dbc.password=${HALO_DATABASE_PASSWORD}
 | |
|       - --spring.sql.init.platform=postgresql
 | |
|       - --halo.external-url=${HALO_EXTERNAL_URL}
 | |
|     labels:
 | |
|       # Main
 | |
|       traefik.enable: true
 | |
|       traefik.http.middlewares.halo-web-redirect.redirectscheme.scheme: https
 | |
|       traefik.http.services.halo.loadbalancer.server.port: 8090
 | |
|       # Web
 | |
|       traefik.http.routers.halo-insecure.rule: Host(`${APP_DOMAIN}`)
 | |
|       traefik.http.routers.halo-insecure.entrypoints: web
 | |
|       traefik.http.routers.halo-insecure.service: halo
 | |
|       traefik.http.routers.halo-insecure.middlewares: halo-web-redirect
 | |
|       # Websecure
 | |
|       traefik.http.routers.halo.rule: Host(`${APP_DOMAIN}`)
 | |
|       traefik.http.routers.halo.entrypoints: websecure
 | |
|       traefik.http.routers.halo.service: halo
 | |
|       traefik.http.routers.halo.tls.certresolver: myresolver
 | |
|       # Local domain
 | |
|       traefik.http.routers.halo-local-insecure.rule: Host(`halo.${LOCAL_DOMAIN}`)
 | |
|       traefik.http.routers.halo-local-insecure.entrypoints: web
 | |
|       traefik.http.routers.halo-local-insecure.service: halo
 | |
|       traefik.http.routers.halo-local-insecure.middlewares: halo-web-redirect
 | |
|       # Local domain secure
 | |
|       traefik.http.routers.halo-local.rule: Host(`halo.${LOCAL_DOMAIN}`)
 | |
|       traefik.http.routers.halo-local.entrypoints: websecure
 | |
|       traefik.http.routers.halo-local.service: halo
 | |
|       traefik.http.routers.halo-local.tls: true
 | |
| 
 | |
|   halodb:
 | |
|     image: postgres:latest
 | |
|     container_name: halodb
 | |
|     restart: unless-stopped
 | |
|     networks:
 | |
|       - tipi_main_network
 | |
|     volumes:
 | |
|       - ${APP_DATA_DIR}/db:/var/lib/postgresql/data
 | |
|     healthcheck:
 | |
|       test: ["CMD", "pg_isready"]
 | |
|       interval: 10s
 | |
|       timeout: 5s
 | |
|       retries: 5
 | |
|     environment:
 | |
|       - POSTGRES_PASSWORD=${HALO_DATABASE_PASSWORD}
 | |
|       - POSTGRES_USER=halo
 | |
|       - POSTGRES_DB=halo
 | |
|       - PGUSER=halo
 | 
![renovate[bot]](/assets/img/avatar_default.png)