php nginx反向代理

  

一、概念理解

  1.代理服务器

  代理服务器,客户机在发送请求时,不会直接发送给目的主机,而是先发送给代理服务器,代理服务接受客户机请求之后,再向主机发出,并接收目的主机返回的数据,存放在代理服务器的硬盘中,再发送给客户机。

  2.为什么要使用代理服务器

  ①提高访问速度

  由于目标主机返回的数据会存放在代理服务器的硬盘中,因此下一次客户再访问相同的站点数据时,会直接从代理服务器的硬盘中读取,起到了缓存的作用,尤其对于热门站点能明显提高请求速度。 

  ②防火墙作用

  由于所有的客户机请求都必须通过代理服务器访问远程站点,因此可在代理服务器上设限,过滤某些不安全信息。 

  ③通过代理服务器访问不能访问的目标站点 

  互联网上有许多开发的代理服务器,客户机在访问受限时,可通过不受限的代理服务器访问目标站点,通俗说,我们使用的FQ浏览器就是利用了代理服务器,虽然不能出国,但也可直接访问外网。

  3.正向代理&反向代理

  ①正向代理

  正向代理,架设在客户机与目标主机之间,只用于代理内部网络对Internet的连接请求,客户机必须指定代理服务器,并将本来要直接发送到Web服务器上的http请求发送到代理服务器中。

  ②反向代理

  反向代理服务器架设在服务器端,通过缓冲经常被请求的页面来缓解服务器的工作量,将客户机请求转发给内部网络上的目标服务器;并将从服务器上得到的结果返回给Internet上请求连接的客户端,此时代理服务器与目标主机一起       对外表现为一个服务器。

  4.反向代理的应用

  现在许多大型web网站都用到反向代理。除了可以防止外网对内网服务器的恶性攻击、缓存以减少服务器的压力和访问安全控制之外,还可以进行负载均衡,将用户请求分配给多个服务器。 

  5.为什么使用nginx

  nginx是一个轻量级、高性能的web server,他可以直接作为http server来代替apache,对PHP需要FastCGI处理器支持,还可以作为一个反向代理服务器来实现负载均衡。虽然apache的mod_proxy和mod_cache也可以实现对多台app server的反向代理和负载均衡,但是nginx在处理并发上有着很大的优势。

二、准备工作

  1.服务器

  因为我们要使用nginx反向代理服务器来达到一个负载均衡的效果,所以需要搭建至少三台服务器才可以模拟这个效果。我使用VMware搭建了三台虚拟机,系统是centos6.5.

  2.环境

  因为需要一台服务器来作为反向代理服务器,而且我是phper,所以反向代理服务器是linux+nginx+mysql+php。其余两台真实服务器是linux+apache+mysql+php,因为apache的性能比较稳定,模块多而且bug少相对于nginx          来说。

  3.搭建环境

  这个东西要说的太多了,这里不一一叙述了,我有两篇文章写了怎么搭建这两种环境,链接:

    LAMP  http://www.cnblogs.com/lina520/p/7240680.html

  LNMP  http://www.cnblogs.com/lina520/p/7240328.html

 

  //有什么问题可以下方留言,如果我会的尽力解决。

三、服务器配置  

   这是我在固定了虚拟机IP之后,然后用SecureCRT工具链接。35这台是反向代理服务器,36,37是两台真实服务器。

  1.编写测试文件

  #cd  var/www/html;#这里是默认web目录,根据自己实际情况编写可访问的一个php文件

  #vi index.php#这里可以随便写点东西,但是要区分开另一台服务器

  

  另外一台服务器同理

  

 2.配置反向代理服务器

  #cd etc/nginx#跳转到nginx的配置页面

   #vi nginx.conf修改配置文件

  

  我们在http模块下增加如下配置,主要是一个upstream和server   

  upstream blance {
    server 192.168.0.36:80; //A服务器
    server 192.168.0.37:80; //B服务器
  }

  

  server{
    listen 80;//真实服务器的端口号
    server_name blance;//这个名字就是我们访问反向代理服务器的域名,注意与上面的服务器集群名一致
    location / {
      proxy_pass http://blance;//这个与上面同理
      proxy_set_header Host $host;//转发请求的头部
      proxy_set_header X-Real-IP $remote_addr;
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
  }

  3.配置访问域名  

  因为是测试,所以没有虚拟域名,但是可以自己制造一个。我的物理机是windows的系统,打开C:\Windows\System32\drivers\etc然后编辑hosts文件,在文件的末端把你想要请求的域名添加进去

  

 

  保存之后,退出打开浏览器访问这个域名,结果如下:

  

  

四、负载均衡策略

  1.RR策略

   就是我们通常说的轮询策略,每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。

   

  

  2.加权策略

   指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。 

   

  只要修改upstream就好了,服务器就会按照权重去访问。如上述配置,A服务器访问的几率是2/3,B是1/3,则访问A两次,访问B一次。

  3.ip_hash

  每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。 

  

  采用了ip_hash策略之后会针对每个访问的ip固定一个后端服务器,就不会再去访问其他服务器,在会话保持的时候,可以解决session的问题

 

 

  上面只写了几种常用的东西,还有很多我不知道的、没写的欢迎大家一起交流!

 

  

 

 

 

 

 

 

 

 

 

 

  

  

转载于:https://www.cnblogs.com/lina520/p/7279742.html

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值