Reverse Proxy

Постави Fluxheim пред application server. Fluxheim управлява TLS, header-и, лимити и избор на upstream.

Basic proxy

[[vhosts]]
name = "app"
hosts = ["app.example.com"]

[[vhosts.routes]]
path_prefix = "/"
action = "proxy"
upstreams = ["127.0.0.1:3000"]

Избор на route

ФункцияИзползвай, когато
path_exactЕдин URL има нужда от точен route.
path_prefixЦяло URL subtree отива към един backend.
strip_prefixBackend страна страна-ът не трябва да вижда public prefix-а.
rewrite_prefixBackend страна страна-ът очаква различен internal prefix.
methodsRoute трябва да приема само избрани HTTP method-и.

Пример за path rewrite

[[vhosts.routes]]
name = "api"
path_prefix = "/api/"
strip_prefix = "/api/"
rewrite_prefix = "/internal/"

[vhosts.routes.proxy]
upstreams = ["10.0.0.20:8080"]
connect_timeout_secs = 5
read_timeout_secs = 30
send_timeout_secs = 30

Production бележки

  • Дръж приложението на loopback или в частна мрежа.
  • Задай request body лимити преди да изложиш upload.
  • Use trusted proxy settings only for networks you control.
  • Предпочитай explicit route-ове пред един голям fallback, когато различни path-ове имат различни safety правила.
Български