参考文章:http://www.jrrzz.net/2010/01/10/multi-host-trac-using-nginx/
我觉得多实例运行的关键点在于对 fastcgi中的script_name和path_info的理解
script_name是脚本名称,我们可以理解成应用的一个入口
path_name是传给这个入口的一个参数,是一个路径
比如在php中
http://www.test.com/index.php/foo/bar.html?c=index&m=search
这里的/index.php为script_name
/foo/bar.html为path_info
再后面的就为query_string鸟
在我们这里如果我们想这样运行多实例
http://xxx.com/trac/instance1/wiki
http://xxx.com/trac/instance2/wiki
就是使用这样的方式在运行instance1和instance2这两个trac的项目实例
那么我们就得设置/trac/instancex(x为可变的部分)为script_name
而后面的为path_info
比如这里的/wiki即为path_info
理解这点我们不难理解下面的配置文件了.
这里很欣赏nginx的配置文件的语法,弄的和脚本语言似的,有正则,有判断,有赋值
PS:为了彻底弄清楚fastcgi_split_path_info这个指令的工作原理,还去看了下nginx的源码,还好有c语言的功底.
这个没有文档的东东还真不容易找一些想知道的东西,除了看源码.
--------------------------------------------
回复
回推
New Retweet
收藏
from Echofon2010-04-16 09:37:16
回复
回推
New Retweet
收藏
from Echofon2010-04-16 09:50:26
回复
回推
New Retweet
收藏
from Echofon2010-04-16 09:51:47
----------------------------------------------------
下面是nginx的配置文件
user admin;
worker_processes 5;
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#access_log logs/access.log main;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
server {
listen 80;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location ~ ^/trac/([0-9a-zA-Z\-]*)/chrome(.*)$ {
alias /home/admin/trac/$1/htdocs$2;
}
fastcgi_split_path_info ^(/trac/[0-9a-zA-Z\-_]*[/]*)(.*)$;
location ~ /htdocs/(.*){
root /home/admin/trac;
}
if ($uri ~ ^/trac/([0-9a-zA-Z\-_]*).*$) {
set $trac_host $1;
}
location ~ ^/trac/([0-9a-zA-Z\-]*)/login {
auth_basic "trac";
auth_basic_user_file /home/admin/etc/trac_$trac_host.htpasswd;
fastcgi_pass unix:/home/admin/run/trac_fastcgi_$trac_host.sock;
fastcgi_param REQUEST_METHOD $request_method;
fastcgi_param SERVER_NAME $server_name;
fastcgi_param SERVER_PORT $server_port;
fastcgi_param SERVER_PROTOCOL $server_protocol;
fastcgi_param QUERY_STRING $query_string;
fastcgi_param REMOTE_USER $remote_user;
fastcgi_param AUTH_USER $remote_user;
fastcgi_param SCRIPT_NAME /trac/$trac_host;
fastcgi_param PATH_INFO /$fastcgi_path_info;
fastcgi_param REMOTE_ADDR $remote_addr;
}
location ~ ^/trac {
auth_basic "trac";
fastcgi_pass unix:/home/admin/run/trac_fastcgi_$trac_host.sock;
fastcgi_param SCRIPT_NAME /trac/$trac_host;
fastcgi_param PATH_INFO /$fastcgi_path_info;
## WSGI NEEDED VARIABLES - trac warns about them
fastcgi_param REQUEST_METHOD $request_method;
fastcgi_param SERVER_NAME $server_name;
fastcgi_param SERVER_PORT $server_port;
fastcgi_param SERVER_PROTOCOL $server_protocol;
fastcgi_param QUERY_STRING $query_string;
fastcgi_param REMOTE_USER $remote_user;
fastcgi_param AUTH_USER $remote_user;
fastcgi_param REMOTE_ADDR $remote_addr;
#root html;
#index index.html index.htm;
}
location = / {
index index.html
}
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
# proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ \.php$ {
# proxy_pass http://127.0.0.1;
#}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
#location ~ \.php$ {
# root html;
# fastcgi_pass 127.0.0.1:9000;
# fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
# include fastcgi_params;
#}
# deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
#location ~ /\.ht {
# deny all;
#}
}
# another virtual host using mix of IP-, name-, and port-based configuration
#
#server {
# listen 8000;
# listen somename:8080;
# server_name somename alias another.alias;
# location / {
# root html;
# index index.html index.htm;
# }
#}
# HTTPS server
#
#server {
# listen 443;
# server_name localhost;
# ssl on;
# ssl_certificate cert.pem;
# ssl_certificate_key cert.key;
# ssl_session_timeout 5m;
# ssl_protocols SSLv2 SSLv3 TLSv1;
# ssl_ciphers ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;
# ssl_prefer_server_ciphers on;
# location / {
# root html;
# index index.html index.htm;
# }
#}
}
- 大小: 51 KB
分享到:
相关推荐
在实际操作时,请确保对每个步骤都进行适当的调整和确认,以确保顺利安装和运行Nginx服务器。此外,Nginx的配置十分灵活,可以根据需要配置反向代理、负载均衡、缓存等功能,这些都是高级用户常用的功能。
#### 一、启动错误:`sbin/nginx: error while loading shared libraries: libpcre.so.1: cannot open shared object file: No such file or directory` **问题描述**: 在尝试启动Nginx时,可能会遇到如下的错误...
Nginx 是由俄罗斯工程师Igor Sysoev 开发的一个高性能Web 服务器,运行效率远超传统的Apache、Tomcat,是世界第二大Web 服务器,被国内外诸多顶级互联网公司采用。 Nginx 的一个突出特点是其灵活优秀的模块化架构,...
quay.io/kubernetes-ingress-controller/nginx-ingress-controller:0.30.0
Nginx 问题 之 nginx: [emerg] unknown directive "echo" in /weblogic/nginx/conf/nginx.conf:43-附件资源
2. **反向代理服务器**:Nginx能够作为反向代理服务器,将客户端的请求转发到后端的多个服务器上,从而实现负载均衡。 3. **静态内容服务**:Nginx非常适合于提供静态内容,如图片、视频和HTML页面。 4. **SSL/TLS...
ngx_postgres是一个上游模块,允许nginx直接与PostgreSQL数据库通信。 响应以rds格式生成,因此与ngx_rds_json和ngx_drizzle模块兼容。 地位 该模块已准备好投入生产,并且与以下nginx版本兼容: 0.7.x(经0.7.60...
2. 配置 Nginx:可以使用配置文件来配置 Nginx,包括设置服务器根目录、端口号、虚拟主机、负载均衡等。 3. PHP-FPM 安装配置:可以使用 PHP-FPM 作为 FastCGI server,提供 PHP支持。 Nginx 的一些常见问题和解决...
#!/bin/sh # # nginx Startup script for nginx # # chkconfig: - 85 15 # processname: nginx # config: /etc/nginx/...# Short-Description: start and stop nginx ### END INIT INFO # Source function library.
image: nginx:latest ports: - containerPort: 80 volumeMounts: - mountPath: /var/www/html name: nginx-pv-storage volumes: - name: nginx-pv-storage persistentVolumeClaim: claimName: nginx-pvc `...
nginx1.18镜像包 使用docker load -i xx.tar 拉取镜像 使用docker images 查看是否成功。...-d nginx: 设置容器在在后台一直运行。 最后我们可以通过浏览器可以直接访问 8080 端口的 nginx 服务是否正常
arm 架构 docker运行nginx镜像包,arm 架构 docker运行nginx镜像包,arm 架构 docker运行nginx镜像包,arm 架构 docker运行nginx镜像包,arm 架构 docker运行nginx镜像包,arm 架构 docker运行nginx镜像包,arm 架构...
nginx ARM平台容器镜像
nginx:alpine离线镜像包,使用docker load -i nginxalpine.tar
nginx -t -c F:/nginx-1.12.2/conf/nginx.conf 测试nginx配置文件是否正确 start nginx nginx -s stop nginx -s quit nginx -s reload nginx -t 修改后的hosts文件放入c:\windows\system32\drivers\etc替换以前的...
nginx1.16镜像包 使用docker load -i xx.tar 拉取镜像 使用docker images 查看是否成功。...-d nginx: 设置容器在在后台一直运行。 最后我们可以通过浏览器可以直接访问 8080 端口的 nginx 服务是否正常
安装SSL证书时,强行杀掉了Nginx的进程,就再也没起来: Restarting nginx daemon: nginxcat: /usr/local/nginx/logs/nginx.pid: No such file or ...如何找回: 代码如下:issued a nginx -s stop and after that
从 S3 为您的静态主页提供服务,同时通过在 docker 中运行的 nginx 代理来保持存储桶的私密性。 用法 克隆这个 repo: git clone --recursive https://github.com/tinnet/docker-nginx-s3proxy.git 构建图像: ...
在文件中,你需要指定镜像(如`nginx:latest`)、副本数量、资源限制以及其他相关设置。例如: ```yaml apiVersion: apps/v1 kind: Deployment metadata: name: nginx-deployment spec: replicas: 3 ...