Linux-Nginx环境部署
Published in:2020-09-03 |

Nginx是一款轻量级的Web服务器/反向代理服务器 ,其特点是占有内存少,并发能力强。

Nginx服务器

一、Nginx概述

1、简介

1.1 什么nginx

Nginx是一款轻量级的Web服务器/反向代理服务器 ,其特点是占有内存少,并发能力强。

2.2 nginx的作用
  • 静态HTTP服务器( 处理静态资源 - 动静分离):

    首先,Nginx是一个HTTP服务器,可以将服务器上的静态文件(图片、CSS、JS文件等)通过HTTP协议展现给客户端。 将静态资源的处理交给Nginx服务器

    1
    2
    3
    # 一个项目中的资源可以为两大类:
    1. 动态资源的请求 普通URL -- uwsgi
    2. 静态资源的请求 /static/ -- nginx

    Nginx提供的动静分离是指把动态请求和静态请求分离开,合适的服务器处理合适的请求,使整个服务器系统的性能、效率更高。

    uWSGI更适合做动态内容的执行,nginx更适合做静态内容的处理,客户端请求直接访问nginx服务器,留下静态部分处理,动态部分转发给uWSGI服务器,最终实现“动静分离”。

  • 反向代理服务器:

    反向代理是指以代理服务器nginx来接受internet上的请求,然后将请求转发给内部网络上的其它服务器uWSGI,并将从uWSGI服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。

  • 负载均衡 :

    多在高并发情况下需要使用。其原理就是将数据流量分摊到多个服务器执行,减轻每台服务器的压力,多台服务器(集群)共同完成工作任务,从而提高了数据的吞吐量。

2、安装步骤

  • 将tar包发送的linux

  • 解压 tar -zxvf nginx-1.11.1.tar.gz

  • 安装依赖 yum install gcc zlib-devel pcre-devel

  • cd到解压目录:./configure #配置检测

  • cd到解压目录:make && make install #编译并安装

  • 安装完成,安装路径为/usr/local/nginx ,日志路径为 /usr/local/nginx/logs ,

    可执行文件路径为 /usr/local/nginx/sbin ,配置文件路径为 /usr/local/nginx/conf

    欢迎页面路径为 /usr/local/nginx/html

  • ln -s /usr/local/nginx/sbin/nginx /usr/bin/nginx 制作连接,便于执行nginx指令

  • nginx #启动
    nginx -s stop #关闭
    nginx -s reload #重启

    http://ip:80即可访问nginx欢迎页面

二、nginx与uWSGI

nginx配置–到配置路径中的nginx.conf /usr/local/nginx/conf/nginx.conf

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
upstream ems{
server 192.168.157.141:9001; # uWSGI's socket =
#server 192.168.157.142:9001; #192.168.x.x:9001
#可以在添加其他的uWSGI的服务器
}

server {
listen 80;
server_name 192.168.157.142; # nginx服务器的ip
charset utf-8;

location / {
uwsgi_pass ems; #和上面的upstream转接
include /usr/local/nginx/conf/uwsgi_params;
}
location /static {
alias /usr/local/static;
}
...

配置好后,重启nginx即可,可以使用Nginx服务器来访问项目

注意关闭防火墙!!

两台虚拟主机,一个运行nginx,其中保存project的静态资源;一个运行uwsgi,其中保存并部署project。

三、集群和负载均衡策略

搭建uWSGI集群,只需要多做几份uWSGI的配置文件,文件中设置不同的ip:port,指向相同的project,然后启动多个uWSGI即可。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
*默认:轮询
upstream django {
server 192.168.0.103:8989;
server 192.168.0.104:8989;
}
*iphash:基于ip的负载均衡.
upstream django {
ip_hash;
server 192.168.0.103:8989;
server 192.168.0.104:8990;
}
*权重轮询:
upstream django {
server 192.168.0.103:8989 weight=1;
server 192.168.0.104:8990 weight=2;
}
*最小连接数:
upstream django {
least_conn;
server 192.168.0.103:8989;
server 192.168.0.104:8990;
}

至此,一个uWSGI集群搭建完成,nginx作为反向代理服务器和web服务器接收请求,然后处理静态的部分,动态部分按照负载均衡策略转发给某一个uWSGI服务器。

1
2
3
# 集群解决了什么问题:
1. 高并发
2. 高完整性(高可用性)

至此python-web-project成功运行于 一个对高并发有更好支持,具有高可用性(high-available)的系统中

Prev:
Pycharm连接MySQL问腿
Next:
Linux-环境部署收集