nginx基本理论和安装部署

本文涉及的产品
传统型负载均衡 CLB,每月750个小时 15LCU
EMR Serverless StarRocks,5000CU*H 48000GB*H
网络型负载均衡 NLB,每月750个小时 15LCU
简介: Nginx (“engine x”) 是一个高性能的、轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。并在一个BSD-like 协议下发行

简介



  • Nginx (“engine x”) 是一个高性能的、轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。并在一个BSD-like 协议下发行


  • Nginx 是由俄罗斯的程序设计师Igor Sysoev所开发,


  • 第一个公开版本0.1.0发布于2004年10月4日


  • 2011年6月1日,nginx 1.0.4发布。因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。


  • ,并在一个BSD-like 协议下发行。由,供俄国大型的入口网站及搜索引擎Rambler(俄文:Рамблер)使用。其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度BWS、新浪、网易、腾讯等


  • Nginx官方网站

RamBler:http://www.rambler.ru/ Nginx:http://nginx.org/


nginx的特性与优点



nginx的特性


  • 在高连接并发,能够支持高达50000个并发连接数的响应


  • 使用epoll and kqueue作为开发模型


  • 负载均衡服务


  • 采用C进行编写,系统资源开销、CPU使用效率 少


nginx的优点


  • 高并发连接:官方测试能够支撑5万并发连接,在实际生产环境中跑到2-3万并发连接数


  • 内存消耗少:在3万并发连接下,开启的10个nginx进程才消耗150M内存(15M*10=150M)


  • 配置文件非常简单:风格跟程序一样通俗易懂


  • 成本低廉:nginx为开源软件,可以免费使用。而购买F5 BIG-IP、NetScaler等硬件负载均衡交换机则需要十多万至几十万人民币


  • 支持Rewrite重写规则:能够根据域名、URL的不同,将HTTP请求分到不同的后端服务器群组


  • 内置的健康检查功能:如果Nginx Proxy后端的某台Web服务器宕机了,不会影响前端访问


  • 节省带宽:支持GZIP压缩,可以添加浏览器本地缓存的Header头


  • 稳定性高:用于反向代理,宕机的概率微乎其微


  • 模块化设计:模块可以动态编译


  • 外围支持好:文档全,二次开发和模块较多


  • 支持热部署:可以不停机重载配置文件


  • -支持事件驱动、AIO(AsyncIO,异步IO)、mmap(Memory Map,内存映射)等性能优化


nginx的功能及应用类别



nginx的基本功能


  • 基于名称和IP的虚拟主机


  • 支持keepalive


  • 支持平滑升级


  • 定制访问日志、支持使用日志缓冲区提高日志存储性能


  • 支持URL重写


  • 支持路径别名


  • 支持基于IP及用户的访问控制


  • 支持速率限制,支持并发数限制


  • nginx的扩展功能


  • 基于名称和IP的虚拟主机


  • 支持keepalive


  • 支持平滑升级


  • 定制访问日志、支持使用日志缓冲区提高日志存储性能


  • 支持URL重写


  • 支持路径别名


  • 支持基于IP及用户的访问控制


  • 支持速率限制,支持并发数限制


nginx的应用类别


  • 使用nginx结合FastCGI运行PHP、JSP、Perl等程序


  • 使用nginx作反向代理、负载均衡、规则过滤


  • 使用nginx运行静态HTML网页、图片


  • nginx与其他新技术的结合应用


了解TengineTengine


  • 是由淘宝网发起的Web服务器项目。它在Nginx的基础上,针对大访问量网站的需求,添加了很多高级功能和特性。Tengine的性能和稳定性已经在大型的网站如淘宝网,天猫商城等得到了很好的检验。(可以这样理解:淘宝拿到了Nginx源代码之后,进行了功能的填充,优化等等,然后提交给Nginx官方,但是由于Nginx官方相应慢或者不响应,加上语言沟通的不顺畅,于是淘宝公司就自己打包,在遵循GPL的原则上进行二次开发,于是就出了现在的Tengine这个版本)。



nginx的模块与工作原理



