0.环境:centos7.2,tomcat8.5*2 ,nginx1.0.13
0-1:起因,由于上线不能影响用户使用,起初使用ip分流,但是有些情况无法获取ip,故查到可以用cookie做分流,这样一来,可以给客户以及测试人员分配角色 ,根据角色设置cookie,再根据cookie实现分流,便可实现上线不影响现网使用。
1.nginx配置
upstream nttest{
# server 127.0.0.1:38080;
server 127.0.0.1:39090;
}
upstream nttest1{
server 127.0.0.1:38080;
}
location ^~ /web/ {
set $group nttest;
if ($http_cookie ~* "hyb_test") {
set $group nttest1;
}
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-real-ip $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
index index.html index.htm;
proxy_pass http://$group;
}
即,声明2个upstream,分别指向tomcat1和2,当路径匹配到web,设置变量group为nttest节点,判断cookie,如果cookie带有hyb_test,则设置变量group为nttest1节点,将请求代理到group。
2测试用例准备
data:image/s3,"s3://crabby-images/4d570/4d57013e8dad097b862ebd4820c46f091660fee2" alt=""
@RequestMapping("/login")
public String login2(String username,String password, HttpServletRequest req, HttpServletResponse resp){
if("hyb".equals(username)){
Cookie cookie = new Cookie("hyb_test_username",username);
cookie.setPath("/");
// cookie.setDomain("domain");
resp.addCookie(cookie);
}
return "success";
}
data:image/s3,"s3://crabby-images/93f45/93f4593b95dde3802fb307321b030776fe78a37d" alt=""
将项目拉到2个tomcat,修改2.jsp内容即可,比如我将nttest1下的2.jsp修改为
data:image/s3,"s3://crabby-images/bd55f/bd55f3eada4cb39a8b8ff8df26c8c81e097db079" alt=""
3测试分流
分别启动tomcat1,tomcat2,正常启动后访问index.jsp
data:image/s3,"s3://crabby-images/3f003/3f0035f3a4d3b1cd03d165890267405a40c52eb3" alt=""
因为没做登陆校验,直接点登陆即可,另开一个窗口,用hyb做用户名登陆,如图
data:image/s3,"s3://crabby-images/eff69/eff6942601cebdd9c74d4bbf1e07d874c5693dd7" alt=""
分别点击登陆,
data:image/s3,"s3://crabby-images/76587/7658719d57af884b42b2f1880fe91377394cb351" alt=""
hyb已经成功访问到nttest1,而其他登陆则访问了nttest,分流成功!
data:image/s3,"s3://crabby-images/06ee3/06ee3e3da44c15e41510760d60613c69ba5398d9" alt=""
data:image/s3,"s3://crabby-images/f4850/f4850fe101754fc120bf9721df6ecf5f7d67e99c" alt=""
网友评论