Compare commits
26 Commits
9f2d13bb51
...
main
Author | SHA1 | Date | |
---|---|---|---|
9025095cb0 | |||
efdc27e656 | |||
aa1c322bc9 | |||
c2e764ff62 | |||
32c28679d1 | |||
5f74753fdd | |||
713ef01ae8 | |||
5c0ed779d7 | |||
5cf33759c3 | |||
c3ca071a01 | |||
36e6e7bfac | |||
e2b3e6e9fd | |||
e6659dbfb4 | |||
b0ddb3105f | |||
f1b7c9c1c7 | |||
9de06cb3f5 | |||
60bcd620b6 | |||
75f19faf69 | |||
a076a1781a | |||
8b7f9dfdda | |||
1d03defa2b | |||
404fe19226 | |||
a2422b948e | |||
e22d4ab79c | |||
b43600aa8c | |||
99c75da940 |
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
.DS_Store
|
@ -1,8 +0,0 @@
|
|||||||
{
|
|
||||||
"folders": [
|
|
||||||
{
|
|
||||||
"path": "."
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"settings": {}
|
|
||||||
}
|
|
@ -1,72 +0,0 @@
|
|||||||
#
|
|
||||||
# WARNING: Make sure to use the docker-compose.yml of the current release:
|
|
||||||
#
|
|
||||||
# https://github.com/immich-app/immich/releases/latest/download/docker-compose.yml
|
|
||||||
#
|
|
||||||
# The compose file on main may not be compatible with the latest release.
|
|
||||||
#
|
|
||||||
|
|
||||||
name: immich
|
|
||||||
|
|
||||||
services:
|
|
||||||
immich-server:
|
|
||||||
container_name: immich_server
|
|
||||||
image: ghcr.io/immich-app/immich-server:${IMMICH_VERSION:-release}
|
|
||||||
# extends:
|
|
||||||
# file: hwaccel.transcoding.yml
|
|
||||||
# service: cpu # set to one of [nvenc, quicksync, rkmpp, vaapi, vaapi-wsl] for accelerated transcoding
|
|
||||||
volumes:
|
|
||||||
# Do not edit the next line. If you want to change the media storage location on your system, edit the value of UPLOAD_LOCATION in the .env file
|
|
||||||
- ${UPLOAD_LOCATION}:/usr/src/app/upload
|
|
||||||
- /etc/localtime:/etc/localtime:ro
|
|
||||||
env_file:
|
|
||||||
- .env
|
|
||||||
ports:
|
|
||||||
- 2283:3001
|
|
||||||
depends_on:
|
|
||||||
- redis
|
|
||||||
- database
|
|
||||||
restart: always
|
|
||||||
|
|
||||||
immich-machine-learning:
|
|
||||||
container_name: immich_machine_learning
|
|
||||||
# For hardware acceleration, add one of -[armnn, cuda, openvino] to the image tag.
|
|
||||||
# Example tag: ${IMMICH_VERSION:-release}-cuda
|
|
||||||
image: ghcr.io/immich-app/immich-machine-learning:${IMMICH_VERSION:-release}
|
|
||||||
# extends: # uncomment this section for hardware acceleration - see https://immich.app/docs/features/ml-hardware-acceleration
|
|
||||||
# file: hwaccel.ml.yml
|
|
||||||
# service: cpu # set to one of [armnn, cuda, openvino, openvino-wsl] for accelerated inference - use the `-wsl` version for WSL2 where applicable
|
|
||||||
volumes:
|
|
||||||
- model-cache:/cache
|
|
||||||
env_file:
|
|
||||||
- .env
|
|
||||||
restart: always
|
|
||||||
|
|
||||||
redis:
|
|
||||||
container_name: immich_redis
|
|
||||||
image: docker.io/redis:6.2-alpine@sha256:e3b17ba9479deec4b7d1eeec1548a253acc5374d68d3b27937fcfe4df8d18c7e
|
|
||||||
healthcheck:
|
|
||||||
test: redis-cli ping || exit 1
|
|
||||||
restart: always
|
|
||||||
|
|
||||||
database:
|
|
||||||
container_name: immich_postgres
|
|
||||||
image: docker.io/tensorchord/pgvecto-rs:pg14-v0.2.0@sha256:90724186f0a3517cf6914295b5ab410db9ce23190a2d9d0b9dd6463e3fa298f0
|
|
||||||
environment:
|
|
||||||
POSTGRES_PASSWORD: ${DB_PASSWORD}
|
|
||||||
POSTGRES_USER: ${DB_USERNAME}
|
|
||||||
POSTGRES_DB: ${DB_DATABASE_NAME}
|
|
||||||
POSTGRES_INITDB_ARGS: '--data-checksums'
|
|
||||||
volumes:
|
|
||||||
# Do not edit the next line. If you want to change the database storage location on your system, edit the value of DB_DATA_LOCATION in the .env file
|
|
||||||
- ${DB_DATA_LOCATION}:/var/lib/postgresql/data
|
|
||||||
healthcheck:
|
|
||||||
test: pg_isready --dbname='${DB_DATABASE_NAME}' --username='${DB_USERNAME}' || exit 1; Chksum="$$(psql --dbname='${DB_DATABASE_NAME}' --username='${DB_USERNAME}' --tuples-only --no-align --command='SELECT COALESCE(SUM(checksum_failures), 0) FROM pg_stat_database')"; echo "checksum failure count is $$Chksum"; [ "$$Chksum" = '0' ] || exit 1
|
|
||||||
interval: 5m
|
|
||||||
start_interval: 30s
|
|
||||||
start_period: 5m
|
|
||||||
command: ["postgres", "-c" ,"shared_preload_libraries=vectors.so", "-c", 'search_path="$$user", public, vectors', "-c", "logging_collector=on", "-c", "max_wal_size=2GB", "-c", "shared_buffers=512MB", "-c", "wal_compression=on"]
|
|
||||||
restart: always
|
|
||||||
|
|
||||||
volumes:
|
|
||||||
model-cache:
|
|
244
resources.toml
244
resources.toml
@ -5,11 +5,12 @@
|
|||||||
[[server]]
|
[[server]]
|
||||||
name = "demo-server"
|
name = "demo-server"
|
||||||
description = "Hosts demo.komo.do"
|
description = "Hosts demo.komo.do"
|
||||||
tags = ["komodo", "demo"]
|
tags = ["demo", "komodo"]
|
||||||
config.address = "https://host.docker.internal:8120"
|
[server.config]
|
||||||
config.region = "South-1"
|
address = "https://periphery:8120"
|
||||||
config.enabled = true
|
region = "South-1"
|
||||||
config.mem_warning = 85.0
|
enabled = true
|
||||||
|
mem_warning = 85.0
|
||||||
|
|
||||||
##
|
##
|
||||||
|
|
||||||
@ -17,10 +18,61 @@ config.mem_warning = 85.0
|
|||||||
name = "demo-sync"
|
name = "demo-sync"
|
||||||
description = "Restores the config back to contents in demo-sync resources.toml"
|
description = "Restores the config back to contents in demo-sync resources.toml"
|
||||||
tags = ["komodo", "demo"]
|
tags = ["komodo", "demo"]
|
||||||
config.git_provider = "git.komo.do"
|
[resource_sync.config]
|
||||||
config.repo = "mbecker20/demo-sync"
|
git_provider = "git.komo.do"
|
||||||
config.resource_path = "resources.toml"
|
repo = "komodo/demo"
|
||||||
config.delete = true
|
resource_path = "resources.toml"
|
||||||
|
delete = true
|
||||||
|
|
||||||
|
####################
|
||||||
|
# FerretDB (Stack) #
|
||||||
|
####################
|
||||||
|
|
||||||
|
[[stack]]
|
||||||
|
name = "demo-ferretdb"
|
||||||
|
tags = ["database", "ferretdb"]
|
||||||
|
[stack.config]
|
||||||
|
server = "demo-server"
|
||||||
|
destroy_before_deploy = true
|
||||||
|
file_contents = """
|
||||||
|
services:
|
||||||
|
|
||||||
|
postgres:
|
||||||
|
# Recommended: Pin to a specific version
|
||||||
|
# https://github.com/FerretDB/documentdb/pkgs/container/postgres-documentdb
|
||||||
|
image: ghcr.io/ferretdb/postgres-documentdb
|
||||||
|
restart: unless-stopped
|
||||||
|
expose:
|
||||||
|
- 5432
|
||||||
|
volumes:
|
||||||
|
- data:/var/lib/postgresql/data
|
||||||
|
environment:
|
||||||
|
POSTGRES_USER: [[FERRETDB_USERNAME]]
|
||||||
|
POSTGRES_PASSWORD: [[FERRETDB_PASSWORD]]
|
||||||
|
POSTGRES_DB: postgres
|
||||||
|
|
||||||
|
ferretdb:
|
||||||
|
# Recommended: Pin to a specific version
|
||||||
|
# https://github.com/FerretDB/FerretDB/pkgs/container/ferretdb
|
||||||
|
image: ghcr.io/ferretdb/ferretdb
|
||||||
|
restart: unless-stopped
|
||||||
|
depends_on:
|
||||||
|
- postgres
|
||||||
|
# ports:
|
||||||
|
# - 27017:27017
|
||||||
|
volumes:
|
||||||
|
- state:/state
|
||||||
|
environment:
|
||||||
|
FERRETDB_POSTGRESQL_URL: postgres://[[FERRETDB_USERNAME]]:[[FERRETDB_PASSWORD]]@postgres:5432/postgres
|
||||||
|
|
||||||
|
networks:
|
||||||
|
default:
|
||||||
|
name: ferretdb
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
data:
|
||||||
|
state:
|
||||||
|
"""
|
||||||
|
|
||||||
##################
|
##################
|
||||||
# Immich (Stack) #
|
# Immich (Stack) #
|
||||||
@ -28,11 +80,10 @@ config.delete = true
|
|||||||
|
|
||||||
[[stack]]
|
[[stack]]
|
||||||
name = "demo-immich"
|
name = "demo-immich"
|
||||||
description = "See https://git.komo.do/mbecker20/demo-sync/src/branch/main/immich.compose.yaml"
|
|
||||||
tags = ["demo", "immich"]
|
tags = ["demo", "immich"]
|
||||||
deploy = true
|
[stack.config]
|
||||||
config.server_id = "demo-server"
|
server = "demo-server"
|
||||||
config.file_contents = """
|
file_contents = """
|
||||||
#
|
#
|
||||||
# WARNING: Make sure to use the docker-compose.yml of the current release:
|
# WARNING: Make sure to use the docker-compose.yml of the current release:
|
||||||
#
|
#
|
||||||
@ -106,7 +157,7 @@ services:
|
|||||||
volumes:
|
volumes:
|
||||||
model-cache:
|
model-cache:
|
||||||
"""
|
"""
|
||||||
config.environment = """
|
environment = """
|
||||||
# Supports comments 🦎
|
# Supports comments 🦎
|
||||||
UPLOAD_LOCATION = /immich/upload
|
UPLOAD_LOCATION = /immich/upload
|
||||||
DB_DATA_LOCATION = /immich/postgres # And end of line comments.
|
DB_DATA_LOCATION = /immich/postgres # And end of line comments.
|
||||||
@ -123,27 +174,32 @@ config.environment = """
|
|||||||
|
|
||||||
[[stack]]
|
[[stack]]
|
||||||
name = "demo-jellyfin"
|
name = "demo-jellyfin"
|
||||||
description = "See https://git.komo.do/mbecker20/demo-sync/src/branch/main/jellyfin.compose.yaml"
|
|
||||||
tags = ["demo", "jellyfin"]
|
tags = ["demo", "jellyfin"]
|
||||||
deploy = true
|
[stack.config]
|
||||||
config.server_id = "demo-server"
|
server = "demo-server"
|
||||||
config.file_paths = ["jellyfin.compose.yaml"]
|
links = [
|
||||||
config.git_provider = "git.komo.do"
|
"https://git.komo.do/komodo/demo/src/branch/main/jellyfin.compose.yaml"
|
||||||
config.repo = "mbecker20/demo-sync"
|
]
|
||||||
|
git_provider = "git.komo.do"
|
||||||
|
repo = "komodo/demo"
|
||||||
|
file_paths = ["jellyfin.compose.yaml"]
|
||||||
|
|
||||||
##########################
|
############################
|
||||||
# Immich Deployer (Repo) #
|
# Jellyfin Deployer (Repo) #
|
||||||
##########################
|
############################
|
||||||
|
|
||||||
[[repo]]
|
[[repo]]
|
||||||
name = "trigger-immich-deploy"
|
name = "trigger-jellyfin-deploy"
|
||||||
description = "clone / pull to trigger immich stop, then deploy."
|
description = "clone / pull to trigger immich stop, then deploy."
|
||||||
tags = ["immich", "automation"]
|
tags = ["immich", "automation"]
|
||||||
config.server_id = "demo-server"
|
[repo.config]
|
||||||
config.git_provider = "git.komo.do"
|
server = "demo-server"
|
||||||
config.repo = "mbecker20/demo-sync"
|
git_provider = "git.komo.do"
|
||||||
config.on_pull.path = "."
|
repo = "komodo/demo"
|
||||||
config.on_pull.command = "sh ./trigger-immich-deploy.sh"
|
on_pull.path = "."
|
||||||
|
on_pull.command = """
|
||||||
|
API_KEY=[[KOMODO_API_KEY]] API_SECRET=[[KOMODO_API_SECRET]] sh ./trigger-jellyfin-deploy.sh
|
||||||
|
"""
|
||||||
|
|
||||||
###########
|
###########
|
||||||
# Logging #
|
# Logging #
|
||||||
@ -153,16 +209,17 @@ config.on_pull.command = "sh ./trigger-immich-deploy.sh"
|
|||||||
name = "grafana-ui"
|
name = "grafana-ui"
|
||||||
description = "runs on port 3001"
|
description = "runs on port 3001"
|
||||||
tags = ["logging", "ui"]
|
tags = ["logging", "ui"]
|
||||||
deploy = true
|
deploy = false
|
||||||
config.server_id = "demo-server"
|
[deployment.config]
|
||||||
config.image.type = "Image"
|
server_id = "demo-server"
|
||||||
config.image.params.image = "grafana/grafana"
|
image.type = "Image"
|
||||||
config.restart = "unless-stopped"
|
image.params.image = "grafana/grafana"
|
||||||
config.network = "bridge"
|
restart = "unless-stopped"
|
||||||
config.ports = "3001 = 3000"
|
network = "bridge"
|
||||||
config.extra_args = ["--add-host=host.docker.internal:host-gateway"] # so it can communicate with tempo at host.docker.internal
|
ports = "3001 = 3000"
|
||||||
config.volumes = "grafana-data = /var/lib/grafana"
|
extra_args = ["--add-host=host.docker.internal:host-gateway"] # so it can communicate with tempo at host.docker.internal
|
||||||
config.labels = "vector = key-value" # So vector picks up the logs, ships to loki
|
volumes = "grafana-data = /var/lib/grafana"
|
||||||
|
labels = "vector = key-value" # So vector picks up the logs, ships to loki
|
||||||
|
|
||||||
##
|
##
|
||||||
|
|
||||||
@ -170,13 +227,14 @@ config.labels = "vector = key-value" # So vector picks up the logs, ships to lok
|
|||||||
name = "loki-logging"
|
name = "loki-logging"
|
||||||
description = "runs on 3100"
|
description = "runs on 3100"
|
||||||
tags = ["logging"]
|
tags = ["logging"]
|
||||||
deploy = true
|
deploy = false
|
||||||
config.server_id = "demo-server"
|
[deployment.config]
|
||||||
config.image.type = "Image"
|
server_id = "demo-server"
|
||||||
config.image.params.image = "grafana/loki"
|
image.type = "Image"
|
||||||
config.restart = "unless-stopped"
|
image.params.image = "grafana/loki"
|
||||||
config.network = "host"
|
restart = "unless-stopped"
|
||||||
config.volumes = "loki-data = /loki"
|
network = "host"
|
||||||
|
volumes = "loki-data = /loki"
|
||||||
|
|
||||||
##
|
##
|
||||||
|
|
||||||
@ -184,12 +242,13 @@ config.volumes = "loki-data = /loki"
|
|||||||
name = "tempo-tracing"
|
name = "tempo-tracing"
|
||||||
description = "OTLP: port 4317. HTTP: 3200. GRPC: 9096"
|
description = "OTLP: port 4317. HTTP: 3200. GRPC: 9096"
|
||||||
tags = ["logging"]
|
tags = ["logging"]
|
||||||
deploy = true
|
deploy = false
|
||||||
config.server_id = "demo-server"
|
[stack.config]
|
||||||
config.file_paths = ["tempo.compose.yaml"]
|
server_id = "demo-server"
|
||||||
config.ignore_services = ["init"]
|
file_paths = ["tempo.compose.yaml"]
|
||||||
config.git_provider = "git.komo.do"
|
ignore_services = ["init"]
|
||||||
config.repo = "mbecker20/demo-sync"
|
git_provider = "git.komo.do"
|
||||||
|
repo = "komodo/demo"
|
||||||
|
|
||||||
####################
|
####################
|
||||||
# Vector (Logging) #
|
# Vector (Logging) #
|
||||||
@ -199,12 +258,13 @@ config.repo = "mbecker20/demo-sync"
|
|||||||
# name = "demo-jellyfin"
|
# name = "demo-jellyfin"
|
||||||
# description = "Vector picks up logs from containers and ships them to central location"
|
# description = "Vector picks up logs from containers and ships them to central location"
|
||||||
# tags = ["logging"]
|
# tags = ["logging"]
|
||||||
# deploy = true
|
# deploy = false
|
||||||
# config.server_id = "demo-server"
|
# [stack.config]
|
||||||
# config.file_paths = ["compose.yaml"]
|
# server_id = "demo-server"
|
||||||
# config.git_provider = "git.komo.do"
|
# file_paths = ["compose.yaml"]
|
||||||
|
# git_provider = "git.komo.do"
|
||||||
#
|
#
|
||||||
# config.repo = "mbecker20/demo-vector"
|
# repo = "mbecker20/demo-vector"
|
||||||
|
|
||||||
# [[repo]]
|
# [[repo]]
|
||||||
|
|
||||||
@ -215,6 +275,70 @@ config.repo = "mbecker20/demo-sync"
|
|||||||
[[deployment]]
|
[[deployment]]
|
||||||
name = "hello_world"
|
name = "hello_world"
|
||||||
tags = ["hello", "world"]
|
tags = ["hello", "world"]
|
||||||
config.server_id = "demo-server"
|
[deployment.config]
|
||||||
config.image.type = "Image"
|
server_id = "demo-server"
|
||||||
config.image.params.image = "hello-world"
|
image.type = "Image"
|
||||||
|
image.params.image = "hello-world"
|
||||||
|
|
||||||
|
##
|
||||||
|
|
||||||
|
[[deployment]]
|
||||||
|
name = "backblaze-help"
|
||||||
|
tags = ["backblaze"]
|
||||||
|
[deployment.config]
|
||||||
|
server = "demo-server"
|
||||||
|
image.type = "Build"
|
||||||
|
image.params.build = "backblaze-cli"
|
||||||
|
redeploy_on_build = true
|
||||||
|
network = "none"
|
||||||
|
|
||||||
|
##
|
||||||
|
|
||||||
|
[[build]]
|
||||||
|
name = "backblaze-cli"
|
||||||
|
tags = ["backblaze"]
|
||||||
|
[build.config]
|
||||||
|
builder = "local"
|
||||||
|
version = "4.3.2"
|
||||||
|
auto_increment_version = false
|
||||||
|
links = [
|
||||||
|
"https://github.com/Backblaze/B2_Command_Line_Tool/releases"
|
||||||
|
]
|
||||||
|
dockerfile = """
|
||||||
|
FROM debian:bookworm-slim
|
||||||
|
|
||||||
|
WORKDIR /usr/local/bin
|
||||||
|
|
||||||
|
# Version arg is automatically populated by komodo build.
|
||||||
|
ARG VERSION
|
||||||
|
|
||||||
|
RUN apt-get update && \
|
||||||
|
apt-get install -y \
|
||||||
|
curl \
|
||||||
|
&& \
|
||||||
|
rm -rf /var/lib/apt/lists/* && \
|
||||||
|
curl -L --output b2 "https://github.com/Backblaze/B2_Command_Line_Tool/releases/download/v$VERSION/b2-linux" && \
|
||||||
|
chmod +x ./b2
|
||||||
|
|
||||||
|
CMD [ "b2", "--help" ]
|
||||||
|
"""
|
||||||
|
|
||||||
|
##
|
||||||
|
|
||||||
|
[[builder]]
|
||||||
|
name = "local"
|
||||||
|
[builder.config]
|
||||||
|
type = "Server"
|
||||||
|
params.server_id = "demo-server"
|
||||||
|
|
||||||
|
##
|
||||||
|
|
||||||
|
[[user_group]]
|
||||||
|
name = "Users"
|
||||||
|
users = ["demo", "komodo"]
|
||||||
|
all.Stack = "Execute"
|
||||||
|
all.Deployment = "Execute"
|
||||||
|
all.Procedure = "None"
|
||||||
|
all.Repo = "Execute"
|
||||||
|
all.Server = "None"
|
||||||
|
permissions = []
|
@ -1,5 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
HOME=/root /root/.cargo/bin/komodo -y execute stop-stack demo-immich
|
|
||||||
sleep 3s
|
|
||||||
HOME=/root /root/.cargo/bin/komodo -y execute deploy-stack demo-immich
|
|
15
trigger-jellyfin-deploy.sh
Normal file
15
trigger-jellyfin-deploy.sh
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
curl --header "Content-Type: application/json" \
|
||||||
|
--header "X-Api-Key: $API_KEY" \
|
||||||
|
--header "X-Api-Secret: $API_SECRET" \
|
||||||
|
--data '{ "stack": "demo-jellyfin" }' \
|
||||||
|
https://demo.komo.do/execute/StopStack
|
||||||
|
|
||||||
|
sleep 10s
|
||||||
|
|
||||||
|
curl --header "Content-Type: application/json" \
|
||||||
|
--header "X-Api-Key: $API_KEY" \
|
||||||
|
--header "X-Api-Secret: $API_SECRET" \
|
||||||
|
--data '{ "stack": "demo-jellyfin" }' \
|
||||||
|
https://demo.komo.do/execute/DeployStack
|
Reference in New Issue
Block a user