114 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
version: "3.7"
 | 
						|
 | 
						|
services:
 | 
						|
  immich:
 | 
						|
    container_name: immich
 | 
						|
    image: ghcr.io/immich-app/immich-server:v1.100.0
 | 
						|
    command: ["start-server.sh"]
 | 
						|
    volumes:
 | 
						|
      - ${ROOT_FOLDER_HOST}/media/data/images/immich:/usr/src/app/upload
 | 
						|
    environment:
 | 
						|
      - NODE_ENV=production
 | 
						|
      - DB_HOSTNAME=immich-db
 | 
						|
      - DB_USERNAME=tipi
 | 
						|
      - DB_PASSWORD=${DB_PASSWORD}
 | 
						|
      - ENABLE_MAPBOX=false
 | 
						|
      - DB_DATABASE_NAME=immich
 | 
						|
      - REDIS_HOSTNAME=immich-redis
 | 
						|
      - JWT_SECRET=${JWT_SECRET}
 | 
						|
    depends_on:
 | 
						|
      - immich-redis
 | 
						|
      - immich-db
 | 
						|
    ports:
 | 
						|
      - ${APP_PORT}:3001
 | 
						|
    restart: unless-stopped
 | 
						|
    networks:
 | 
						|
      - tipi_main_network
 | 
						|
    labels:
 | 
						|
      # Main
 | 
						|
      traefik.enable: true
 | 
						|
      traefik.http.middlewares.immich-web-redirect.redirectscheme.scheme: https
 | 
						|
      traefik.http.services.immich.loadbalancer.server.port: 3001
 | 
						|
      # Web
 | 
						|
      traefik.http.routers.immich-insecure.rule: Host(`${APP_DOMAIN}`)
 | 
						|
      traefik.http.routers.immich-insecure.entrypoints: web
 | 
						|
      traefik.http.routers.immich-insecure.service: immich
 | 
						|
      traefik.http.routers.immich-insecure.middlewares: immich-web-redirect
 | 
						|
      # Websecure
 | 
						|
      traefik.http.routers.immich.rule: Host(`${APP_DOMAIN}`)
 | 
						|
      traefik.http.routers.immich.entrypoints: websecure
 | 
						|
      traefik.http.routers.immich.service: immich
 | 
						|
      traefik.http.routers.immich.tls.certresolver: myresolver
 | 
						|
      # Local domain
 | 
						|
      traefik.http.routers.immich-local-insecure.rule: Host(`immich.${LOCAL_DOMAIN}`)
 | 
						|
      traefik.http.routers.immich-local-insecure.entrypoints: web
 | 
						|
      traefik.http.routers.immich-local-insecure.service: immich
 | 
						|
      traefik.http.routers.immich-local-insecure.middlewares: immich-web-redirect
 | 
						|
      # Local domain secure
 | 
						|
      traefik.http.routers.immich-local.rule: Host(`immich.${LOCAL_DOMAIN}`)
 | 
						|
      traefik.http.routers.immich-local.entrypoints: websecure
 | 
						|
      traefik.http.routers.immich-local.service: immich
 | 
						|
      traefik.http.routers.immich-local.tls: true
 | 
						|
 | 
						|
  immich-microservices:
 | 
						|
    container_name: immich-microservices
 | 
						|
    image: ghcr.io/immich-app/immich-server:v1.100.0
 | 
						|
    command: ["start-microservices.sh"]
 | 
						|
    volumes:
 | 
						|
      - ${ROOT_FOLDER_HOST}/media/data/images/immich:/usr/src/app/upload
 | 
						|
    environment:
 | 
						|
      - NODE_ENV=production
 | 
						|
      - DB_HOSTNAME=immich-db
 | 
						|
      - DB_USERNAME=tipi
 | 
						|
      - DB_PASSWORD=${DB_PASSWORD}
 | 
						|
      - DB_DATABASE_NAME=immich
 | 
						|
      - REDIS_HOSTNAME=immich-redis
 | 
						|
      - JWT_SECRET=${JWT_SECRET}
 | 
						|
      - ENABLE_MAPBOX=false
 | 
						|
    depends_on:
 | 
						|
      - immich-redis
 | 
						|
      - immich-db
 | 
						|
    restart: unless-stopped
 | 
						|
    networks:
 | 
						|
      - tipi_main_network
 | 
						|
 | 
						|
  immich-machine-learning:
 | 
						|
    container_name: immich-machine-learning
 | 
						|
    image: ghcr.io/immich-app/immich-machine-learning:v1.100.0
 | 
						|
    volumes:
 | 
						|
      - ${ROOT_FOLDER_HOST}/media/data/images/immich:/usr/src/app/upload
 | 
						|
      - ${APP_DATA_DIR}/data/immich-ml-cache:/cache
 | 
						|
    environment:
 | 
						|
      - NODE_ENV=production
 | 
						|
      - DB_HOSTNAME=immich-db
 | 
						|
      - DB_USERNAME=tipi
 | 
						|
      - DB_PASSWORD=${DB_PASSWORD}
 | 
						|
      - DB_NAME=immich
 | 
						|
      - DB_DATABASE_NAME=immich
 | 
						|
    depends_on:
 | 
						|
      - immich-db
 | 
						|
    restart: unless-stopped
 | 
						|
    networks:
 | 
						|
      - tipi_main_network
 | 
						|
 | 
						|
  immich-redis:
 | 
						|
    container_name: immich-redis
 | 
						|
    image: redis:6.2
 | 
						|
    restart: unless-stopped
 | 
						|
    networks:
 | 
						|
      - tipi_main_network
 | 
						|
 | 
						|
  immich-db:
 | 
						|
    container_name: immich-db
 | 
						|
    image: tensorchord/pgvecto-rs:pg14-v0.2.0@sha256:90724186f0a3517cf6914295b5ab410db9ce23190a2d9d0b9dd6463e3fa298f0
 | 
						|
    environment:
 | 
						|
      POSTGRES_PASSWORD: ${DB_PASSWORD}
 | 
						|
      POSTGRES_USER: tipi
 | 
						|
      POSTGRES_DB: immich
 | 
						|
      PG_DATA: /var/lib/postgresql/data
 | 
						|
    volumes:
 | 
						|
      - ${APP_DATA_DIR}/data/db:/var/lib/postgresql/data
 | 
						|
    restart: unless-stopped
 | 
						|
    networks:
 | 
						|
      - tipi_main_network
 |