WordPress
Ein praktisches PHP-FPM-Rezept für einen normalen WordPress-Front-Steuerungler.
WordPress-Vhost
[[vhosts]]
name = "wordpress"
hosts = ["blog.example.com"]
[vhosts.web]
root = "/srv/wordpress"
index_files = ["index.php", "index.html"]
deny_dotfiles = true
[vhosts.php]
enabled = true
root = "/srv/wordpress"
index = "index.php"
preset = "wordpress"
try_files = "wordpress"
deny_path_prefixes = ["/wp-content/uploads/"]
[vhosts.php.fpm]
mode = "external"
socket = "/run/php-fpm/wordpress.sock"
WordPress cache route
[[vhosts.routes]]
name = "wp-assets"
path_prefix = "/wp-content/"
action = "proxy"
[vhosts.routes.proxy]
upstreams = ["127.0.0.1:9000"]
[vhosts.routes.cache]
enabled = true
preset = "wordpress"
status_ttls = { "200" = 3600, "404" = 60 }
extensions = ["css", "js", "png", "jpg", "webp", "svg"]
bypass_cookie_name_prefixes = ["wordpress_logged_in_", "wordpress_sec_"]
Häufige Prüfungen
- Stelle sicher, dass der PHP-FPM-Benutzer WordPress-Dateien lesen kann.
- Halte Uploads nur dort beschreibbar, wo WordPress Schreibzugriff braucht.
- Put cache in front of public assets, not wp-admin.
- Keep login, preview, cron, XML-RPC, and admin paths out of shared cache.
- Nutze das WordPress-Preset als Basis und erganze dann site-spezifische Bypasses.
Gute Passung
Dieses Setup ist fur einen normalen WordPress-Frontcontroller, bei dem Fluxheim sichere statische Dateien ausliefert, PHP in Upload-Pfaden blockiert und dynamische Requests an PHP-FPM weiterleitet.