mirror of
https://github.com/kevinveenbirkenbach/computer-playbook.git
synced 2025-08-26 21:45:20 +02:00
- Improved get_service_name filter plugin (clearer suffix handling, consistent var names). - Added MODE_ASSERT flag to optionally execute validation/assertion tasks. - Fixed systemd unit handling: consistent use of %I instead of %i, correct escaping of instance names. - Unified on_failure behavior and alarm composer scripts. - Cleaned up redundant logging, handlers, and debug config. - Strengthened sys-service template resolution with assert (only active when MODE_ASSERT). - Simplified timer and suffix handling with get_service_name filter. - Hardened sensitive tasks with no_log. - Added conditional asserts across roles (Keycloak, DNS, Mailu, Discourse, etc.). These changes improve consistency, safety, and validation across the automation stack. Conversation: https://chatgpt.com/share/68a4ae28-483c-800f-b2f7-f64c7124c274
64 lines
2.6 KiB
Django/Jinja
64 lines
2.6 KiB
Django/Jinja
worker_processes auto;
|
|
|
|
events
|
|
{
|
|
worker_connections 1024;
|
|
}
|
|
|
|
http
|
|
{
|
|
include mime.types;
|
|
|
|
{# default_type application/octet-stream; If html filter does not work, this one needs to be used#}
|
|
|
|
default_type text/html;
|
|
|
|
{# caching #}
|
|
proxy_cache_path {{ NGINX.DIRECTORIES.CACHE.GENERAL }} levels=1:2 keys_zone=cache:20m max_size=20g inactive=14d use_temp_path=off;
|
|
proxy_cache_path {{ NGINX.DIRECTORIES.CACHE.IMAGE }} levels=1:2 keys_zone=imgcache:10m inactive=60m use_temp_path=off;
|
|
|
|
# --------------------------------------------------------------------------------
|
|
# Tweak the hash table used to store your server_name entries:
|
|
server_names_hash_bucket_size 64; # size of each bucket for server_name lookups (in bytes)
|
|
server_names_hash_max_size 512; # maximum total buckets for the server_name hash table
|
|
# --------------------------------------------------------------------------------
|
|
|
|
{# logging and debugging #}
|
|
{% if MODE_DEBUG | bool %}
|
|
{# individual log format for better debugging #}
|
|
log_format debug '$host - $remote_addr [$time_local] '
|
|
'"$request" $status $body_bytes_sent '
|
|
'"Referer: $http_referer" '
|
|
'"User-Agent: $http_user_agent" '
|
|
'"ReqTime: $request_time" "UpstreamTime: $upstream_response_time" '
|
|
'"ReqLength: $request_length" "BytesSent: $bytes_sent" '
|
|
'"ConnRequests: $connection_requests" '
|
|
'"X-Forwarded-For: $http_x_forwarded_for" '
|
|
'"Scheme: $scheme" "Protocol: $server_protocol" "ServerName: $server_name"';
|
|
access_log /dev/stdout debug;
|
|
{% endif %}
|
|
error_log /dev/stderr info;
|
|
|
|
sendfile on;
|
|
keepalive_timeout 65;
|
|
|
|
{# gzip #}
|
|
gzip on;
|
|
gzip_proxied any;
|
|
gzip_vary on;
|
|
gzip_disable "MSIE [1-6]\.(?!.*SV1)"; # Disable for Internetexplorer 6
|
|
gzip_comp_level 4;
|
|
gzip_min_length 256;
|
|
gzip_types application/atom+xml application/javascript application/xml+rss application/x-javascript application/json application/ld+json application/manifest+json application/rss+xml application/vnd.geo+json application/vnd.ms-fontobject application/x-font-ttf application/x-web-app-app-manifest+json application/xhtml+xml application/xml font/opentype image/bmp image/svg+xml image/x-icon text/cache-manifest text/css text/plain text/vcard text/vnd.rim.location.xloc text/vtt text/x-component text/x-cross-domain-policy text/javascript text/xml;
|
|
|
|
types_hash_max_size 4096;
|
|
{% for dir in NGINX.DIRECTORIES.HTTP.values() %}
|
|
include {{ dir }}*.conf;
|
|
{% endfor %}
|
|
}
|
|
|
|
# For port proxies
|
|
stream{
|
|
include {{NGINX.DIRECTORIES.STREAMS}}*.conf;
|
|
}
|