- 浏览: 461169 次
- 性别:
- 来自: 杭州
文章分类
最新评论
-
syw19901001:
30多条mysql数据库优化方法,千万级数据库记录查询轻松解决 ...
MYSQL的全表扫描,主键索引(聚集索引、第一索引),非主键索引(非聚集索引、第二索引),覆盖索引四种不同查询的分析 -
gaoyuanyuan121:
直接改成root.war,根路径能访问,项目路径也能访问,赞 ...
jetty 中如何设置root app -
freezingsky:
翻出来,再看一次!
AOP 的简单入门 -
Shen.Yiyang:
inter12 写道Shen.Yiyang 写道我说的不是NI ...
ReentrantLock、sync、ReentrantReadWriteLock性能比较 -
inter12:
Shen.Yiyang 写道我说的不是NIO和BIO的区别,而 ...
ReentrantLock、sync、ReentrantReadWriteLock性能比较
本文是基本已经安装nginx的前提下,若是未安装 sudo aptitude install nginx 即可!
一 反向代理
配置文件默认是在 /etc/nginx/nginx.conf
最新nginx是通过include指令读取其他的配置文件
include /etc/nginx/conf.d/*.conf;
include /etc/nginx/sites-enabled/*;
我们不需要改变这个自带的版本,有也不宜去改变。copy一份出来
cp /etc/nginx/nginx.conf /home/inter12/base/config/ #这个可以是你自己的任何目录
vim /home/inter12/base/config/nginx.conf 添加server
在
http { .... server { listen 9090; server_name localhost } ... include /etc/nginx/conf.d/*.conf; include /etc/nginx/sites-enabled/*; .... }
先暂时不需要理会是什么意思,确认下配置文件是否正确。
nginx -t -c /home/inter12/base/config/nginx.conf
nginx: the configuration file /home/inter12/base/config/nginx.conf syntax is ok
nginx: configuration file /home/inter12/base/config/nginx.conf test is successful
则表明是OK的。每次修改配置文件后,都可以采用这个命令来进行检查!
那么启动服务
nginx -c /home/inter12/base/config/nginx.conf
查看服务是否启动
ps -ef | grep nginx
netstat -anpl | grep 9090
浏览器访问 localhost:9090 出现一个 404错误页面 下面是 nginx/1.1.19 的话,恭喜你,第一步已经完成了!
listen 9090 //监听9090端口
server_name localhost //监听的IP是localhost ,这个地方可以写多个 server_name localhost inter12.iteye.com(需要修改你本地的/etc/hosts文件)
tips:
若是不注释include /etc/nginx/sites-enabled/*;的,那么两个配置都会生效。即
localhost:9090 访问回事一个404错误,因为我们还没有指定默认的跳转地址
localhost:80 访问到默认的nginx页面 : welcome to nginx!
到目前为止的配置,我们已经告诉nginx,若是碰到localhost:9090就给进行代理,下面就解决的问题是如何代理?
修改配置文件(一下所说的配置文件都是我们copy出来的那份文件,不是默认的那份配置文件).
http { ... server { ... charset utf-8; location / { proxy_pass http://wwww.dianping.com; } ... } }
重新启动:
sudo nginx -c /home/inter12/base/config/nginx.conf -s quit
sudo nginx -c /home/inter12/base/config/nginx.conf
或是:
sudo nginx -c /home/inter12/base/config/nginx.conf -s reload // 这个命令好像存在点问题!
这个时候访问
localhost:9090/ 就会跳转到 www.dianping.com
通过firebugs查看,这个跳转过程的状态码是301 .
若是加上
http {
... server { ... charset utf-8; location /hh { rewrite ^(.*) http://wwww.dianping.com; } ... } }
况
是服务器间的跳转,那么我需要跳转到一个具体的页面是怎么处理呢?请看下面
localhost:9090/hh 就会跳转到 www.dianping.com/hh 这个hh还会带过去,同理采用proxy_pass也会把location后面的路径带过去!
通过firebugs查看,这个跳转过程的状态码是302 .
延伸的说,我们可以采用rewirte配置统一的错误页面
error_page 403 404 500 /error; location /error { rewrite ^(.*) http://wwww.dianping.com/error; }
二 如何建立虚拟目录
存在两种方式alias和root.先看看alias怎么配置虚拟路径
location ~ ^/a/ { alias /home/inter12/base/temp/; }
配置后一直报403错误,查了下资料,可能是两个原因。
1.一般情况下nginx的用户是www-data, 属于www-data用户组。网页文件的属主一般不是www-data, 有可能造成不能访问。解决的办法是将网页文件的属主加到www-data用户组中:
usermod -G www-data inter12 .
2.当访问的url是一个路径而不是一个文件时,因为nginx默认是禁止列目录的,所以可能造成403返回。解决办法是在配置文件中加入默认访问文件。
location / {
root /www;
index index.php index.html index.htm ;
}
既然知道原因了,那解决起来就容易,简单的做法就是将/home/inter12/base/temp/这个目录赋予777的权限,另一种新建一个www-data用户将文件放在其根目录下。这里选择的是第二种:
useradd www-data -s /bin/bash -h /home/www-data cp /home/inter12/base/temp/hh.html /home/www-data/
修改配置为:
location ^~/a/{ alias /home/www-data/; }
http://localhost:9090/a/hh.html 就可以看到我们自己的页面。其实这个URL对应到文件中就是 /home/www-data/hh.html 会把location后面的/a/这个路径去除。
再看看root怎么配置虚拟路径
location ^~/r/{ root /home/www-data/; }
重新启动后访问http://localhost:9090/r/hh.html,OK页面出现。采用root方式对应的文件路径是 /home/www-data/r/hh.html 也就是说location后来的/r/这个,目录不会丢失。
这个也是采用alias和root的最大区别!
网上查了些资料,有些提出是若是 location / {}采用 root ,其他的 location /other {}采用alias。具体原因也未提,以后再深究。
几个要点
1.任何一个配置语句都需要分号(;)结尾。
2.采用alias的话必须配置成 location ^~/a/{ ,而不可以配置成 location ~^/a/{} 这样是访问不到的,网上很多资料都不知道是哪里乱抄过来,害人不浅,还是stackoverflow上的答案靠谱!对于采用root方式的话,前后到无所谓。
3.向最权威,官方的地方查资料。http://wiki.nginx.org/Chs
再附上一个完整的nginx.conf吧:
user www-data; worker_processes 4; pid /var/run/nginx.pid; events { worker_connections 768; } http { sendfile on; tcp_nopush on; tcp_nodelay on; keepalive_timeout 65; types_hash_max_size 2048; include /etc/nginx/mime.types; default_type application/octet-stream; access_log /var/log/nginx/access.log; error_log /var/log/nginx/error.log; gzip on; gzip_disable "msie6"; server { listen 9090; server_name localhost; charset utf-8; # proxy_pass 301 location /pp { proxy_pass http://www.dianping.com; } # rewrite 302 location /re/ { rewrite ^(.)* http://www.dianping.com; } # visit local file by alias location ^~/a/{ alias /home/www-data/; } # visit local file by root location ^~/r/ { root /home/www-data/; } } #include /etc/nginx/conf.d/*.conf; #include /etc/nginx/sites-enabled/*; }
tips:
301
被请求的资源已永久移动到新位置,并且将来任何对此资源的引用都应该使用本响应返回的若干个 URI 之一。如果可能,拥有链接编辑功能的客户端应当自动把请求的地址修改为从服务器反馈回来的地址。除非额外指定,否则这个响应也是可缓存的。
新的永久性的 URI 应当在响应的 Location 域中返回。除非这是一个 HEAD 请求,否则响应的实体中应当包含指向新的 URI 的超链接及简短说明。
302的状态码解释:
请求的资源现在临时从不同的 URI 响应请求。由于这样的重定向是临时的,客户端应当继续向原有地址发送以后的请求。只有在Cache-Control或Expires中进行了指定的情况下,这个响应才是可缓存的。
新的临时性的 URI 应当在响应的 Location 域中返回。除非这是一个 HEAD 请求,否则响应的实体中应当包含指向新的 URI 的超链接及简短说明。
总结:
上面主要设置了nginx的HTTP核心模块(HTTP Core)
测试配置文件是否正确 :nginx -t -c /home/inter12/base/config/nginx.conf
启动nginx : nginx -c /home/inter12/base/config/nginx.conf
停止nginx : nginx -c /home/inter12/base/config/nginx.conf -s quit //正常退出
停止nginx : nginx -c /home/inter12/base/config/nginx.conf -s stop //强制停止
发表评论
-
subversion 1.7.8 linux下的安装笔记
2013-01-13 16:31 5288因为eclipse换成了4.2.1,里面自带的svn就更 ... -
文件差、并、diff操作、pstree、iftop命令使用笔记
2013-01-09 11:14 1559数据准备: inter12@inter12-Virtu ... -
上线性能调优笔记
2012-09-12 21:16 2116普通的性能调优主要从四个方面入手 网络,磁盘IO,内存,C ... -
ubantu安装中文输入法
2012-05-14 10:19 2737在linux下中文输入法的一些事 现在的中文输入 ... -
svn过滤提交的小技巧
2012-05-02 20:18 3720我们在命令行中使用svn ci 提交代码时候,可能经常碰 ... -
个人环境的常用软件包
2012-04-18 10:36 1371个人.ubantu下常用软 ... -
nginx安装笔记
2012-04-17 23:17 3822中间碰到了些问题,就随笔记下了! 安装过程 1.先装 ... -
cpu的缓存同步机制
2012-02-22 15:40 4040cache同步机制之读写 ... -
top命令详解
2012-02-13 13:46 1645前几天跟一人交流的时候,讨论到系统监控命令,对于其 ... -
linux下简单搭建ftp
2012-01-30 16:45 1462接手了一个项目,其中需要一个FTP服务。到手后,发现原来 ... -
一日一脚本--- dirname
2011-11-02 12:28 1210每日一收获 cd `dirname $0` $0 代表 ... -
SVN代码分支合并
2011-02-12 14:55 4316命令版拉分支 svn cp 主干路径 分支路径 ... -
linux下安装 apache+mod_jk+jboss
2010-12-20 13:21 2007之前装过,但是忘记了。这次再次安装顺便也把操作步骤记录下来。免 ... -
DIG简单命令使用
2010-11-16 19:59 2148dig 命令用于查看DNS解析的过程 我们可以查看 DNS的 ... -
mail及查看sun系统位数
2010-07-30 17:38 12651. 发邮件 mail -s "$t ... -
SCP命令
2010-07-30 17:35 1260从远程拷贝本地 scp 本地用户名 @IP 地址 : 文件名 ... -
AIX常见日志查看位置
2010-07-30 17:31 3620进行AIX 的日常维护,需 ... -
crontab命令简介
2010-07-30 17:26 1618crontab命令简介 部分参数说明 crontab ... -
linux系统查看系统性能命令详解(7)
2010-07-22 12:32 1291# iostat -x 1 avg-cpu: %user %n ... -
linux系统查看系统性能命令详解(6)
2010-07-22 12:30 1275参数详解:top命令式将系统最敏感的参数信息列出来。 PR ...
相关推荐
nginx多网站反向代理
本文将详细介绍Nginx如何实现正向代理和反向代理,以及这两种代理方式的应用场景。 **正向代理** 正向代理的主要作用是让内部网络中的设备(如服务器B)通过一个具有外部网络访问权限的设备(如服务器A)来访问...
`nginx`作为一款高性能的反向代理服务器和负载均衡器,常用于处理静态资源,而`tomcat`则作为Java应用服务器,主要负责运行Java Web应用。下面我们将详细探讨`nginx1.6`的安装、`tomcat7`的安装以及它们之间的反向...
在 Windows 环境下配置 Nginx 作为 Tomcat 的反向代理服务器是一项常见的任务,主要用于实现负载均衡、提高安全性及提升性能等目的。本文将从下载 Nginx 开始,详细介绍如何在 Windows 系统上完成这一配置。 #### ...
快速创建nginx反向代理
2. **配置Nginx**:在Nginx的配置文件(通常是`/etc/nginx/nginx.conf`或`/etc/nginx/sites-available/default`)中,我们需要创建一个新的虚拟主机或者在现有主机配置中添加反向代理规则。以下是一个简单的示例: ...
【标题】:“基于Linux下Nginx的安装与项目部署详解” 【描述】:本文将详细介绍如何在Linux系统中安装Nginx,并探讨其主要功能,包括反向代理、负载均衡以及项目部署的具体操作。 【标签】:“Nginx”,“Nginx...
Linux使用Nginx进行反向代理,进行端口转发,可以实现负载均衡等
本资源是专门针对本博文的, nginx的反向代理的简单配置文件,给大家使用时做参考,拿走不谢,怎么一定要50字呢?
nginx 负载均衡 反向代理 nginx 负载均衡 反向代理 nginx 负载均衡 反向代理
在配置Nginx作为反向代理服务器时,有时会遇到可以通过域名正常访问Linux系统下部署的Tomcat服务器,但是却无法访问到部署在Tomcat上的具体项目的情况。这种情况通常是因为Nginx的配置文件中的设置不正确所导致的。 ...
本文将详细介绍如何在CentOS 6.6 x64环境下搭建Nginx反向代理服务器,并通过具体步骤指导读者完成配置。 #### 二、Nginx安装系统环境与组件 本教程中涉及的主要组件包括: - **操作系统**: CentOS 6.6 x64 - **...
在IT行业中,HTTPS通信是确保网站数据安全传输的重要手段,而Nginx作为一款高性能的HTTP和反向代理服务器,常被用来实现这种安全通信。本文将深入探讨如何通过Nginx配置HTTPS服务器,实现443端口的反向代理,以及与...
此文比较详细讲述了Nginx与proxy共同搭建反向代理服务的配置方法
然后k兄就提议可以在内网搭建个nginx反向代理服务器,将nginx反向代理服务器的80映射到外网IP的80,这样指向到公司外网IP的域名的HTTP请求就会发送到nginx反向代理服务器,利用nginx反向代理将不同域名的请求转发给...
在IT行业中,Linux系统下的Nginx部署与反向代理是一项关键技能,尤其对于服务器管理和Web服务优化至关重要。Nginx是一款高性能、轻量级的HTTP服务器和反向代理服务器,以其高效的性能、低内存占用和强大的负载均衡...
在多级反向代理的场景中,请求会经过多个 Nginx 服务器,每级都指向下一个级别的服务器,最终达到目标 C2 服务器。 实施这种隐蔽策略的大致步骤如下: 1. 在第一层 Nginx 反向代理节点(例如:21.67.38.47)上配置...
2.在D:\nginx\目录下用记事本新建一个文本文档改名为 proxy.conf。 proxy.conf里面的内容格式如下: server { listen 80; server_name www.*****.com; location / { proxy_pass http://192.168.45.1:8045; ...
通过使用Nginx 反向代理来解决JS跨域问题 http://blog.csdn.net/mzhaocai/article/details/79238338