job "mediawiki" { datacenters = ["aperture"] type = "service" meta { domain = "wiki.redbrick.dcu.ie" } group "rbwiki" { count = 1 network { mode = "bridge" port "http" { to = 80 } port "fpm" { to = 9000 } port "db" { to = 3306 } } service { name = "rbwiki-web" port = "http" check { type = "http" path = "/Main_Page" interval = "10s" timeout = "5s" } tags = [ "traefik.enable=true", "traefik.port=${NOMAD_PORT_http}", "traefik.http.routers.rbwiki.rule=Host(`${NOMAD_META_domain}`) || Host(`wiki.rb.dcu.ie`)", "traefik.http.routers.rbwiki.entrypoints=web,websecure", "traefik.http.routers.rbwiki.tls.certresolver=lets-encrypt", "traefik.http.routers.rbwiki.middlewares=rbwiki-redirect-root, rbwiki-redirect-mw", "traefik.http.middlewares.rbwiki-redirect-root.redirectregex.regex=^https://wiki\\.redbrick\\.dcu\\.ie/?$", "traefik.http.middlewares.rbwiki-redirect-root.redirectregex.replacement=https://wiki.redbrick.dcu.ie/Main_Page", "traefik.http.middlewares.rbwiki-redirect-mw.redirectregex.regex=https://wiki\\.redbrick\\.dcu\\.ie/Mw/(.*)", "traefik.http.middlewares.rbwiki-redirect-mw.redirectregex.replacement=https://wiki.redbrick.dcu.ie/$1", ] } task "rbwiki-nginx" { driver = "docker" config { image = "nginx:alpine" ports = ["http"] volumes = [ "local/nginx.conf:/etc/nginx/nginx.conf", "/storage/nomad/mediawiki/extensions:/var/www/html/extensions", "/storage/nomad/mediawiki/images:/var/www/html/images", "/storage/nomad/mediawiki/skins:/var/www/html/skins", "/storage/nomad/mediawiki/resources/assets:/var/www/html/Resources/assets", ] } resources { cpu = 200 memory = 100 } template { data = <<EOH # user www-data www-data; error_log /dev/stderr error; events { worker_connections 1024; } http { include /etc/nginx/mime.types; server_tokens off; error_log /dev/stderr error; access_log /dev/stdout; charset utf-8; server { server_name {{ env "NOMAD_META_domain" }}; listen 80; listen [::]:80; root /var/www/html; index index.php index.html index.htm; client_max_body_size 5m; client_body_timeout 60; # MediaWiki short URLs location / { try_files $uri $uri/ @rewrite; } location @rewrite { rewrite ^/(.*)$ /index.php?title=$1&$args; } location ~* \.(js|css|png|jpg|jpeg|gif|ico|svg|woff|woff2|ttf|otf|eot|ico)$ { try_files $uri /index.php; expires max; log_not_found off; } # Pass the PHP scripts to FastCGI server location ~ \.php$ { include fastcgi_params; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_pass {{ env "NOMAD_HOST_ADDR_fpm" }}; fastcgi_index index.php; } location ~ /\.ht { deny all; } } } EOH destination = "local/nginx.conf" } } task "rbwiki-php" { driver = "docker" config { image = "ghcr.io/wizzdom/mediawiki-fpm-ldap-alpine:latest" ports = ["fpm"] volumes = [ "/storage/nomad/mediawiki/extensions:/var/www/html/extensions", "/storage/nomad/mediawiki/images:/var/www/html/images", "/storage/nomad/mediawiki/skins:/var/www/html/skins", "/storage/nomad/mediawiki/resources/assets:/var/www/html/Resources/assets", "local/LocalSettings.php:/var/www/html/LocalSettings.php", "local/ldapprovider.json:/etc/mediawiki/ldapprovider.json" ] } resources { cpu = 4000 memory = 1200 } template { data = <<EOH { "LDAP": { "authorization": { "rules": { "groups": { "required": [] } } }, "connection": { "server": "{{ key "mediawiki/ldap/server" }}", "user": "{{ key "mediawiki/ldap/user" }}", "pass": "{{ key "mediawiki/ldap/password" }}", "options": { "LDAP_OPT_DEREF": 1 }, "grouprequest": "MediaWiki\\Extension\\LDAPProvider\\UserGroupsRequest\\GroupMemberUid::factory", "basedn": "o=redbrick", "groupbasedn": "ou=groups,o=redbrick", "userbasedn": "ou=accounts,o=redbrick", "searchattribute": "uid", "searchstring": "uid=USER-NAME,ou=accounts,o=redbrick", "usernameattribute": "uid", "realnameattribute": "cn", "emailattribute": "altmail" } } } EOH destination = "local/ldapprovider.json" } template { data = file("LocalSettings.php") destination = "local/LocalSettings.php" } } service { name = "rbwiki-db" port = "db" check { name = "mariadb_probe" type = "tcp" interval = "10s" timeout = "2s" } } task "rbwiki-db" { driver = "docker" config { image = "mariadb" ports = ["db"] volumes = [ "/storage/nomad/mediawiki/db:/var/lib/mysql", "/oldstorage/wiki_backups:/wiki-backups/backup", "local/conf.cnf:/etc/mysql/mariadb.conf.d/50-server.cnf", ] } template { data = <<EOH [mysqld] max_connections = 100 key_buffer_size = 2G query_cache_size = 0 innodb_buffer_pool_size = 6G innodb_log_file_size = 512M innodb_flush_log_at_trx_commit = 1 innodb_flush_method = O_DIRECT innodb_io_capacity = 200 tmp_table_size = 5242K max_heap_table_size = 5242K innodb_log_buffer_size = 16M innodb_file_per_table = 1 bind-address = 0.0.0.0 # Logging slow_query_log = 1 slow_query_log_file = /var/log/mysql/slow.log long_query_time = 1 EOH destination = "local/conf.cnf" } resources { cpu = 800 memory = 1200 } template { data = <<EOH MYSQL_DATABASE={{ key "mediawiki/db/name" }} MYSQL_USER={{ key "mediawiki/db/username" }} MYSQL_PASSWORD={{ key "mediawiki/db/password" }} MYSQL_RANDOM_ROOT_PASSWORD=yes EOH destination = "local/.env" env = true } } } }