当前位置: 移动技术网 > 科技>操作系统>Linux > Nginx

Nginx

2019年05月24日  | 移动技术网科技  | 我要评论

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  ;
}
而后重启 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 ,重启nginx服务,重启php-fpm服务(他的端口为9000)。
打开nginx配置文件
在规则处添加新的规则
location  ~ php${  
fastcgi_pass 127.0.0.1:9000;  指定php-fpm服务监听地址
include fastcgi.conf;    加载fastcgi配置文件
}

而后重启nginx 重启mariadb

建立mysql 在网站根目录编写要上线的网站配置文件。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网