Add Gitea as App
This commit is contained in:
parent
ad8fd86bcb
commit
ffe8c8fecd
110
nomad_jobs/apps/gitea-standalone.nomad.hcl
Normal file
110
nomad_jobs/apps/gitea-standalone.nomad.hcl
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
# Deploy Gitea with dependancies encapsulated in the nomad job spec. This spec
|
||||||
|
# will not persist data between restarts. Good for getting started.
|
||||||
|
|
||||||
|
# WARNING: Set a secure password for the postgres user. Line 38
|
||||||
|
# WARNING: Update the domain gitea should be deployed to on traefik. Line 90
|
||||||
|
|
||||||
|
job "gitea-standalone" {
|
||||||
|
datacenters = ["dc1"]
|
||||||
|
|
||||||
|
group "database" {
|
||||||
|
count = 1
|
||||||
|
|
||||||
|
network {
|
||||||
|
mode = "bridge"
|
||||||
|
}
|
||||||
|
|
||||||
|
service {
|
||||||
|
name = "gitea-postgres-standalone"
|
||||||
|
port = "5432"
|
||||||
|
tags = ["traefik.enable=false"] # Hide postgres from traefik
|
||||||
|
|
||||||
|
connect {
|
||||||
|
sidecar_service {
|
||||||
|
tags = ["traefik.enable=false"] # Hide postgres envoy from traefik
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
task "postgres" {
|
||||||
|
driver = "docker"
|
||||||
|
|
||||||
|
config {
|
||||||
|
image = "postgres:16.1-alpine3.19"
|
||||||
|
}
|
||||||
|
|
||||||
|
env = {
|
||||||
|
"POSTGRES_USER"="gitea",
|
||||||
|
"POSTGRES_PASSWORD"="not-a-secure-password",
|
||||||
|
"POSTGRES_DB"="gitea"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
group "frontend" {
|
||||||
|
count = 1
|
||||||
|
|
||||||
|
network {
|
||||||
|
mode = "bridge"
|
||||||
|
port "ingress" {
|
||||||
|
to = 3000
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Attach to Postgres Instance
|
||||||
|
service {
|
||||||
|
name = "postgres-gitea-standalone-envoy"
|
||||||
|
port = "ingress"
|
||||||
|
tags = ["traefik.enable=false"] # Hide envoy from traefik
|
||||||
|
|
||||||
|
connect {
|
||||||
|
sidecar_service {
|
||||||
|
proxy {
|
||||||
|
upstreams {
|
||||||
|
destination_name = "gitea-postgres-standalone"
|
||||||
|
local_bind_address = "127.0.0.1"
|
||||||
|
local_bind_port = 5432
|
||||||
|
}
|
||||||
|
}
|
||||||
|
tags = ["traefik.enable=false"] # Hide envoy from traefik
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
check {
|
||||||
|
type = "http"
|
||||||
|
path = "/"
|
||||||
|
interval = "10s"
|
||||||
|
timeout = "2s"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Expose to Traefik as a service
|
||||||
|
service {
|
||||||
|
name = "gitea-standalone"
|
||||||
|
port = "ingress"
|
||||||
|
|
||||||
|
tags = [
|
||||||
|
"traefik.enable=true",
|
||||||
|
"traefik.http.routers.gitea-standalone.tls=true",
|
||||||
|
"traefik.http.routers.gitea-standalone.entrypoints=websecure",
|
||||||
|
"traefik.http.routers.gitea-standalone.rule=Host(`git.example.local`)"
|
||||||
|
]
|
||||||
|
|
||||||
|
check {
|
||||||
|
type = "http"
|
||||||
|
path = "/"
|
||||||
|
interval = "10s"
|
||||||
|
timeout = "2s"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
task "gitea-standalone" {
|
||||||
|
driver = "docker"
|
||||||
|
|
||||||
|
config {
|
||||||
|
image = "gitea/gitea:1.21.1"
|
||||||
|
ports = ["ingress"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user