Nginx
程序员文章站
2023-01-21 09:33:40
nginx也是一个提供web服务的程序 nginx特点:多个连接对应一个进程(性能要求高时选择) 占用内存资源少,轻量级web服务器 抗并发好 处理静态文件性能是apache的三倍以上 nginx 作为负载均衡服务器,支持 7 层负载均衡 本身就是一个反向代理服务器 apache特点:一个连接对应一 ......
nginx也是一个提供web服务的程序
nginx特点:多个连接对应一个进程(性能要求高时选择)
占用内存资源少,轻量级web服务器
抗并发好
处理静态文件性能是apache的三倍以上
nginx 作为负载均衡服务器,支持 7 层负载均衡
本身就是一个反向代理服务器
apache特点:一个连接对应一个进程(追求稳定时使用)
重量级web服务器
rewrite比nginx强大,就是跳转
更为成熟,少bug
更加稳定
对php支持比较简单
在处理php文件上有优势
集群(一堆服务器)
简单来说,集群就是指一组相互独立的计算机,利用高速通信网络组成的一个较大的计算机服务系统,每个集群节点都是运行各自服务的独立服务器。这些服务器之间可以彼此通信,协同向用户提供应用程序、系统资源和数据,并以单一系统的模式加以管理。当用户客户机请求集群系统时,集群给用户的感觉就是一个单一的服务器,而实际上用户请求的是一组集群服务器。
集群主要包括几大特点:高性能、价格有效性、可伸缩性、高可用性、透明性、可管理性和可编程性。
nginx安装
一:添加源
[epel]
name=epel
enabled=1
gpgcheck=0
baseurl=https://mirrors.aliyun.com/epel/7server/x86_64/
二:下载 yum install nginx –y
三:配置文件/etc/nginx/nginx.conf
user:定义了哪个用户来运行我们nginx
woeker_processes auto:定义了自动获取启动进程,在网站处理高并发的时候,可以修改此处,还有修改 worker_connections(一个进程的连接数) 的数值,两个数值相乘就是可以处理的请求数量。
erro_log:错误日志存放路径
pid:nginx生成的唯一标识号文件
log_format:定义了日志的格式
access_log:定义了记录你的ip地址,时间
比如apache可以定义多个虚拟主机,nginx怎么实现呢,在http里面定义。
server就是用来定义我们虚拟主机的
server {
listen 要监听的端口;
root 指定网站根目录;
index index.html;
}
而后重启 systemctl restart nginx 访问ip加端口即可
location / { :定义了匹配规则
}
反向代理
反向代理:客户端请求进来之后,调度器并不会直接返回结果,而是直接转发到后端节点去,由后端节点给客户端返回请求。
用到的模块: nginx_http_proxy_module
指令
proxy_pass:指定上游服务器(后端的节点)的ip和端口
proxy_set_header:指定在重新封装请求报文的时候,添加一个新的首部
syntax(语法): proxy_pass url; 当你写了url的时候default就不用写了,当default不为空,proxy_pass也就不用我们填写了
default: —
context(上下文的意思): location, if in location, limit_except 规定了proxy_pass的填写位置只能在location里面。
例子:proxy_pass http://10.220.5.200:80;
syntax: proxy_set_header field value;
default: proxy_set_header host $proxy_host;
context: http, server, location
反向代理部署
先开启三台虚拟,用第一台作为调度器,后两台(这两台推荐部署apache,方便,快捷)作为节点。
然后在第二台和第三台的网站根目录下向测试文件写入一段话。而后修改第一台的nginx配置文件。
location / { /代表不管你请求什么,我都转发到第二台上。
proxy_pass http://第二台ip地址;
}
而后重启nginx服务。
反向代理两台时如何添加:
location /4 { /4代表你搜索4的时候,我才会转发到另一台上。
proxy_pass http://另一台 ip地址/; 最后加/,意思是完全代理
}
location /7 { /7代表你搜索7的时候,我才会转发到另一台上。
proxy_pass http://另一台ip地址/;
}
nginx的端口也是80
负载均衡
调度器:分发用户的请求到一个后端节点 就是nginx
上游服务器(真实服务器):每个真正用来处理用户请求的节点都是一个上游服务器
cip:客户端的ip地址 客户端ip地址
rip:真实服务器的ip地址 后端节点的ip
vip:虚拟ip,用户所看到的是也是虚拟ip 调度服务器做了一个vip
weight=#:设置服务器的权重(数字越大,权重越高):我后端有三台服务器,第一台的weight为2,,第二台的weight为1,,第三台的weight为3,第三台的负载就要高一点,比如我现在有六个请求进来了,我第三台就会处理三个,第二台处理一个,第一台处理两个。你给他设置多少,他就会处理多少。
backup: 设置服务器处于备用状态(其他节点出现故障,备用节点才开始工作)
down:设置让一个节点处于离线状态(经常用在维护一个节点的情况下)
max_fails=number:设置连续几次转发失败就认为该节点出现故障,然后就不再向该节点转发用户请求了。如果你不给我返回,我就不会给你转发了。
fail_timeout=time: 和上个参数组合使用,作用是设置等待上游服务器响应超时时间。定义了多长时间算不返回。
指令:upstream
作用:定义一个上游服务器组
格式
upstream name {
server 上游服务器1 参数 参数;
server 上游服务器1 参数 参数;
server 上游服务器1 参数 参数;
}
只能在server上面定义upstream
部署负载均衡
upstream name {
server 上游服务器1 参数 参数;
server 上游服务器1 参数 参数;
}
location / { /代表不管你请求什么,我都调用我定义的upstream上。
proxy_pass http://name;
}
lnmp架构上线动态网站
先下载 yum install nginx php php-mysql php-fpm mariadb-server –y
先把之前的nginx的配置文件修改删除,在root下添加 index index.php index.html,重启nginx服务,重启php-fpm服务(他的端口为9000)。
打开nginx配置文件
在规则处添加新的规则
location ~ php${
fastcgi_pass 127.0.0.1:9000; 指定php-fpm服务监听地址
include fastcgi.conf; 加载fastcgi配置文件
}
而后重启nginx 重启mariadb
建立mysql 在网站根目录编写要上线的网站配置文件。
下一篇: Android中使用AspectJ详解