正向代理:代理客户端,服务器不知道具体谁请求的,比如使用代理服务器访问国外网站,国外网站不知道正真的请求方
反向代理:代理服务端,客户端不知道具体哪一台服务器提供的服务
准备工作:在liunx上安装一个tomcat 使用默认端口,使用nginx作为反向代理,当访问www.1234.com时候返回tomcat页面,
配置:在nginx的配置文件中配置代理的地址即可
http { include mime.types; default_type application/octet-stream; sendfile on; server { listen 80; server_name www.abc.com;#访问的地址 location / { #反向代理配置 和root配置二选一 proxy_pass http://localhost:8080;#要代理的地址 #root /www/blog/; #index index.html index.htm; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } }
通过增加服务器将单个服务器处理的负载分发到多个服务器处理即为负载均衡
案例效果:浏览器输入地址www.192.168.3.217/demo/a.html 平均到8080和8081端口
准备:linux安装两台tomcat, 一台8080 一台8081,分别在两台的tomcat里面的webapps目录中创建名称是demo的文件夹,在demo中创建a.html用于测试,两个a.html页面内容可以不一样 方便查看负责均衡效果
通过浏览器访问www.192.168.3.217/demo/a.html 刷新可以看到交替显示不同的页面
a.轮询(默认):每个请求按时间顺序分配到不同的服务器,如果服务器down掉 自动剔除
b.weight:weight代表权重 默认为1 权重越高 被分配的客户端越多,具体配置如下
c.ip_hash:每个请求按访问ip的hash结果分配,这样每个访客固定一个后端服务器,可以解决session的问题
d:fair(第三方),按后端服务器的响应时间来分配请求,响应时间短的优先分配
e:url_hash 根据用户访问的url定向转发请求
f:least_conn 最少连接访问
retry机制
当某个tomcat挂掉时nginx已经将请求发过来 ,这时由于retry机制会立马再次请求别的tomcat返回请求
一般只适合中小公司 静态资源不怎么多 放在nginx,
使用nginx把静态资源和动态资源分离,使用tomcat处理动态资源,使用nginx处理静态静态资源。提高请求效率
如何实现?
准备工作:在Liunx的"/"目录下创建两个目录/source/image和/source/js,在image中放置一张图片a.png ,js文件夹中放置一个b.js文件,
效果:通过nginx请求到上面的a.png和测试.js
配置文件中配置
server { listen 80; server_name www.abc.com; location / { proxy_pass http://www.demo.com; } #所有的图片请求 location /img { root /source; } #所有的js请求 location /js { root /source; } #也可以使用正则 location ~*/(js|img|css) { root /source; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } }
测试:
访问地址:192.168.3.217/img/
//由于配置了autoindex on (展示列表)
访问地址:192.168.3.217/image/a.png
响应一张图片
访问地址:192.168.3.217/js/a.js
响应js文件