欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  科技

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

 

 

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 在网站根目录编写要上线的网站配置文件。