一.简介
1.Nginx(engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务。Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文:Рамблер)开发的,第一个公开版本0.1.0发布于2004年10月4日。
2.其将[源代码]以类BSD许可证的形式发布,因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。2011年6月1日,nginx 1.0.4发布。
3.Nginx是一款轻量级的Web服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,在BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。
4.代理:
(1) 正向代理:作⽤于客户端。
(2)反向代理:作⽤在服务器端,客户端不知道反向代理服务器的存在。
5.单节点故障:
(1)⼤并发请求下,服务器只有⼀个,如果服务器挂掉,单节点发⽣故障,整个就不能正常运⾏了。
(2)解决⽅案:配置服务器集群。使⽤ nginx ,通过ip 管理多个 tomcat服务器。
二.模拟伪集群
1.解压两个tomcat,在serve.xml⽂件配置两套不同的端⼝,8080,8005,8009和8081,8006,8010。
2.修改Nginx的nginx.conf配置⽂件,实现负载均衡。
(1)服务器集群配置
(2)nginx不能处理jsp⻚⾯,交由tomcat处理。
(3)代码参考:
#服务器集群配置
upstream jeffrey.com{
server 127.0.0.1:8080 weight=1;
#服务器配置,weight是权重,权重越⼤,分配的概率越⼤。
server 127.0.0.1:8081 weight=2;
}
#当前的nginx配置
server {
listen 80;#侦听端⼝号
server_name localhost;
#当前服务的域名.如果是localhost:8080的请求,则交给jeffrey.com的集群来处理。
location / {
proxy_pass http://jeffrey.com ;
#与服务器集群的名称⼀致
proxy_redirect default;
}
location = /50x.html {
root html;
}
}
3.关闭nginx :
(1)nginx -s stop
(2)nginx -s quit
- 这⾥出现⼀个新问题:
(1)⼀个服务器挂掉后,nginx不会⽴刻判断其死亡,⽽是等待,但是死掉的服务器⾥的信息怎么办?
(2)⼀个应⽤通常有多个服务器,登录成功后,session只会在⼀台存储,想要多台服务器都识别到这个session,后端统⼀存储。
(3)所以,集群产⽣的新问题:session共享。 - 解决session共享:
(1) session复制
(2)后端统⼀存储,后端统⼀找⼀个中间件将Session存起来即可,这个中间件是数据库redis或
者缓存。此时,tomcat作为客户端,redis作为服务端。
(3)不要使⽤session。 - redis实现session共享
- 改写tomcat底层
- 三个session的jar包复制到tomcat下的lib中,commons-pool2-2.2.jar,jedis-2.5.2.jar,tomcat-redis-session-manager-2.0.0.jar。
- 安装redis server
- tomcat修改conf/context.xml,新增代码
<Valve
className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />
<Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"
host="localhost"
port="6379"
database="0"
maxInactiveInterval="60" />
(1)启动redis-server.exe
//启动
redis-server redis.windows.conf
//关闭
shutdown
(2)启动tomcat,启动nginx;
- nginx,tomcat,redis集群中。redis处理了两件事情,session共享,缓存。
- 缓存的问题,缓存穿透和击穿。
- 缓存处理流程:
(1)前台请求,后台先从缓存中取数据,取到直接返回结果。
(2)取不到时从数据库中取,数据库取到更新缓存,并返回结果。
(3)数据库也没取到,那直接返回空结果。
今天是我在千锋线上学习的第52天,加油!!!