2019-08-01 23:58:36 +00:00
<!doctype html>
< html lang = "en" class = "no-js" >
< head >
< meta charset = "utf-8" >
< meta name = "viewport" content = "width=device-width,initial-scale=1" >
< meta http-equiv = "x-ua-compatible" content = "ie=edge" >
2019-11-08 14:46:32 +00:00
< link rel = "canonical" href = "https://kubernetes.github.io/ingress-nginx/user-guide/fcgi-services/" >
2019-08-01 23:58:36 +00:00
< meta name = "lang:clipboard.copy" content = "Copy to clipboard" >
< meta name = "lang:clipboard.copied" content = "Copied to clipboard" >
< meta name = "lang:search.language" content = "en" >
< meta name = "lang:search.pipeline.stopwords" content = "True" >
< meta name = "lang:search.pipeline.trimmer" content = "True" >
< meta name = "lang:search.result.none" content = "No matching documents" >
< meta name = "lang:search.result.one" content = "1 matching document" >
< meta name = "lang:search.result.other" content = "# matching documents" >
< meta name = "lang:search.tokenizer" content = "[\s\-]+" >
< link rel = "shortcut icon" href = "../../assets/images/favicon.png" >
2020-02-14 15:40:31 +00:00
< meta name = "generator" content = "mkdocs-1.0.4, mkdocs-material-4.6.3" >
2019-08-01 23:58:36 +00:00
< title > Exposing FCGI services - NGINX Ingress Controller< / title >
2020-02-09 23:53:05 +00:00
< link rel = "stylesheet" href = "../../assets/stylesheets/application.adb8469c.css" >
2019-08-01 23:58:36 +00:00
2019-08-22 18:23:26 +00:00
< link rel = "stylesheet" href = "../../assets/stylesheets/application-palette.a8b3c06d.css" >
2019-08-01 23:58:36 +00:00
< meta name = "theme-color" content = "#009688" >
2020-02-09 23:53:05 +00:00
< script src = "../../assets/javascripts/modernizr.86422ebf.js" > < / script >
2019-08-01 23:58:36 +00:00
< link href = "https://fonts.gstatic.com" rel = "preconnect" crossorigin >
2020-02-09 23:53:05 +00:00
< link rel = "stylesheet" href = "https://fonts.googleapis.com/css?family=Roboto:300,400,400i,700%7CRoboto+Mono&display=fallback" >
2019-08-01 23:58:36 +00:00
< style > body , input { font-family : "Roboto" , "Helvetica Neue" , Helvetica , Arial , sans-serif } code , kbd , pre { font-family : "Roboto Mono" , "Courier New" , Courier , monospace } < / style >
< link rel = "stylesheet" href = "../../assets/fonts/material-icons.css" >
< link rel = "stylesheet" href = "../../extra.css" >
< script >
window.ga = window.ga || function() {
(ga.q = ga.q || []).push(arguments)
}
ga.l = +new Date
/* Setup integration and send page view */
ga("create", "UA-118407822-1", "kubernetes.github.io")
ga("set", "anonymizeIp", true)
ga("send", "pageview")
/* Register handler to log search on blur */
document.addEventListener("DOMContentLoaded", () => {
if (document.forms.search) {
var query = document.forms.search.query
query.addEventListener("blur", function() {
if (this.value) {
var path = document.location.pathname;
ga("send", "pageview", path + "?q=" + this.value)
}
})
}
})
< / script >
< script async src = "https://www.google-analytics.com/analytics.js" > < / script >
< / head >
< body dir = "ltr" data-md-color-primary = "teal" data-md-color-accent = "green" >
< svg class = "md-svg" >
< defs >
< svg xmlns = "http://www.w3.org/2000/svg" width = "416" height = "448" viewBox = "0 0 416 448" id = "__github" > < path fill = "currentColor" d = "M160 304q0 10-3.125 20.5t-10.75 19T128 352t-18.125-8.5-10.75-19T96 304t3.125-20.5 10.75-19T128 256t18.125 8.5 10.75 19T160 304zm160 0q0 10-3.125 20.5t-10.75 19T288 352t-18.125-8.5-10.75-19T256 304t3.125-20.5 10.75-19T288 256t18.125 8.5 10.75 19T320 304zm40 0q0-30-17.25-51T296 232q-10.25 0-48.75 5.25Q229.5 240 208 240t-39.25-2.75Q130.75 232 120 232q-29.5 0-46.75 21T56 304q0 22 8 38.375t20.25 25.75 30.5 15 35 7.375 37.25 1.75h42q20.5 0 37.25-1.75t35-7.375 30.5-15 20.25-25.75T360 304zm56-44q0 51.75-15.25 82.75-9.5 19.25-26.375 33.25t-35.25 21.5-42.5 11.875-42.875 5.5T212 416q-19.5 0-35.5-.75t-36.875-3.125-38.125-7.5-34.25-12.875T37 371.5t-21.5-28.75Q0 312 0 260q0-59.25 34-99-6.75-20.5-6.75-42.5 0-29 12.75-54.5 27 0 47.5 9.875t47.25 30.875Q171.5 96 212 96q37 0 70 8 26.25-20.5 46.75-30.25T376 64q12.75 25.5 12.75 54.5 0 21.75-6.75 42 34 40 34 99.5z" / > < / svg >
< / defs >
< / svg >
< input class = "md-toggle" data-md-toggle = "drawer" type = "checkbox" id = "__drawer" autocomplete = "off" >
< input class = "md-toggle" data-md-toggle = "search" type = "checkbox" id = "__search" autocomplete = "off" >
< label class = "md-overlay" data-md-component = "overlay" for = "__drawer" > < / label >
2020-02-09 23:53:05 +00:00
< a href = "#exposing-fastcgi-servers" tabindex = "0" class = "md-skip" >
2019-08-01 23:58:36 +00:00
Skip to content
< / a >
< header class = "md-header" data-md-component = "header" >
< nav class = "md-header-nav md-grid" >
< div class = "md-flex" >
< div class = "md-flex__cell md-flex__cell--shrink" >
2020-02-09 23:53:05 +00:00
< a href = "https://kubernetes.github.io/ingress-nginx" title = "NGINX Ingress Controller" aria-label = "NGINX Ingress Controller" class = "md-header-nav__button md-logo" >
2019-08-01 23:58:36 +00:00
< i class = "md-icon" > public< / i >
< / a >
< / div >
< div class = "md-flex__cell md-flex__cell--shrink" >
< label class = "md-icon md-icon--menu md-header-nav__button" for = "__drawer" > < / label >
< / div >
< div class = "md-flex__cell md-flex__cell--stretch" >
< div class = "md-flex__ellipsis md-header-nav__title" data-md-component = "title" >
< span class = "md-header-nav__topic" >
NGINX Ingress Controller
< / span >
< span class = "md-header-nav__topic" >
Exposing FCGI services
< / span >
< / div >
< / div >
< div class = "md-flex__cell md-flex__cell--shrink" >
< label class = "md-icon md-icon--search md-header-nav__button" for = "__search" > < / label >
< div class = "md-search" data-md-component = "search" role = "dialog" >
< label class = "md-search__overlay" for = "__search" > < / label >
< div class = "md-search__inner" role = "search" >
< form class = "md-search__form" name = "search" >
2020-02-09 23:53:05 +00:00
< input type = "text" class = "md-search__input" aria-label = "search" name = "query" placeholder = "Search" autocapitalize = "off" autocorrect = "off" autocomplete = "off" spellcheck = "false" data-md-component = "query" data-md-state = "active" >
2019-08-01 23:58:36 +00:00
< label class = "md-icon md-search__icon" for = "__search" > < / label >
< button type = "reset" class = "md-icon md-search__icon" data-md-component = "reset" tabindex = "-1" >

