nginx配置实现代理多个内网地址
2014-06-24 21:16
253 查看
网上看到一个例子,如果配置内网的,但是如果网页包含本地图片的时候(如果引用URL地址的图片不会有问题),会导致页面无法正常显示。
下面是在例子的基础上,做了红色部分的修改:
假设在内网有多个地址,比如:
http://192.168.10.1/manage http://192.168.10.2/manage2
有一个对外的公网地址100.100.112.121,想实现请求:
访问100.100.112.121/bbsadmin 就访问到http://192.168.10.1/manage
访问100.100.112.121/cmsadmin就访问到http://192.168.10.1/manage2
配置如下:
server {
listen 5000;
server_name 127.0.0.1;
charset utf-8;
location / {
root html;
index index.html index.htm;
}
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;
}
说明:如果网站页面上包含本地图片的话,通过nginx可能出现无法显示的情况,这个时候需要在server配置节(注意是当前设置代理的server。今天就犯错了,把这个配置节写在nginx自身端口的server配置节了)设置:
location ~* \.(css|js|jpg|bng|html|css|png|gif|ico|)$ {
root d:/NodeJs/nodeJS项目;#静态文件保存目录的上一级父目录
expires 24h; #设置过期时间
}
location /bbsadmin {
proxy_pass http://192.168.10.1/manage; proxy_redirect off;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $http_host;
}
location /cmsadmin{
proxy_pass http://192.168.10.1/manage2; proxy_redirect off;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $http_host;
}
}
root path
在server中:表示全局的,对所有有的location都有意义。
在location:局部的资源定义
location /a/ {
root /var/www/;
}
location / 就代表 location 里面的 root,若是location里的 root 未定义,就从 server 里面继承!
下面是在例子的基础上,做了红色部分的修改:
假设在内网有多个地址,比如:
http://192.168.10.1/manage http://192.168.10.2/manage2
有一个对外的公网地址100.100.112.121,想实现请求:
访问100.100.112.121/bbsadmin 就访问到http://192.168.10.1/manage
访问100.100.112.121/cmsadmin就访问到http://192.168.10.1/manage2
配置如下:
server {
listen 5000;
server_name 127.0.0.1;
charset utf-8;
location / {
root html;
index index.html index.htm;
}
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;
}
说明:如果网站页面上包含本地图片的话,通过nginx可能出现无法显示的情况,这个时候需要在server配置节(注意是当前设置代理的server。今天就犯错了,把这个配置节写在nginx自身端口的server配置节了)设置:
location ~* \.(css|js|jpg|bng|html|css|png|gif|ico|)$ {
root d:/NodeJs/nodeJS项目;#静态文件保存目录的上一级父目录
expires 24h; #设置过期时间
}
location /bbsadmin {
proxy_pass http://192.168.10.1/manage; proxy_redirect off;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $http_host;
}
location /cmsadmin{
proxy_pass http://192.168.10.1/manage2; proxy_redirect off;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $http_host;
}
}
root path
在server中:表示全局的,对所有有的location都有意义。
在location:局部的资源定义
location /a/ {
root /var/www/;
}
location / 就代表 location 里面的 root,若是location里的 root 未定义,就从 server 里面继承!
相关文章推荐
- Nginx安装配置,简单构建LNMP环境配置反向代理,实现动静分离,以及实现负载均衡。
- 使用apache和nginx代理实现tomcat负载均衡及集群配置详解
- Python+Nginx实现邮件POP、IMAP、SMTP代理配置介绍
- NGINX 实现内部网络的HTTP代理服务器的配置
- nginx 个人配置,实现简单反向代理
- Python+Nginx实现邮件POP、IMAP、SMTP代理配置介绍
- 用反向代理nginx proxy_pass配置解决ie8 ajax请求被拦截问题 ie8用nginx代理实现跨域请求访问 nginx405正向代理request_uri
- nginx内网代理为外网地址
- 智能一代云平台(十七):Keepalived+Nginx实现高可用,反向代理---Keepalived安装及相关配置
- nginx反向代理tomcat、实现动静分离/配置文件
- Nginx正反向代理、负载均衡等功能实现配置
- centos6.5环境自动化运维之puppet实现nginx反向代理功能及puppet安装配置详解
- Nginx反向代理Tomcat实现现负载均衡(高可用)以及利用redis+Session同步会话共享配置详解
- 反向代理概念以及apache,nginx配置反向代理实现负载均衡方法
- windows上 nginx 配置代理服务,配置多域名,以及最简单实现跨域配置
- Nginx正反向代理、负载均衡等功能实现配置
- Nginx正反向代理、负载均衡等功能实现配置
- vue-cli项目开发/生产环境代理实现跨域请求+webpack配置开发/生产环境的接口地址
- nginx配置程序重定向时跳转到内网地址,无法正常使用
- windows利用iis配置反向代理实现ECS内网互通oss