The Funtoo Linux project has transitioned to "Hobby Mode" and this wiki is now read-only.
Difference between revisions of "Package:Tengine"
Threesixes (talk | contribs) m (add passenger garbage) |
m |
||
Line 2: | Line 2: | ||
|Summary=Robust, small and high performance http and reverse proxy server | |Summary=Robust, small and high performance http and reverse proxy server | ||
|CatPkg=www-servers/tengine | |CatPkg=www-servers/tengine | ||
|Homepage=http://tengine.taobao.org | |Homepage=http://tengine.taobao.org | ||
}} | }} | ||
Line 23: | Line 22: | ||
TENGINE_EXTERNAL_MODULES_HTTP="passenger" | TENGINE_EXTERNAL_MODULES_HTTP="passenger" | ||
}} | }} | ||
{{important|Actual version of tengine complains about a missing group and fails to configure, just "groupadd tengine" before you emerge.}} | |||
Then, just: | Then, just: | ||
Line 38: | Line 39: | ||
load ngx_http_fastcgi_module.so; | load ngx_http_fastcgi_module.so; | ||
load ngx_http_rewrite_module.so; | load ngx_http_rewrite_module.so; | ||
load ngx_http_access_module.so; ## added because you want most likely use allow & deny on certain positions | |||
} | } | ||
... | ... | ||
Line 47: | Line 49: | ||
===Sites=== | ===Sites=== | ||
{{c|/etc/tengine/sites-available/localhost}} has site specific configurations. Generally localhost is copied to domain.tld file formats in the {{c|/etc/tengine/sites-available/}} directory. | {{c|/etc/tengine/sites-available/localhost}} has site specific configurations. Generally localhost is copied to domain.tld file formats in the {{c|/etc/tengine/sites-available/}} directory. | ||
===Redirection=== | |||
These days, it is usual to have anything on https to protect your users regarding login and privacy where it comes handy to automatically redirect requests from http which are often a result of the browsers autocompletion. To achieve that, we need a server listening on http and redirecting to our main server on https like this : | |||
{{file|name=/etc/tengine/sites-available/redir|desc=redirection from http to https|body= | |||
server { | |||
server_name domain.tld; | |||
listen 80; | |||
return 302 https://www.domain.tld$request_uri; | |||
} | |||
}} | |||
===PHP-FPM=== | ===PHP-FPM=== | ||
Line 68: | Line 82: | ||
{{console|body=###i## rc-update add tengine default | {{console|body=###i## rc-update add tengine default | ||
###i## rc}} | ###i## rc}} | ||
{{EbuildFooter}} | {{EbuildFooter}} |
Revision as of 12:52, April 10, 2015
Tengine
We welcome improvements to this page. To edit this page, Create a Funtoo account. Then log in and then click here to edit this page. See our editing guidelines to becoming a wiki-editing pro.
Tengine is an www-servers/nginx fork. It supports DSO module loading, meaning it can have external modules without the need to compile them in.
Installation
If you happen to want all modules installed dynamically, you, still, need to install some static modules. Make sure to add this to your /etc/portage/make.conf
file:
/etc/portage/make.conf
- Tengine all-modules build...
TENGINE_SHARED_MODULES_HTTP="access addition autoindex browser charset_filter empty_gif fastcgi flv footer_filter geoip image_filter limit_conn limit_req lua map memcached mp4 random_index referer reqstat rewrite scgi secure_link slice split_clients sub sysguard tfs trim_filter upstream_ip_hash upstream_least_conn upstream_session_sticky user_agent userid_filter uwsgi xslt"
TENGINE_STATIC_MODULES_HTTP="concat dav degradation geo gunzip gzip gzip_static perl proxy realip spdy ssi ssl stub_status upstream-rbtree upstream_check upstream_consistent_hash upstream_keepalive"
...
External Modules
If you want to run passenger:
/etc/portage/make.conf
- build the passenger moduleTENGINE_EXTERNAL_MODULES_HTTP="passenger"
Actual version of tengine complains about a missing group and fails to configure, just "groupadd tengine" before you emerge.
Then, just:
root # emerge tengine
Configuration
Files for configuration are located at /etc/tengine
The major differing point in tengine from nginx is that you have to specifically declare which modules are loaded. Available modules are located at /var/lib/tengine/modules
.
/etc/tengine/tengine.conf
- DSO module statements...
dso {
load ngx_http_charset_filter_module.so;
load ngx_http_fastcgi_module.so;
load ngx_http_rewrite_module.so;
load ngx_http_access_module.so; ## added because you want most likely use allow & deny on certain positions
}
...
Tengine
/etc/tengine/tengine.conf
contains engine specific configurations.
Sites
/etc/tengine/sites-available/localhost
has site specific configurations. Generally localhost is copied to domain.tld file formats in the /etc/tengine/sites-available/
directory.
Redirection
These days, it is usual to have anything on https to protect your users regarding login and privacy where it comes handy to automatically redirect requests from http which are often a result of the browsers autocompletion. To achieve that, we need a server listening on http and redirecting to our main server on https like this :
/etc/tengine/sites-available/redir
- redirection from http to httpsserver {
server_name domain.tld;
listen 80;
return 302 https://www.domain.tld$request_uri;
}
PHP-FPM
Tengine does not natively support php, so we delegate that responsibility to php-fpm
/etc/tengine/sites-available/localhost
- fpm tcp/ip configurationserver {
...
index index.php index.cgi index.htm index.html;
location ~ \.php$ {
fastcgi_pass 127.0.0.1:9000;
include fastcgi.conf;
}
...
}
Usage
To start the tengine server:
root # rc-update add tengine default root # rc