< / button >
< / form >
< div class = "md-search__output" >
< div class = "md-search__scrollwrap" data-md-scrollfix >
< div class = "md-search-result" data-md-component = "result" >
< div class = "md-search-result__meta" >
Type to start searching
< / div >
< ol class = "md-search-result__list" > < / ol >
< / div >
< / div >
< / div >
< / div >
< / div >
< / div >
< div class = "md-flex__cell md-flex__cell--shrink" >
< div class = "md-header-nav__source" >
< a href = "https://github.com/kubernetes/ingress-nginx/" title = "Go to repository" class = "md-source" data-md-source = "github" >
< div class = "md-source__icon" >
< svg viewBox = "0 0 24 24" width = "24" height = "24" >
< use xlink:href = "#__github" width = "24" height = "24" > < / use >
< / svg >
< / div >
< div class = "md-source__repository" >
kubernetes/ingress-nginx
< / div >
< / a >
< / div >
< / div >
< / div >
< / nav >
< / header >
< div class = "md-container" >
< nav class = "md-tabs md-tabs--active" data-md-component = "tabs" >
< div class = "md-tabs__inner md-grid" >
< ul class = "md-tabs__list" >
< li class = "md-tabs__item" >
2019-09-22 20:06:22 +00:00
< a href = "../.." class = "md-tabs__link" >
2019-08-01 23:58:36 +00:00
Welcome
< / a >
< / li >
< li class = "md-tabs__item" >
2019-09-22 20:06:22 +00:00
< a href = "../../deploy/" class = "md-tabs__link" >
2019-08-01 23:58:36 +00:00
Deployment
< / a >
< / li >
< li class = "md-tabs__item" >
2019-09-22 20:06:22 +00:00
< a href = "../nginx-configuration/" class = "md-tabs__link" >
2019-08-01 23:58:36 +00:00
User guide
< / a >
< / li >
< li class = "md-tabs__item" >
2019-09-22 20:06:22 +00:00
< a href = "../../examples/" class = "md-tabs__link" >
2019-08-01 23:58:36 +00:00
Examples
< / a >
< / li >
< / ul >
< / div >
< / nav >
2019-09-22 20:06:22 +00:00
< main class = "md-main" role = "main" >
2019-08-01 23:58:36 +00:00
< div class = "md-main__inner md-grid" data-md-component = "container" >
< div class = "md-sidebar md-sidebar--primary" data-md-component = "navigation" >
< div class = "md-sidebar__scrollwrap" >
< div class = "md-sidebar__inner" >
< nav class = "md-nav md-nav--primary" data-md-level = "0" >
< label class = "md-nav__title md-nav__title--site" for = "__drawer" >
2019-11-08 14:46:32 +00:00
< a href = "https://kubernetes.github.io/ingress-nginx" title = "NGINX Ingress Controller" class = "md-nav__button md-logo" >
2019-08-01 23:58:36 +00:00
< i class = "md-icon" > public< / i >
< / a >
NGINX Ingress Controller
< / label >
< div class = "md-nav__source" >
< a href = "https://github.com/kubernetes/ingress-nginx/" title = "Go to repository" class = "md-source" data-md-source = "github" >
< div class = "md-source__icon" >
< svg viewBox = "0 0 24 24" width = "24" height = "24" >
< use xlink:href = "#__github" width = "24" height = "24" > < / use >
< / svg >
< / div >
< div class = "md-source__repository" >
kubernetes/ingress-nginx
< / div >
< / a >
< / div >
< ul class = "md-nav__list" data-md-scrollfix >
< li class = "md-nav__item md-nav__item--nested" >
< input class = "md-toggle md-nav__toggle" data-md-toggle = "nav-1" type = "checkbox" id = "nav-1" >
< label class = "md-nav__link" for = "nav-1" >
Welcome
< / label >
< nav class = "md-nav" data-md-component = "collapsible" data-md-level = "1" >
< label class = "md-nav__title" for = "nav-1" >
Welcome
< / label >
< ul class = "md-nav__list" data-md-scrollfix >
< li class = "md-nav__item" >
< a href = "../.." title = "Welcome" class = "md-nav__link" >
Welcome
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../how-it-works/" title = "How it works" class = "md-nav__link" >
How it works
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../troubleshooting/" title = "Troubleshooting" class = "md-nav__link" >
Troubleshooting
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../kubectl-plugin/" title = "kubectl plugin" class = "md-nav__link" >
kubectl plugin
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../development/" title = "Development" class = "md-nav__link" >
Development
< / a >
< / li >
< / ul >
< / nav >
< / li >
< li class = "md-nav__item md-nav__item--nested" >
< input class = "md-toggle md-nav__toggle" data-md-toggle = "nav-2" type = "checkbox" id = "nav-2" >
< label class = "md-nav__link" for = "nav-2" >
Deployment
< / label >
< nav class = "md-nav" data-md-component = "collapsible" data-md-level = "1" >
< label class = "md-nav__title" for = "nav-2" >
Deployment
< / label >
< ul class = "md-nav__list" data-md-scrollfix >
< li class = "md-nav__item" >
< a href = "../../deploy/" title = "Installation Guide" class = "md-nav__link" >
Installation Guide
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../deploy/baremetal/" title = "Bare-metal considerations" class = "md-nav__link" >
Bare-metal considerations
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../deploy/rbac/" title = "Role Based Access Control (RBAC)" class = "md-nav__link" >
Role Based Access Control (RBAC)
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../deploy/validating-webhook/" title = "Validating Webhook (admission controller)" class = "md-nav__link" >
Validating Webhook (admission controller)
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../deploy/upgrade/" title = "Upgrade" class = "md-nav__link" >
Upgrade
< / a >
< / li >
< / ul >
< / nav >
< / li >
< li class = "md-nav__item md-nav__item--active md-nav__item--nested" >
< input class = "md-toggle md-nav__toggle" data-md-toggle = "nav-3" type = "checkbox" id = "nav-3" checked >
< label class = "md-nav__link" for = "nav-3" >
User guide
< / label >
< nav class = "md-nav" data-md-component = "collapsible" data-md-level = "1" >
< label class = "md-nav__title" for = "nav-3" >
User guide
< / label >
< ul class = "md-nav__list" data-md-scrollfix >
< li class = "md-nav__item md-nav__item--nested" >
< input class = "md-toggle md-nav__toggle" data-md-toggle = "nav-3-1" type = "checkbox" id = "nav-3-1" >
< label class = "md-nav__link" for = "nav-3-1" >
NGINX Configuration
< / label >
< nav class = "md-nav" data-md-component = "collapsible" data-md-level = "2" >
< label class = "md-nav__title" for = "nav-3-1" >
NGINX Configuration
< / label >
< ul class = "md-nav__list" data-md-scrollfix >
< li class = "md-nav__item" >
< a href = "../nginx-configuration/" title = "Introduction" class = "md-nav__link" >
Introduction
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../basic-usage/" title = "Basic usage" class = "md-nav__link" >
Basic usage
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../nginx-configuration/annotations/" title = "Annotations" class = "md-nav__link" >
Annotations
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../nginx-configuration/configmap/" title = "ConfigMap" class = "md-nav__link" >
ConfigMap
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../nginx-configuration/custom-template/" title = "Custom NGINX template" class = "md-nav__link" >
Custom NGINX template
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../nginx-configuration/log-format/" title = "Log format" class = "md-nav__link" >
Log format
< / a >
< / li >
< / ul >
< / nav >
< / li >
< li class = "md-nav__item" >
< a href = "../cli-arguments/" title = "Command line arguments" class = "md-nav__link" >
Command line arguments
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../custom-errors/" title = "Custom errors" class = "md-nav__link" >
Custom errors
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../default-backend/" title = "Default backend" class = "md-nav__link" >
Default backend
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../exposing-tcp-udp-services/" title = "Exposing TCP and UDP services" class = "md-nav__link" >
Exposing TCP and UDP services
< / a >
< / li >
< li class = "md-nav__item md-nav__item--active" >
< input class = "md-toggle md-nav__toggle" data-md-toggle = "toc" type = "checkbox" id = "__toc" >
< label class = "md-nav__link md-nav__link--active" for = "__toc" >
Exposing FCGI services
< / label >
< a href = "./" title = "Exposing FCGI services" class = "md-nav__link md-nav__link--active" >
Exposing FCGI services
< / a >
< nav class = "md-nav md-nav--secondary" >
< label class = "md-nav__title" for = "__toc" > Table of contents< / label >
< ul class = "md-nav__list" data-md-scrollfix >
< li class = "md-nav__item" >
2019-09-22 20:06:22 +00:00
< a href = "#example-objects-to-expose-a-fastcgi-pod" class = "md-nav__link" >
2019-08-01 23:58:36 +00:00
Example Objects to Expose a FastCGI Pod
< / a >
< / li >
< li class = "md-nav__item" >
2020-02-09 23:53:05 +00:00
< a href = "#fastcgi-ingress-annotations" class = "md-nav__link" >
FastCGI Ingress Annotations
2019-08-01 23:58:36 +00:00
< / a >
< nav class = "md-nav" >
< ul class = "md-nav__list" >
< li class = "md-nav__item" >
2019-09-22 20:06:22 +00:00
< a href = "#the-nginxingresskubernetesiofastcgi-index-annotation" class = "md-nav__link" >
2019-08-01 23:58:36 +00:00
The nginx.ingress.kubernetes.io/fastcgi-index Annotation
< / a >
< / li >
< li class = "md-nav__item" >
2019-09-22 20:06:22 +00:00
< a href = "#the-nginxingresskubernetesiofastcgi-params-configmap-annotation" class = "md-nav__link" >
2019-08-01 23:58:36 +00:00
The nginx.ingress.kubernetes.io/fastcgi-params-configmap Annotation
< / a >
< / li >
< / ul >
< / nav >
< / li >
< / ul >
< / nav >
< / li >
< li class = "md-nav__item" >
< a href = "../ingress-path-matching/" title = "Regular expressions in paths" class = "md-nav__link" >
Regular expressions in paths
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../external-articles/" title = "External Articles" class = "md-nav__link" >
External Articles
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../miscellaneous/" title = "Miscellaneous" class = "md-nav__link" >
Miscellaneous
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../monitoring/" title = "Prometheus and Grafana installation" class = "md-nav__link" >
Prometheus and Grafana installation
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../multiple-ingress/" title = "Multiple Ingress controllers" class = "md-nav__link" >
Multiple Ingress controllers
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../tls/" title = "TLS/HTTPS" class = "md-nav__link" >
TLS/HTTPS
< / a >
< / li >
< li class = "md-nav__item md-nav__item--nested" >
< input class = "md-toggle md-nav__toggle" data-md-toggle = "nav-3-13" type = "checkbox" id = "nav-3-13" >
< label class = "md-nav__link" for = "nav-3-13" >
Third party addons
< / label >
< nav class = "md-nav" data-md-component = "collapsible" data-md-level = "2" >
< label class = "md-nav__title" for = "nav-3-13" >
Third party addons
< / label >
< ul class = "md-nav__list" data-md-scrollfix >
< li class = "md-nav__item" >
< a href = "../third-party-addons/modsecurity/" title = "ModSecurity Web Application Firewall" class = "md-nav__link" >
ModSecurity Web Application Firewall
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../third-party-addons/opentracing/" title = "OpenTracing" class = "md-nav__link" >
OpenTracing
< / a >
< / li >
< / ul >
< / nav >
< / li >
< / ul >
< / nav >
< / li >
< li class = "md-nav__item md-nav__item--nested" >
< input class = "md-toggle md-nav__toggle" data-md-toggle = "nav-4" type = "checkbox" id = "nav-4" >
< label class = "md-nav__link" for = "nav-4" >
Examples
< / label >
< nav class = "md-nav" data-md-component = "collapsible" data-md-level = "1" >
< label class = "md-nav__title" for = "nav-4" >
Examples
< / label >
< ul class = "md-nav__list" data-md-scrollfix >
< li class = "md-nav__item" >
< a href = "../../examples/" title = "Introduction" class = "md-nav__link" >
Introduction
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/PREREQUISITES/" title = "Prerequisites" class = "md-nav__link" >
Prerequisites
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/affinity/cookie/" title = "Sticky Sessions" class = "md-nav__link" >
Sticky Sessions
< / a >
< / li >
< li class = "md-nav__item md-nav__item--nested" >
< input class = "md-toggle md-nav__toggle" data-md-toggle = "nav-4-4" type = "checkbox" id = "nav-4-4" >
< label class = "md-nav__link" for = "nav-4-4" >
Auth
< / label >
< nav class = "md-nav" data-md-component = "collapsible" data-md-level = "2" >
< label class = "md-nav__title" for = "nav-4-4" >
Auth
< / label >
< ul class = "md-nav__list" data-md-scrollfix >
< li class = "md-nav__item" >
< a href = "../../examples/auth/basic/" title = "Basic Authentication" class = "md-nav__link" >
Basic Authentication
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/auth/client-certs/" title = "Client Certificate Authentication" class = "md-nav__link" >
Client Certificate Authentication
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/auth/external-auth/" title = "External Basic Authentication" class = "md-nav__link" >
External Basic Authentication
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/auth/oauth-external-auth/" title = "External OAUTH Authentication" class = "md-nav__link" >
External OAUTH Authentication
< / a >
< / li >
< / ul >
< / nav >
< / li >
< li class = "md-nav__item md-nav__item--nested" >
< input class = "md-toggle md-nav__toggle" data-md-toggle = "nav-4-5" type = "checkbox" id = "nav-4-5" >
< label class = "md-nav__link" for = "nav-4-5" >
Customization
< / label >
< nav class = "md-nav" data-md-component = "collapsible" data-md-level = "2" >
< label class = "md-nav__title" for = "nav-4-5" >
Customization
< / label >
< ul class = "md-nav__list" data-md-scrollfix >
< li class = "md-nav__item" >
< a href = "../../examples/customization/configuration-snippets/" title = "Configuration Snippets" class = "md-nav__link" >
Configuration Snippets
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/customization/custom-configuration/" title = "Custom Configuration" class = "md-nav__link" >
Custom Configuration
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/customization/custom-errors/" title = "Custom Errors" class = "md-nav__link" >
Custom Errors
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/customization/custom-headers/" title = "Custom Headers" class = "md-nav__link" >
Custom Headers
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/customization/external-auth-headers/" title = "External authentication" class = "md-nav__link" >
External authentication
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/customization/ssl-dh-param/" title = "Custom DH parameters for perfect forward secrecy" class = "md-nav__link" >
Custom DH parameters for perfect forward secrecy
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/customization/sysctl/" title = "Sysctl tuning" class = "md-nav__link" >
Sysctl tuning
< / a >
< / li >
< / ul >
< / nav >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/docker-registry/" title = "Docker registry" class = "md-nav__link" >
Docker registry
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/grpc/" title = "gRPC" class = "md-nav__link" >
gRPC
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/multi-tls/" title = "Multi TLS certificate termination" class = "md-nav__link" >
Multi TLS certificate termination
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/rewrite/" title = "Rewrite" class = "md-nav__link" >
Rewrite
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/static-ip/" title = "Static IPs" class = "md-nav__link" >
Static IPs
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/tls-termination/" title = "TLS termination" class = "md-nav__link" >
TLS termination
< / a >
< / li >
< li class = "md-nav__item" >
< a href = "../../examples/psp/" title = "Pod Security Policy (PSP)" class = "md-nav__link" >
Pod Security Policy (PSP)
< / a >
< / li >
< / ul >
< / nav >
< / li >
< / ul >
< / nav >
< / div >
< / div >
< / div >
< div class = "md-sidebar md-sidebar--secondary" data-md-component = "toc" >
< div class = "md-sidebar__scrollwrap" >
< div class = "md-sidebar__inner" >
< nav class = "md-nav md-nav--secondary" >
< label class = "md-nav__title" for = "__toc" > Table of contents< / label >
< ul class = "md-nav__list" data-md-scrollfix >
< li class = "md-nav__item" >
2019-09-22 20:06:22 +00:00
< a href = "#example-objects-to-expose-a-fastcgi-pod" class = "md-nav__link" >
2019-08-01 23:58:36 +00:00
Example Objects to Expose a FastCGI Pod
< / a >
< / li >
< li class = "md-nav__item" >
2020-02-09 23:53:05 +00:00
< a href = "#fastcgi-ingress-annotations" class = "md-nav__link" >
FastCGI Ingress Annotations
2019-08-01 23:58:36 +00:00
< / a >
< nav class = "md-nav" >
< ul class = "md-nav__list" >
< li class = "md-nav__item" >
2019-09-22 20:06:22 +00:00
< a href = "#the-nginxingresskubernetesiofastcgi-index-annotation" class = "md-nav__link" >
2019-08-01 23:58:36 +00:00
The nginx.ingress.kubernetes.io/fastcgi-index Annotation
< / a >
< / li >
< li class = "md-nav__item" >
2019-09-22 20:06:22 +00:00
< a href = "#the-nginxingresskubernetesiofastcgi-params-configmap-annotation" class = "md-nav__link" >
2019-08-01 23:58:36 +00:00
The nginx.ingress.kubernetes.io/fastcgi-params-configmap Annotation
< / a >
< / li >
< / ul >
< / nav >
< / li >
< / ul >
< / nav >
< / div >
< / div >
< / div >
< div class = "md-content" >
< article class = "md-content__inner md-typeset" >
< a href = "https://github.com/kubernetes/ingress-nginx/edit/master/docs/user-guide/fcgi-services.md" title = "Edit this page" class = "md-icon md-content__icon" >  < / a >
2019-11-08 19:24:34 +00:00
< h1 id = "exposing-fastcgi-servers" > Exposing FastCGI Servers< a class = "headerlink" href = "#exposing-fastcgi-servers" title = "Permanent link" > ¶< / a > < / h1 >
2019-08-01 23:58:36 +00:00
< blockquote >
< p > < strong > FastCGI< / strong > is a < a href = "https://en.wikipedia.org/wiki/Binary_protocol" title = "Binary protocol" > binary protocol< / a > for interfacing interactive programs with a < a href = "https://en.wikipedia.org/wiki/Web_server" title = "Web server" > web server< / a > . [...] (It's) aim is to reduce the overhead related to interfacing between web server and CGI programs, allowing a server to handle more web page requests per unit of time.< / p >
< p > — Wikipedia< / p >
< / blockquote >
2020-02-09 23:53:05 +00:00
< p > The < em > ingress-nginx< / em > ingress controller can be used to directly expose < a href = "https://en.wikipedia.org/wiki/FastCGI" > FastCGI< / a > servers. Enabling FastCGI in your Ingress only requires setting the < em > backend-protocol< / em > annotation to < code class = "codehilite" > < span class = "err" > FCGI< / span > < / code > , and with a couple more annotations you can customize the way < em > ingress-nginx< / em > handles the communication with your FastCGI < em > server< / em > .< / p >
2019-11-08 19:24:34 +00:00
< h2 id = "example-objects-to-expose-a-fastcgi-pod" > Example Objects to Expose a FastCGI Pod< a class = "headerlink" href = "#example-objects-to-expose-a-fastcgi-pod" title = "Permanent link" > ¶< / a > < / h2 >
2020-02-09 23:53:05 +00:00
< p > The < em > Pod< / em > example object below exposes port < code class = "codehilite" > < span class = "err" > 9000< / span > < / code > , which is the conventional FastCGI port.< / p >
< div class = "codehilite" > < pre > < span > < / span > < code > < span class = "nt" > apiVersion< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > v1< / span >
2019-08-01 23:58:36 +00:00
< span class = "nt" > kind< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > Pod< / span >
< span class = "nt" > metadata< / span > < span class = "p" > :< / span >
< span class = "nt" > name< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > example-app< / span >
< span class = "nt" > labels< / span > < span class = "p" > :< / span >
< span class = "nt" > app< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > example-app< / span >
< span class = "nt" > spec< / span > < span class = "p" > :< / span >
< span class = "nt" > containers< / span > < span class = "p" > :< / span >
< span class = "p p-Indicator" > -< / span > < span class = "nt" > name< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > example-app< / span >
< span class = "nt" > image< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > example-app:1.0< / span >
< span class = "nt" > ports< / span > < span class = "p" > :< / span >
< span class = "p p-Indicator" > -< / span > < span class = "nt" > containerPort< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > 9000< / span >
< span class = "nt" > name< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > fastcgi< / span >
2020-02-09 23:53:05 +00:00
< / code > < / pre > < / div >
2019-08-01 23:58:36 +00:00
2020-02-09 23:53:05 +00:00
< p > The < em > Service< / em > object example below matches port < code class = "codehilite" > < span class = "err" > 9000< / span > < / code > from the < em > Pod< / em > object above.< / p >
< div class = "codehilite" > < pre > < span > < / span > < code > < span class = "nt" > apiVersion< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > v1< / span >
2019-08-01 23:58:36 +00:00
< span class = "nt" > kind< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > Service< / span >
< span class = "nt" > metadata< / span > < span class = "p" > :< / span >
< span class = "nt" > name< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > example-service< / span >
< span class = "nt" > spec< / span > < span class = "p" > :< / span >
< span class = "nt" > selector< / span > < span class = "p" > :< / span >
< span class = "nt" > app< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > example-app< / span >
< span class = "nt" > ports< / span > < span class = "p" > :< / span >
< span class = "p p-Indicator" > -< / span > < span class = "nt" > port< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > 9000< / span >
< span class = "nt" > targetPort< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > 9000< / span >
< span class = "nt" > name< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > fastcgi< / span >
2020-02-09 23:53:05 +00:00
< / code > < / pre > < / div >
2019-08-01 23:58:36 +00:00
2020-02-09 23:53:05 +00:00
< p > And the < em > Ingress< / em > and < em > ConfigMap< / em > objects below demonstrates the supported < em > FastCGI< / em > specific annotations (NGINX actually has 50 FastCGI directives, all of which have not been exposed in the ingress yet), and matches the service < code class = "codehilite" > < span class = "err" > example-service< / span > < / code > , and the port named < code class = "codehilite" > < span class = "err" > fastcgi< / span > < / code > from above. The < em > ConfigMap< / em > < strong > must< / strong > be created first for the < em > Ingress Controller< / em > to be able to find it when the < em > Ingress< / em > object is created, otherwise you will need to restart the < em > Ingress Controller< / em > pods.< / p >
< div class = "codehilite" > < pre > < span > < / span > < code > < span class = "c1" > # The ConfigMap MUST be created first for the ingress controller to be able to< / span >
2019-08-01 23:58:36 +00:00
< span class = "c1" > # find it when the Ingress object is created.< / span >
< span class = "nt" > apiVersion< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > v1< / span >
< span class = "nt" > kind< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > ConfigMap< / span >
< span class = "nt" > metadata< / span > < span class = "p" > :< / span >
< span class = "nt" > name< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > example-cm< / span >
< span class = "nt" > data< / span > < span class = "p" > :< / span >
< span class = "nt" > SCRIPT_FILENAME< / span > < span class = "p" > :< / span > < span class = "s" > " /example/index.php" < / span >
< span class = "nn" > ---< / span >
2019-12-17 16:46:43 +00:00
< span class = "nt" > apiVersion< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > networking.k8s.io/v1beta1< / span >
2019-08-01 23:58:36 +00:00
< span class = "nt" > kind< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > Ingress< / span >
< span class = "nt" > metadata< / span > < span class = "p" > :< / span >
< span class = "nt" > annotations< / span > < span class = "p" > :< / span >
< span class = "nt" > kubernetes.io/ingress.class< / span > < span class = "p" > :< / span > < span class = "s" > " nginx" < / span >
< span class = "nt" > nginx.ingress.kubernetes.io/backend-protocol< / span > < span class = "p" > :< / span > < span class = "s" > " FCGI" < / span >
< span class = "nt" > nginx.ingress.kubernetes.io/fastcgi-index< / span > < span class = "p" > :< / span > < span class = "s" > " index.php" < / span >
< span class = "nt" > nginx.ingress.kubernetes.io/fastcgi-params-configmap< / span > < span class = "p" > :< / span > < span class = "s" > " example-cm" < / span >
< span class = "nt" > name< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > example-app< / span >
< span class = "nt" > spec< / span > < span class = "p" > :< / span >
< span class = "nt" > rules< / span > < span class = "p" > :< / span >
< span class = "p p-Indicator" > -< / span > < span class = "nt" > host< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > app.example.com< / span >
< span class = "nt" > http< / span > < span class = "p" > :< / span >
< span class = "nt" > paths< / span > < span class = "p" > :< / span >
< span class = "p p-Indicator" > -< / span > < span class = "nt" > backend< / span > < span class = "p" > :< / span >
< span class = "nt" > serviceName< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > example-service< / span >
< span class = "nt" > servicePort< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > fastcgi< / span >
2020-02-09 23:53:05 +00:00
< / code > < / pre > < / div >
2019-08-01 23:58:36 +00:00
2020-02-09 23:53:05 +00:00
< h2 id = "fastcgi-ingress-annotations" > FastCGI Ingress Annotations< a class = "headerlink" href = "#fastcgi-ingress-annotations" title = "Permanent link" > ¶< / a > < / h2 >
< p > To enable FastCGI, the < code class = "codehilite" > < span class = "err" > nginx.ingress.kubernetes.io/backend-protocol< / span > < / code > annotation needs to be set to < code class = "codehilite" > < span class = "err" > FCGI< / span > < / code > , which overrides the default < code class = "codehilite" > < span class = "err" > HTTP< / span > < / code > value.< / p >
2019-08-01 23:58:36 +00:00
< blockquote >
2020-02-09 23:53:05 +00:00
< p > < code class = "codehilite" > < span class = "err" > nginx.ingress.kubernetes.io/backend-protocol: " FCGI" < / span > < / code > < / p >
2019-08-01 23:58:36 +00:00
< / blockquote >
2020-02-09 23:53:05 +00:00
< p > < strong > This enables the < em > FastCGI< / em > mode for all paths defined in the < em > Ingress< / em > object< / strong > < / p >
< h3 id = "the-nginxingresskubernetesiofastcgi-index-annotation" > The < code class = "codehilite" > < span class = "err" > nginx.ingress.kubernetes.io/fastcgi-index< / span > < / code > Annotation< a class = "headerlink" href = "#the-nginxingresskubernetesiofastcgi-index-annotation" title = "Permanent link" > ¶< / a > < / h3 >
< p > To specify an index file, the < code class = "codehilite" > < span class = "err" > fastcgi-index< / span > < / code > annotation value can optionally be set. In the example below, the value is set to < code class = "codehilite" > < span class = "err" > index.php< / span > < / code > . This annotation corresponds to < a href = "http://nginx.org/en/docs/http/ngx_http_fastcgi_module.html#fastcgi_index" > the < em > NGINX< / em > < code class = "codehilite" > < span class = "err" > fastcgi_index< / span > < / code > directive< / a > .< / p >
2019-08-01 23:58:36 +00:00
< blockquote >
2020-02-09 23:53:05 +00:00
< p > < code class = "codehilite" > < span class = "err" > nginx.ingress.kubernetes.io/fastcgi-index: " index.php" < / span > < / code > < / p >
2019-08-01 23:58:36 +00:00
< / blockquote >
2020-02-09 23:53:05 +00:00
< h3 id = "the-nginxingresskubernetesiofastcgi-params-configmap-annotation" > The < code class = "codehilite" > < span class = "err" > nginx.ingress.kubernetes.io/fastcgi-params-configmap< / span > < / code > Annotation< a class = "headerlink" href = "#the-nginxingresskubernetesiofastcgi-params-configmap-annotation" title = "Permanent link" > ¶< / a > < / h3 >
< p > To specify < a href = "http://nginx.org/en/docs/http/ngx_http_fastcgi_module.html#fastcgi_param" > < em > NGINX< / em > < code class = "codehilite" > < span class = "err" > fastcgi_param< / span > < / code > directives< / a > , the < code class = "codehilite" > < span class = "err" > fastcgi-params-configmap< / span > < / code > annotation is used, which in turn must lead to a < em > ConfigMap< / em > object containing the < em > NGINX< / em > < code class = "codehilite" > < span class = "err" > fastcgi_param< / span > < / code > directives as key/values.< / p >
2019-08-01 23:58:36 +00:00
< blockquote >
2020-02-09 23:53:05 +00:00
< p > < code class = "codehilite" > < span class = "err" > nginx.ingress.kubernetes.io/fastcgi-params-configmap: " example-configmap" < / span > < / code > < / p >
2019-08-01 23:58:36 +00:00
< / blockquote >
2020-02-09 23:53:05 +00:00
< p > And the < em > ConfigMap< / em > object to specify the < code class = "codehilite" > < span class = "err" > SCRIPT_FILENAME< / span > < / code > and < code class = "codehilite" > < span class = "err" > HTTP_PROXY< / span > < / code > < em > NGINX's< / em > < code class = "codehilite" > < span class = "err" > fastcgi_param< / span > < / code > directives will look like the following:< / p >
< p > < div class = "codehilite" > < pre > < span > < / span > < code > < span class = "nt" > apiVersion< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > v1< / span >
2019-08-01 23:58:36 +00:00
< span class = "nt" > kind< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > ConfigMap< / span >
< span class = "nt" > metadata< / span > < span class = "p" > :< / span >
< span class = "nt" > name< / span > < span class = "p" > :< / span > < span class = "l l-Scalar l-Scalar-Plain" > example-configmap< / span >
< span class = "nt" > data< / span > < span class = "p" > :< / span >
< span class = "nt" > SCRIPT_FILENAME< / span > < span class = "p" > :< / span > < span class = "s" > " /example/index.php" < / span >
< span class = "nt" > HTTP_PROXY< / span > < span class = "p" > :< / span > < span class = "s" > " " < / span >
2020-02-09 23:53:05 +00:00
< / code > < / pre > < / div >
2019-08-01 23:58:36 +00:00
Using the < em > namespace/< / em > prefix is also supported, for example:< / p >
< blockquote >
2020-02-09 23:53:05 +00:00
< p > < code class = "codehilite" > < span class = "err" > nginx.ingress.kubernetes.io/fastcgi-params-configmap: " example-namespace/example-configmap" < / span > < / code > < / p >
2019-08-01 23:58:36 +00:00
< / blockquote >
2020-02-09 23:53:05 +00:00
2019-08-01 23:58:36 +00:00
< / article >
< / div >
< / div >
< / main >
< footer class = "md-footer" >
< div class = "md-footer-nav" >
< nav class = "md-footer-nav__inner md-grid" >
< a href = "../exposing-tcp-udp-services/" title = "Exposing TCP and UDP services" class = "md-flex md-footer-nav__link md-footer-nav__link--prev" rel = "prev" >
< div class = "md-flex__cell md-flex__cell--shrink" >
< i class = "md-icon md-icon--arrow-back md-footer-nav__button" > < / i >
< / div >
< div class = "md-flex__cell md-flex__cell--stretch md-footer-nav__title" >
< span class = "md-flex__ellipsis" >
< span class = "md-footer-nav__direction" >
Previous
< / span >
Exposing TCP and UDP services
< / span >
< / div >
< / a >
< a href = "../ingress-path-matching/" title = "Regular expressions in paths" class = "md-flex md-footer-nav__link md-footer-nav__link--next" rel = "next" >
< div class = "md-flex__cell md-flex__cell--stretch md-footer-nav__title" >
< span class = "md-flex__ellipsis" >
< span class = "md-footer-nav__direction" >
Next
< / span >
Regular expressions in paths
< / span >
< / div >
< div class = "md-flex__cell md-flex__cell--shrink" >
< i class = "md-icon md-icon--arrow-forward md-footer-nav__button" > < / i >
< / div >
< / a >
< / nav >
< / div >
< div class = "md-footer-meta md-typeset" >
< div class = "md-footer-meta__inner md-grid" >
< div class = "md-footer-copyright" >
powered by
2020-02-09 23:53:05 +00:00
< a href = "https://www.mkdocs.org" target = "_blank" rel = "noopener" > MkDocs< / a >
2019-08-01 23:58:36 +00:00
and
2020-02-09 23:53:05 +00:00
< a href = "https://squidfunk.github.io/mkdocs-material/" target = "_blank" rel = "noopener" >
2019-08-01 23:58:36 +00:00
Material for MkDocs< / a >
< / div >
< / div >
< / div >
< / footer >
< / div >
2020-02-24 22:42:17 +00:00
< script src = "../../assets/javascripts/application.df00da5d.js" > < / script >
2019-08-01 23:58:36 +00:00
< script > app . initialize ( { version : "1.0.4" , url : { base : "../.." } } ) < / script >
< / body >
< / html >