nginxd的模块


nginx的模块从结构上分为:


  • 核心模块:HTTP模块、EVENT模块和MAIL模块等


  • 基础模块:HTTP Access模块、HTTP FastCGI模块、HTTP Proxy模块和HTTP Rewrite模块等


  • 第三方模块:HTTP Upstream模块(负载分担)、Request Hash模块、Notice模块(提示)和HTTP Access Key模块等


nginx模块从功能上分:


  • Handlers(处理器模块)。此类模块直接处理请求,并进行输出内容和修改headers信息等操作。handlers处理器模块一般只能有一个


  • Filters(过滤器模块)。此类模块主要对其他处理器模块输出的内容进行修改操作,最后由nginx输出


  • Proxies(代理器模块)。就是nginx的HTTP Upstream之类的模块,这些模块主要与后端一些服务比如fastcgi等操作交互,实现服务代理和负载均衡等功能


  • nginx基本模块:所谓基本模块,指的是nginx默认的功能模块,它们提供的指令,允许你使用定义nginx基本功能的变量,在编译时不能被禁用,包括:


核心模块:基本功能和指令,如进程管理和安全。常见的核心模块指令,大部分是放置在配置文件的顶部


事件模块:在Nginx内配置网络使用的能力。常见的events(事件)模块指令,大部分是放置在配置文件的顶部

配置模块:提供包含机制


nginx的工作原理


nginx的进程架构:


启动nginx时,会启动一个Master进程,这个进程不处理任何客户端的请求,主要用来产生worker线程,一个worker线程用来处理n个request



image.png


大白话:当客户端请求访问(http/https)负载均衡服务器,此时又worker进程来处理,分辨客户端请求的是静态、动态、还是在缓存里面的内容,


  • 如果是静态的话,通过HTTP直接交给转发给Web server


  • 如果是动态资源,就转发给通过FastCGI转发给Application server


  • 如果是本地缓存的话的就直接有memcache处理,本地没有缓存,就在次通过配置的I/O 、A/O、mmap相关方式去查找,并记录相关映射


nginx原理总结:



image.png


  • 缓存的原理


image.png


lamp架构和lnmp架构的工作原理对比



Apache:



image.png


Nginx:


image.png


nginx的安装与配置



  • 创建系统用户、组nginx


[root@localhost ~]#groupadd -r nginx
[root@localhost ~]# useradd -r -M -s /sbin/nologin  -g nginx  nginx


  • 安装依赖环境


[root@localhost ~]# yum -y install pcre-devel openssl openssl-devel gcc gcc-c++
安装过程略....
[root@localhost ~]# yum -y groups mark install 'Development Tools'  #如果你安装虚拟机时,安装过开发工具,此步骤无需操作
Loaded plugins: product-id, search-disabled-repos, subscription-manager
This system is not registered with an entitlement server. You can use subscription-manager to register.
There is no installed groups file.
Maybe run: yum groups mark convert (see man yum)
Marked install: Development Tools


  • 创建日志存放目录


[root@localhost ~]# mkdir -p /var/log/nginx
[root@localhost ~]# chown -R nginx.nginx /var/log/nginx


  • 下载nginx


[root@localhost ~]# cd /usr/src/
[root@localhost src]# wget http://nginx.org/download/nginx-1.12.0.tar.gz
…………


  • 编译安装


[root@localhost src]# ls
debug  kernels  nginx-1.12.0.tar.gz
[root@localhost src]# tar xf nginx-1.12.0.tar.gz
[root@localhost src]# cd nginx-1.12.0
[root@localhost nginx-1.12.0]# ./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-debug \
--with-http_ssl_module \
--with-http_realip_module \
--with-http_gunzip_module \
--with-http_gzip_static_module \
--with-http_stub_status_module \
--http-log-path=/var/log/nginx/access.log \
--error-log-path=/var/log/nginx/error.log
[root@localhost nginx-1.12.0]# make -j $(grep 'processor' /proc/cpuinfo | wc -l) && make install
安装过程略....


nginx安装后配置


  • 配置环境变量


