nginx 学习
1.1 什么是ngaix
是一个高性能HTTP和反向代理服务器,特点是占有内存少,并发能力强。
ngaix 是转为性能优化而开发,性能是其最重要的考量,实现上非常注重效率,能经受高负载的考验。
1.2 反向代理
- 正向代理
使用代理服务器访问网址。
- 反向代理
反向代理,对客户端代理无感知,此时代理服务器和目标服务器对外就是一个服务器
1.3 负载均衡
增加服务器的数量,将请求分发到各个服务器上,将原先请求集中到单个服务器上的情况改为将请求分发到多个服务器上,将负载分发到不同的服务器,也就是负载均衡
1.4 动静分离
加快网站解析速度,将动态页面与静态页面由不同的服务器来解析
服务器查看端口
firewall-cmd --list-all
服务器开放端口
firewall-cmd --add-service
开启8081端口
firewall-cmd --add-port=8081/tcp --permanent
重启防火墙
firewall-cmd --reload
2 nginx 配置文件
2.1 全局快
从配置文件开始到events 块之间的内容,主要会设置一些影响nginx服务器整体运行,主要包括配置运行Nginx服务器的用户 ,允许生成的worker process 数,进程pid存放的路径,日志等
比如
worker_processes 1;
worker_processes 值越大,可以支持的并发处理数量就越多
2.2 events 块
events 块涉及的指令主要影响Nginx服务器与用户的网络连接,常用的设置包括是否开启对多 work process的网络连接进行序列化,是否允许同时接受多个网络连接,每个word process可以同时支持的最大连接数。
比如
worker_connections 1024;支持的最大连接数
2.3 http块
http块包括http全局快,server块
- http块
http全局快配置的指令包括文件引入,MIME-TYPE定义,日志定义,连接超时时间,单链接请求数上限
- server块
3 nginx反向代理
location = / {
# 仅仅匹配请求 /
[ configuration A ]
}
location / {
# 匹配所有以 / 开头的请求。
# 但是如果有更长的同类型的表达式,则选择更长的表达式。
# 如果有正则表达式可以匹配,则优先匹配正则表达式。
[ configuration B ]
}
location /documents/ {
# 匹配所有以 /documents/ 开头的请求。
# 但是如果有更长的同类型的表达式,则选择更长的表达式。
# 如果有正则表达式可以匹配,则优先匹配正则表达式。
[ configuration C ]
}
location ^~ /images/ {
# 匹配所有以 /images/ 开头的表达式,如果匹配成功,则停止匹配查找。
# 所以,即便有符合的正则表达式location,也不会被使用
[ configuration D ]
}
location ~* \.(gif|jpg|jpeg)$ {
# 匹配所有以 gif jpg jpeg结尾的请求。
# 但是 以 /images/开头的请求,将使用 Configuration D
[ configuration E ]
}
实现效果从80端口直接跳到使用8080端口。
可以使用nginx反向代理,根据访问路径跳转到不同端口的服务中
主要修改的是server_name,y以及location中需要增加proxy_pass
访问 http://ayugudu.top:80/web/ 直接跳转到 http://ayugudu.top:8080/
访问 http:// ayugudu.top:80/wx/ 直接跳转到 http://ayugudu.top:8081/
server
{
listen 80;
server_name http://ayugudu.top/;
location ~ /wx/ {
root login.html;
index login.html;
proxy_pass http://ayugudu.top:8081;
proxy_redirect default;
}
location ~ /web/ {
root login.html;
index login.html;
proxy_pass http://ayugudu.top:8080;
proxy_redirect default;
}
4 nginx 动静分离
动静分离是把动态跟静态请求分开,可以理解成使用Nginx处理静态页面,Tomcat 处理动态页面
实现方式
- 一中是将静态文件独立成单独的域名,放在独立的服务器上,通过nginx转发到静态资源文件
- 另外一种方法时将动态与静态文件混合在一起发布,通过nginx来分开。
location指定不同的后缀名实现不同的请求转发,通过expires参数设置,使浏览器缓存过期时间,减少与服务器之间的请求和流量。比对服务器该文件最后更新时间没有变化,则不会从服务器抓取,返回状态码304,有修改则直接从服务器重新下载。
root实例:
location ^~ /t/ {
root /www/root/html/;
}
如果一个请求的URI是/t/a.html时,web服务器将会返回服务器上的/www/root/html/t/a.html的文件。
alias实例:
location ^~ /t/ {
alias /www/root/html/new_t/;
}
如果一个请求的URI是/t/a.html时,web服务器将会返回服务器上的/www/root/html/new_t/a.html的文件。注意这里是new_t,因为alias会把location后面配置的路径丢弃掉,把当前匹配到的目录指向到指定
5 nginx 负载均衡
增加服务器的数量,然后将请求分发到各个服务器上,将原先请求分发到多个服务器上,将负载分发到不同的服务器,也就是负载均衡。
- 实现将请求分发给不同的服务器
http {
upstream myserver{
ip_hash;
server localhost:8080 weight=1;
server localhost:8081 weight=1;
}
server {
location / {
proxy_pass http://myserver;
proxy_connect_timeout 10;
}
}
}
nginx 提供了几种分配方式:
- 轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果服务器挂掉,会自定剔除
- weight
weight 代表权重,默认为1,权重越高被分配的客户端越多
upstream myserver{
server localhost:8080 weight=1;
server localhost:8081 weight=1;
}
- ip_hash
每个请求按访问的ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题
upstream myserver{
ip_hash;
server localhost:8080 ;
server localhost:8081 ;
}
- fair
按后端服务器的响应时间来分配请求,响应时间短的优先分配。
upstream myserver{
server localhost:8080 ;
server localhost:8081 ;
fair;
}