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的问题

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

  

  

  

时间: 2024-11-05 20:45:46

php nginx反向代理的相关文章

Nginx反向代理的配置

Chapter: Nginx基本操作释疑 1. Nginx的端口修改问题 2. Nginx 301重定向的配置 3. Windows下配置Nginx使之支持PHP 4. Linux下配置Nginx使之支持PHP 5. 以源码编译的方式安装PHP与php-fpm 6. Nginx多站点配置的一次实践 7. Nginx反向代理的配置 Nginx 作为 web 服务器一个重要的功能就是反向代理.其实我们在前面的一篇文章<Nginx多站点配置的一次实践>里,用的就是 Nginx 的反向代理,这里简单再

nginx反向代理

1. 操作系统 CentOS 6.4 x86_64 2.软件版本 Nginx 1.4.2 3.实验拓扑 注,实验拓扑见下文. 4.安装yum源 1 2 3 [root @nginx ~]# rpm -ivh http://download.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm [[email protected] ~]# rpm -ivh http://download.fedoraproject.org/

Nginx反向代理、动静分离、负载均衡及rewrite隐藏路径详解(Nginx Apache MySQL Redis)–第三部分

Nginx反向代理.动静分离.负载均衡及rewrite隐藏路径详解 (Nginx Apache MySQL Redis) 楓城浪子原创,转载请标明出处! 更多技术博文请见个人博客:https://fengchenglangzi.000webhostapp.com 微信bh19890922 QQ445718526.490425557 三.Nginx动静分离及负载均衡 3.1 Nginx安装 请参考:https://fengchenglangzi.000webhostapp.com/?p=511 亦

nginx 反向代理

关于什么是nginx以及为什么使用的理论网上还是有很多资料的,这里就不在赘述了.下面简单的说一下nginx的反向代理及实现 一.反向代理: 反向代理(Reverse Proxy)方式是指它根据客户端的请求,从后端的服务器(如Web服务器)上获取资源,然后再将这些资源返回给客户端. 与正向代理不同,正向代理作为一个媒介将互联网上获取的资源返回给相关联的客户端,而反向代理是在服务器端(如Web服务器)作为代理使用, 而不是客户端. 客户端通过正向代理可以访问很多不同的资源,而反向代理是很多客户端都通

Nginx反向代理,负载均衡,redis session共享,keepalived高可用

相关知识自行搜索,直接上干货... 使用的资源: nginx主服务器一台,nginx备服务器一台,使用keepalived进行宕机切换. tomcat服务器两台,由nginx进行反向代理和负载均衡,此处可搭建服务器集群. redis服务器一台,用于session的分离共享. nginx主服务器:192.168.50.133 nginx备服务器:192.168.50.135 tomcat项目服务器1:192.168.50.137 tomcat项目服务器2:192.168.50.139 redis服

Cento7+Nginx反向代理实现多域名跳转

近期比较忙,所以很少写文档了,最近有个项目组有多个环境需要做映射,所以就想到了通过Nginx反向代理实现多域名地址跳转,以致就总结了一下,其实说到代理我们大家都知道.最常见最常说的所谓的就是NAT,就是将内部多个地址请求通过代理转达到外部.这个就叫正向代理,那什么是反向代理呢-就是和正向代理相反:所以很好理解,Nginx反向代理功能很强大,可以通过一个nginx代理实现多个域名及不同的端口进行代理转发,所以在日常的运维中很有帮助.我们今天的演示是通过Nginx反向代理实现内部不同的多个域名转发.

Nginx反向代理、负载均衡、页面缓存、URL重写及读写分离详解

大纲 一.前言 二.环境准备 三.安装与配置Nginx 四.Nginx之反向代理 五.Nginx之负载均衡 六.Nginx之页面缓存 七.Nginx之URL重写 八.Nginx之读写分离 注,操作系统为 CentOS 6.4 x86_64 , Nginx 是版本是最新版的1.4.2,所以实验用到的软件请点击这里下载:http://yunpan.cn/QXIgqMmVmuZrm 一.前言 在前面的几篇博文中我们主要讲解了Nginx作为Web服务器知识点,主要的知识点有nginx的理论详解.ngin

nginx反向代理tomcat提示13 permission denied while connecting to upstream

nginx反向代理tomcat提示13 permission denied while connecting to upstream,网上很多都是说13 permission denied while reading to upstream,这是两个完全不同的错误,我遇到的如下截图: 查看selinux日志发现错误: 后来发现是selinux的问题,于是先关掉selinux:setenforce 0:然后再访问果然好使. 于是启用selinux,再执行下面的命令,修改selinux的值: set

Web服务之Nginx反向代理与负载均衡

一.代理 正向代理: 正向代理是一个位于客户端和目标服务器之间的服务器,为了从目标服务器取得内容,客户端向代理发送一个请求并指定目标服务器,然后代理向目标服务器转交请求并将获得的内容返回给客户端.客户端必须要进行一些特别的设置才能使用正向代理. 作用: 访问无法访问的服务器(翻墙,懂得) 加速访问目标服务器(链路加速) Cache缓存(访问加速) 实现客户端访问授权 隐藏访问者 反向代理: 反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转

Php学习之nginx反向代理详解

本文和大家分享的主要是php中nginx反向代理相关内容,一起来看看吧,希望对大家学习php有所帮助. 一.概念理解 1.代理服务器 代理服务器,客户机在发送请求时,不会直接发送给目的主机,而是先发送给代理服务器,代理服务接受客户机请求之后,再向主机发出,并接收目的主机返回的数据,存放在代理服务器的硬盘中,再发送给客户机. 2.为什么要使用代理服务器 ①提高访问速度 由于目标主机返回的数据会存放在代理服务器的硬盘中,因此下一次客户再访问相同的站点数据时,会直接从代理服务器的硬盘中读取,起到了缓存