[root@localhost ~]# echo 'export PATH=/usr/local/nginx/sbin:$PATH' > /etc/profile.d/nginx.sh
[root@localhost ~]# . /etc/profile.d/nginx.sh


  • 服务控制方式,使用nginx命令


-t //检查配置文件语法


-v //输出nginx的版本


-c //指定配置文件的路径


-s //发送服务控制信号,可选值有{stop|quit|reopen|reload}


  • 启动nginx


[root@localhost ~]# nginx
[root@localhost ~]# ss -antl
State      Recv-Q Send-Q   Local Address:Port                  Peer Address:Port
LISTEN     0      128                  *:80                               *:*
LISTEN     0      128                  *:22                               *:*
LISTEN     0      100          127.0.0.1:25                               *:*
LISTEN     0      128                 :::22                              :::*
LISTEN     0      100                ::1:25                              :::* 


相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
2月前
|
弹性计算 运维 监控
快速部署 Nginx 社区版
Nginx是一个高性能的HTTP和反向代理服务器。Nginx在计算巢上提供了社区版服务,您无需自行配置云主机,即可在计算巢上快速部署Nginx服务、实现运维监控,从而方便地基于Nginx搭建您自己的应用。本文介绍使用如何通过计算巢快速部署Nginx社区版。
快速部署 Nginx 社区版
|
29天前
|
负载均衡 应用服务中间件 Linux
nginx学习,看这一篇就够了:下载、安装。使用:正向代理、反向代理、负载均衡。常用命令和配置文件,很全
这篇博客文章详细介绍了Nginx的下载、安装、配置以及使用,包括正向代理、反向代理、负载均衡、动静分离等高级功能,并通过具体实例讲解了如何进行配置。
134 4
nginx学习,看这一篇就够了:下载、安装。使用:正向代理、反向代理、负载均衡。常用命令和配置文件,很全
|
1月前
|
tengine 关系型数据库 MySQL
Tengine、Nginx安装MySQL数据库命令教程
本指南详细介绍了在Linux系统上安装与配置MySQL数据库的步骤。首先通过下载并安装MySQL社区版本,接着启动MySQL服务,使用`systemctl start mysqld.service`命令。若启动失败,可尝试使用`sudo /etc/init.d/mysqld start`。利用`systemctl status mysqld.service`检查MySQL的服务状态,确保其处于运行中。通过日志文件获取初始密码,使用该密码登录数据库,并按要求更改初始密码以增强安全性。随后创建一个名为`tengine`的数据库,最后验证数据库创建是否成功以及完成整个设置流程。
|
27天前
|
应用服务中间件 Linux nginx
Mac os 安装 nginx 教程(success)
这篇文章是关于如何在Mac OS系统上使用Homebrew安装nginx及其依赖,并解决安装过程中可能出现的权限问题。
63 0
Mac os 安装 nginx 教程(success)
|
1月前
|
tengine 应用服务中间件 Linux
Tengine、Nginx安装PHP命令教程
要在阿里云Linux上安装PHP,请先更新YUM源并启用PHP 8.0仓库,然后安装PHP及相关扩展。通过`php -v`命令验证安装成功后,需修改Nginx配置文件以支持PHP,并重启服务。最后,创建`phpinfo.php`文件测试安装是否成功。对于CentOS系统,还需安装EPEL源和Remi仓库,其余步骤类似。完成上述操作后,可通过浏览器访问`http://IP地址/phpinfo.php`测试安装结果。
|
1月前
|
Ubuntu 搜索推荐 应用服务中间件
Nginx安装与使用
Nginx安装与使用
|
1月前
|
负载均衡 算法 应用服务中间件
Nginx安装及配置详解
Nginx安装及配置详解
|
1月前
|
应用服务中间件 程序员 开发工具
mac下安装nginx
mac下安装nginx
|
1月前
|
前端开发 JavaScript 应用服务中间件
使用nginx部署网站
使用nginx部署网站
|
1月前
|
应用服务中间件 Linux nginx
CentOS7安装Nginx
CentOS7安装Nginx
下一篇
无影云桌面