文章目录
- 引入
- 简介
- 作用
- 常用命令
- 配置文件
引入
在公司项目刚上线时,用户少,并发量小,此时一个jar包启动应用就够了,然后内部 Tomcat 返回内容给用户
当用户增多,并发量增大,一台服务器满足不了我们的需求
于是可以横向扩展,增加服务器;这时几个项目启动在不同的服务器上,用户要访问,就需要增加一个代理服务器了,通过代理服务器来帮我们转发和处理请求
我们希望这个代理服务器可以帮助我们接收用户的请求,然后将用户的请求按照规则帮我们转发到不同的服务器节点之上,可以按照服务器的性能提供不同的权重选择。保证最佳体验
简介
- Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务
- 其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好
- Nginx 是一个安装非常的简单、配置文件非常简洁、Bug非常少的服务;Nginx 启动特别容易,并且几乎可以做到7*24不间断运行,即使运行数个月也不需要重新启动。你还能够不间断服务的情况下进行软件版本的升级
- Nginx代码完全用C语言从头写成。官方数据测试表明能够支持高达 50,000 个并发连接数的响应
作用
- Http代理,反向代理:作为web服务器最常用的功能之一,尤其是反向代理
正向代理:代理客户端的 如vpn
反向代理:代理服务器的
- Nginx提供的负载均衡策略有2种:内置策略和扩展策略;内置策略为轮询,加权轮询,IP Hash;IP Hash对客户端请求的IP进行Hash操作,然后根据Hash结果将同一个客户端ip的请求分发给同一台服务器进行处理,可以解决session不共享的问题
- 动静分离:在我们的软件开发中,有些请求是需要后台处理的,有些请求是不需要经过后台处理的(如:css、html、jpg、js等文件),让动态网站里的动态网页根据一定规则把不变的资源和经常变的资源区分开来,动静资源做好了拆分以后,我们就可以根据静态资源的特点将其做缓存操作,提高资源响应的速度
常用命令
cd /usr/local/nginx/sbin/
./nginx 启动
./nginx -s stop 停止
./nginx -s quit 安全退出
./nginx -s reload 重新加载配置文件
ps aux|grep nginx 查看nginx进程
配置文件
http {
upstream rainhey{ //rainhey是自定义的名称,用于location中引用
server 127.0.0.1:8082/ weight=1; //服务地址、端口 权重-比例,可以用来设置负载均衡
server 127.0.0.1:8081/ weight=1;
}
server {
listen 80;
server_name localhost;
location / { // nginx拦截所有 80端口的 /请求
root html;
index index.html index.htm;
proxy_pass http://rainhey; // 代理到rainhey服务列表中的服务
}