标签:log 开发 ack tar crt mic logs war linu
代理服务器,客户机在发送请求时,不会直接发送给目的主机,而是先发送给代理服务器,代理服务接受客户机请求之后,再向主机发出,并接收目的主机返回的数据,存放在代理服务器的硬盘中,再发送给客户机。
由于目标主机返回的数据会存放在代理服务器的硬盘中,因此下一次客户再访问相同的站点数据时,会直接从代理服务器的硬盘中读取,起到了缓存的作用,尤其对于热门站点能明显提高请求速度。
由于所有的客户机请求都必须通过代理服务器访问远程站点,因此可在代理服务器上设限,过滤某些不安全信息。
互联网上有许多开发的代理服务器,客户机在访问受限时,可通过不受限的代理服务器访问目标站点,通俗说,我们使用的FQ浏览器就是利用了代理服务器,虽然不能出国,但也可直接访问外网。
正向代理,架设在客户机与目标主机之间,只用于代理内部网络对Internet的连接请求,客户机必须指定代理服务器,并将本来要直接发送到Web服务器上的http请求发送到代理服务器中。
反向代理服务器架设在服务器端,通过缓冲经常被请求的页面来缓解服务器的工作量,将客户机请求转发给内部网络上的目标服务器;并将从服务器上得到的结果返回给Internet上请求连接的客户端,此时代理服务器与目标主机一起 对外表现为一个服务器。
现在许多大型web网站都用到反向代理。除了可以防止外网对内网服务器的恶性攻击、缓存以减少服务器的压力和访问安全控制之外,还可以进行负载均衡,将用户请求分配给多个服务器。
nginx是一个轻量级、高性能的web server,他可以直接作为http server来代替apache,对PHP需要FastCGI处理器支持,还可以作为一个反向代理服务器来实现负载均衡。虽然apache的mod_proxy和mod_cache也可以实现对多台app server的反向代理和负载均衡,但是nginx在处理并发上有着很大的优势。
因为我们要使用nginx反向代理服务器来达到一个负载均衡的效果,所以需要搭建至少三台服务器才可以模拟这个效果。我使用VMware搭建了三台虚拟机,系统是centos6.5.
因为需要一台服务器来作为反向代理服务器,而且我是phper,所以反向代理服务器是linux+nginx+mysql+php。其余两台真实服务器是linux+apache+mysql+php,因为apache的性能比较稳定,模块多而且bug少相对于nginx 来说。
这个东西要说的太多了,这里不一一叙述了,我有两篇文章写了怎么搭建这两种环境,链接:
LAMP http://www.cnblogs.com/lina520/p/7240680.html
LNMP http://www.cnblogs.com/lina520/p/7240328.html
//有什么问题可以下方留言,如果我会的尽力解决。
这是我在固定了虚拟机IP之后,然后用SecureCRT工具链接。35这台是反向代理服务器,36,37是两台真实服务器。
#cd var/www/html;#这里是默认web目录,根据自己实际情况编写可访问的一个php文件
#vi index.php#这里可以随便写点东西,但是要区分开另一台服务器
另外一台服务器同理
#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;
}
}
因为是测试,所以没有虚拟域名,但是可以自己制造一个。我的物理机是windows的系统,打开C:\Windows\System32\drivers\etc然后编辑hosts文件,在文件的末端把你想要请求的域名添加进去
保存之后,退出打开浏览器访问这个域名,结果如下:
就是我们通常说的轮询策略,每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。
只要修改upstream就好了,服务器就会按照权重去访问。如上述配置,A服务器访问的几率是2/3,B是1/3,则访问A两次,访问B一次。
每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。
采用了ip_hash策略之后会针对每个访问的ip固定一个后端服务器,就不会再去访问其他服务器,在会话保持的时候,可以解决session的问题
标签:log 开发 ack tar crt mic logs war linu
原文地址:http://www.cnblogs.com/lina520/p/7279742.html