文章目录
-
- Nginx
- 第1章 Nginx简介
- 1.1 Nginx概述
- 1.2 Nginx作为web服务器
- 1.3 正向代理
- 1.4 反向代理
- 1.5 负载均衡
- 1.6 动静分离
- 第2章 Nginx安装
- 2.1 进入nginx官网,下载
- 2.2 需要的安装包
- 2.3 在线安装nginx
- 第一步,安装pcre
- 第二步,安装openssl 、zlib 、 gcc 依赖
- 第三步,安装nginx
- 第四步,关闭防火墙,访问nginx
- 2.4 离线安装nginx
- 第一步 安装pcre
- 第二步 安装openssl
- 第三步 安装zlib
- 第四步 安装nginx
- 第五步 关闭防火墙,开放端口【参考2.3第四步】
- 第3章 Nginx常用的命令和配置文件
- 3.1 nginx常用的命令
- 3.2 nginx.conf 配置文件
- 第一部分:全局块
- 第二部分:events块
- 第三部分:http块
- ①、http 全局块
- ②、server 块
- 第4章 Nginx配置实例-反向代理
- 4.1 反向代理实例一
- 4.1.1 实验准备工作
- 4.1.2 反向代理实例一演示
- 4.2 反向代理实例二
- 4.2.1 实验准备工作
- 4.2.2 反向代理实例二演示
- 4.2.3 location指令说明
- 第5章 Nginx配置实例-负载均衡
- 5.1 实现效果
- 5.2 准备工作
- 5.3 在nginx的配置文件中进行负载均衡的配置
- 5.4 nginx分配服务器策略
- 5.4.1 轮询(默认)
- 5.4.2 weight
- 5.4.3 ip_hash
- 5.4.4 fair(第三方)
- 5.4.5 其他参数
- 第6章 Nginx配置实例-动静分离
- 6.1 实验代码
- 6.2 实验一
- 6.3 实验二
- 第7章 Nginx原理与优化参数配置
- 7.1 Nginx原理
- 7.2 Nginx.conf配置详解
Nginx
第1章 Nginx简介
1.1 Nginx概述
Nginx (“engine x”) 是一个高性能的HTTP和反向代理服务器,特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等
1.2 Nginx作为web服务器
Nginx可以作为静态页面的web服务器,同时还支持CGI协议的动态语言,比如perl、php等。但是不支持java。Java程序只能通过与tomcat配合完成。Nginx专为性能优化而开发,性能是其最重要的考量,实现上非常注重效率 ,能经受高负载的考验,有报告表明能支持高达 50,000个并发连接数。
https://lnmp.org/nginx.html
https://news.netcraft.com/archives/category/web-server-survey/
1.3 正向代理
Nginx不仅可以做反向代理,实现负载均衡。还能用作正向代理来进行上网等功能。
正向代理:如果把局域网外的Internet想象成一个巨大的资源库,则局域网中的客户端要访问Internet,则需要通过代理服务器来访问,这种代理服务就称为正向代理。
1.4 反向代理
反向代理:其实客户端对代理是无感知的,因为客户端不需要任何配置就可以访问,我们只需要将请求发送到反向代理服务器,由反向代理服务器去选择目标服务器获取数据后,在返回给客户端,此时反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器地址,隐藏了真实服务器IP地址。
访问自己在外国的服务器 这个不会拦截将获取到的数据放到反向代理拿回来
1.5 负载均衡
客户端发送多个请求到服务器,服务器处理请求,有一些可能要与数据库进行交互,服务器处理完毕后,再将结果返回给客户端。
这种架构模式对于早期的系统相对单一,并发请求相对较少的情况下是比较适合的,成本也低。但是随着信息数量的不断增长,访问量和数据量的飞速增长,以及系统业务的复杂度增加,这种架构会造成服务器相应客户端的请求日益缓慢,并发量特别大的时候,还容易造成服务器直接崩溃。很明显这是由于服务器性能的瓶颈造成的问题,那么如何解决这种情况呢?
我们首先想到的可能是升级服务器的配置,比如提高CPU执行频率,加大内存等提高机器的物理性能来解决此问题,但是我们知道摩尔定律的日益失效,硬件的性能提升已经不能满足日益提升的需求了。最明显的一个例子,天猫双十一当天,某个热销商品的瞬时访问量是极其庞大的,那么类似上面的系统架构,将机器都增加到现有的顶级物理配置,都是不能够满足需求的。那么怎么办呢?
上面的分析我们去掉了增加服务器物理配置来解决问题的办法,也就是说纵向解决问题的办法行不通了,那么横向增加服务器的数量呢?这时候集群的概念产生了,单个服务器解决不了,我们增加服务器的数量,然后将请求分发到各个服务器上,将原先请求集中到单个服务器上的情况改为将请求分发到多个服务器上,将负载分发到不同的服务器,也就是我们所说的负载均衡。
1.6 动静分离
为了加快网站的解析速度,可以把动态页面和静态页面由不同的服务器来解析,加快解析速度。降低原来单个服务器的压力。
第2章 Nginx安装
2.1 进入nginx官网,下载
http://nginx.org/ nginx-1.12.2.tar.gz
2.2 需要的安装包
pcre-8.37.tar.gz
openssl-1.0.1t.tar.gz
zlib-1.2.8.tar.gz
nginx-1.12.2.tar.gz
2.3 在线安装nginx
第一步,安装pcre
第一步 联网下载pcre
wget http://downloads.sourceforge.net/project/pcre/pcre/8.37/pcre-8.37.tar.gz
第二步 解压压缩文件
使用命令 tar -zxvf pcre-8.37.tar.gz
第三步 ./configure完成后,回到pcre目录下执行make,最后执行make install
第四步 pcre-config --version 检查版本
第二步,安装openssl 、zlib 、 gcc 依赖
yum -y install make zlib zlib-devel gcc-c++ libtool openssl openssl-devel
第三步,安装nginx
使用命令解压
./configure
make && make install
进入目录 /usr/local/nginx/sbin 执行./nginx 启动服务
第四步,关闭防火墙,访问nginx
在windows系统中访问linux中nginx,默认不能访问的,因为防火墙问题
关闭防火墙-开放访问的端口号,80端口
查看开放的端口号
firewall-cmd --list-all
设置开放的服务或端口号
firewall-cmd --add-service=http --permanent
firewall-cmd --add-port=80/tcp --permanent
重启防火墙
firewall-cmd --reload
2.4 离线安装nginx
第一步 安装pcre
解压缩pcre-xx.tar.gz包
进入解压缩目录,执行./configure
注意:如果提示错误,需要提前安装gcc++
执行 cd /run/media/root/CentOS 7 x86_64/Packages(已经从中拷贝出来了26个安装包,直接使用准备好的文件夹rpmgcc安装即可)
rpm -Uvh *.rpm --nodeps --force
检查安装后版本
gcc -v
g++ -v
./configure完成后,回到pcre目录下执行make,再执行make ennstall
第二步 安装openssl
解压缩openssl-xx.tar.gz包
进入解压缩目录,执行./config
make && make install
第三步 安装zlib
解压缩zlib-xx.tar.gz包
进入解压缩目录,执行./configure
make && make install
第四步 安装nginx
解压缩nginx-xx.tar.gz包
进入解压缩目录,执行./configure
make && make install
第五步 关闭防火墙,开放端口【参考2.3第四步】
第3章 Nginx常用的命令和配置文件
3.1 nginx常用的命令
(1)启动命令
在/usr/local/nginx/sbin目录下执行 ./nginx
(2)关闭命令
在/usr/local/nginx/sbin目录下执行 ./nginx -s stop
(3)重新加载命令
在/usr/local/nginx/sbin目录下执行 ./nginx -s reload
(4)查看版本
(5)查看进程
3.2 nginx.conf 配置文件
nginx 安装目录(/usr/local/nginx/conf/nginx.conf)下,其默认的配置文件都放在这个目录的 conf 目录下,而主配置文件 nginx.conf 也在其中,后续对 nginx 的使用基本上都是对此配置文件进行相应的修改
配置文件中有很多#, 开头的表示注释内容,我们去掉所有以 # 开头的段落,精简之后的内容如下:
配置代理
proxy_pass http://192.168.19.131:8080;
根据上述文件,我们可以很明显的将 nginx.conf 配置文件分为三部分:
第一部分:全局块
从配置文件开始到 events 块之间的内容,主要会设置一些影响nginx 服务器整体运行的配置指令,主要包括配置运行 Nginx 服务器的用户(组)、允许生成的 worker process 数,进程 PID 存放路径、日志存放路径和类型以及配置文件的引入等。
比如上面第一行配置的:
这是 Nginx 服务器并发处理服务的关键配置,worker_processes 值越大,可以支持的并发处理量也越多,但是会受到硬件、软件等设备的制约。
第二部分:events块
比如上面的配置:
events 块涉及的指令主要影响 Nginx 服务器与用户的网络连接,常用的设置包括是否开启对多 work process 下的网络连接进行序列化,是否允许同时接收多个网络连接,选取哪种事件驱动模型来处理连接请求,每个 work process 可以同时支持的最大连接数等。
上述例子就表示每个 work process 支持的最大连接数为 1024.
这部分的配置对 Nginx 的性能影响较大,在实际中应该灵活配置