网站可以自己做服务器么,汕头生态建设典型案例,seo任务优化网站排名,网站建设的步骤有哪些文章目录 学习链接概图一、Nginx简介1.1 背景介绍名词解释 1.2 常见服务器对比IISTomcatApacheLighttpd其他的服务器 1.3 Nginx的优点(1)速度更快、并发更高(2)配置简单#xff0c;扩展性强(3)高可靠性(4)热部署(5)成本低、BSD许可证 1.4 Nginx的功能特性及常用功能基本HTTP服… 文章目录 学习链接概图一、Nginx简介1.1 背景介绍名词解释 1.2 常见服务器对比IISTomcatApacheLighttpd其他的服务器 1.3 Nginx的优点(1)速度更快、并发更高(2)配置简单扩展性强(3)高可靠性(4)热部署(5)成本低、BSD许可证 1.4 Nginx的功能特性及常用功能基本HTTP服务高级HTTP服务邮件服务Nginx常用的功能模块 二、Nginx环境准备2.1 Nginx版本介绍2.2 获取Nginx源码2.3 准备服务器系统2.4 Nginx安装方式介绍2.4.1 前置环境GCC编译器PCREzlibOpenSSL 2.4.2 方案一Nginx的源码简单安装2.4.3 方案二yum安装源码简单安装和yum安装的差异解压Nginx目录 2.4.4 方案三:Nginx的源码复杂安装 2.5 Nginx目录结构分析2.6 Nginx服务器启停命令2.6.1 方式一:Nginx服务的信号控制2.6.2 方式二:Nginx的命令行控制 2.7 Nginx服务器版本升级和新增模块2.7.1 环境准备2.7.2 方案一:使用Nginx服务信号进行升级2.7.3 方案二:使用Nginx安装目录的make命令完成升级 三、Nginx核心配置文件结构3.1 全局块3.1.1 user指令3.1.2 work process指令3.1.3 其他指令 3.2 events块events指令配置实例 3.3 http块3.3.1 定义MIME-Type3.3.2 自定义服务日志3.3.3 其他配置指令 3.4 server块和location块 学习链接
黑马程序员Nginx教程Java进阶从0到1学会Nginx分布式框架
概图 一、Nginx简介
1.1 背景介绍
Nginx“engine x”一个具有高性能的【HTTP】和【反向代理】的【WEB服务器】同时也是一个【POP3/SMTP/IMAP代理服务器】是由伊戈尔·赛索耶夫(俄罗斯人)使用C语言编写的Nginx的第一个版本是2004年10月4号发布的0.1.0版本。另外值得一提的是伊戈尔·赛索耶夫将Nginx的源码进行了开源这也为Nginx的发展提供了良好的保障。 名词解释 WEB服务器 WEB服务器也叫网页服务器英文名叫Web Server主要功能是为用户提供网上信息浏览服务。 HTTP: HTTP是超文本传输协议的缩写是用于从WEB服务器传输超文本到本地浏览器的传输协议也是互联网上应用最为广泛的一种网络协议。HTTP是一个客户端和服务器端请求和应答的标准客户端是终端用户服务端是网站通过使用Web浏览器、网络爬虫或者其他工具客户端发起一个到服务器上指定端口的HTTP请求。 POP3/SMTP/IMAP POP3(Post Offic Protocol 3)邮局协议的第三个版本 SMTP(Simple Mail Transfer Protocol)简单邮件传输协议 IMAP(Internet Mail Access Protocol)交互式邮件存取协议 通过上述名词的解释我们可以了解到Nginx也可以作为电子邮件代理服务器。 反向代理 正向代理 反向代理
1.2 常见服务器对比
在介绍这一节内容之前我们先来认识一家公司叫Netcraft。
Netcraft公司于1994年底在英国成立多年来一直致力于互联网市场以及在线安全方面的咨询服务其中在国际上最具影响力的当属其针对网站服务器、SSL市场所做的客观严谨的分析研究公司官网每月公布的调研数据Web Server Survey已成为当今人们了解全球网站数量以及服务器市场分额情况的主要参考依据时常被诸如华尔街杂志英国BBCSlashdot等媒体报道或引用。
我们先来看一组数据我们先打开Nginx的官方网站 http://nginx.org/,找到Netcraft公司公布的数据对当前主流服务器产品进行介绍。 上面这张图展示了2019年全球主流Web服务器的市场情况其中有Apache、Microsoft-IIS、google Servers、Nginx、Tomcat等而我们在了解新事物的时候往往习惯通过类比来帮助自己理解事物的概貌。所以下面我们把几种常见的服务器来给大家简单介绍下
IIS
全称(Internet Information Services)即互联网信息服务是由微软公司提供的基于windows系统的互联网基本服务。windows作为服务器在稳定性与其他一些性能上都不如类UNIX操作系统因此在需要高性能Web服务器的场合下IIS可能就会被冷落.
Tomcat
Tomcat是一个运行Servlet和JSP的Web应用软件Tomcat技术先进、性能稳定而且开放源代码因此深受Java爱好者的喜爱并得到了部分软件开发商的认可成为目前比较流行的Web应用服务器。但是Tomcat天生是一个重量级的Web服务器对静态文件和高并发的处理比较弱。
Apache
Apache的发展时期很长同时也有过一段辉煌的业绩。从上图可以看出大概在2014年以前都是市场份额第一的服务器。Apache有很多优点如稳定、开源、跨平台等。但是它出现的时间太久了在它兴起的年代互联网的产业规模远远不如今天所以它被设计成一个重量级的、不支持高并发的Web服务器。在Apache服务器上如果有数以万计的并发HTTP请求同时访问就会导致服务器上消耗大量能存操作系统内核对成百上千的Apache进程做进程间切换也会消耗大量的CUP资源并导致HTTP请求的平均响应速度降低这些都决定了Apache不可能成为高性能的Web服务器。这也促使了Lighttpd和Nginx的出现。
Lighttpd
Lighttpd是德国的一个开源的Web服务器软件它和Nginx一样都是轻量级、高性能的Web服务器欧美的业界开发者比较钟爱Lighttpd,而国内的公司更多的青睐Nginx同时网上Nginx的资源要更丰富些。
其他的服务器
Google ServersWeblogic, Webshpere(IBM)…
经过各个服务器的对比种种迹象都表明Nginx将以性能为王。这也是我们为什么选择Nginx的理由。
1.3 Nginx的优点
(1)速度更快、并发更高
单次请求或者高并发请求的环境下Nginx都会比其他Web服务器响应的速度更快。一方面在正常情况下单次请求会得到更快的响应另一方面在高峰期(如有数以万计的并发请求)Nginx比其他Web服务器更快的响应请求。Nginx之所以有这么高的并发处理能力和这么好的性能原因在于Nginx采用了多进程和I/O多路复用(epoll)的底层实现。
(2)配置简单扩展性强
Nginx的设计极具扩展性它本身就是由很多模块组成这些模块的使用可以通过配置文件的配置来添加。这些模块有官方提供的也有第三方提供的模块如果需要完全可以开发服务自己业务特性的定制模块。
(3)高可靠性
Nginx采用的是多进程模式运行其中有一个master主进程和N多个worker进程worker进程的数量我们可以手动设置每个worker进程之间都是相互独立提供服务并且master主进程可以在某一个worker进程出错时快速去拉起新的worker进程提供服务。
(4)热部署
现在互联网项目都要求以7*24小时进行服务的提供针对于这一要求Nginx也提供了热部署功能即可以在Nginx不停止的情况下对Nginx进行文件升级、更新配置和更换日志文件等功能。
(5)成本低、BSD许可证
BSD是一个开源的许可证世界上的开源许可证有很多现在比较流行的有六种分别是GPL、BSD、MIT、Mozilla、Apache、LGPL。这六种的区别是什么我们可以通过下面一张图来解释下 Nginx本身是开源的我们不仅可以免费的将Nginx应用在商业领域而且还可以在项目中直接修改Nginx的源码来定制自己的特殊要求。这些点也都是Nginx为什么能吸引无数开发者继续为Nginx来贡献自己的智慧和青春。OpenRestry [NginxLua] Tengine[淘宝]
1.4 Nginx的功能特性及常用功能
Nginx提供的基本功能服务从大体上归纳为基本HTTP服务、“高级HTTP服务”和邮件服务等三大类。
基本HTTP服务
Nginx可以提供基本HTTP服务可以作为HTTP代理服务器和反向代理服务器支持通过缓存加速访问可以完成简单的负载均衡和容错支持包过滤功能支持SSL等。
处理静态文件、处理索引文件以及支持自动索引提供反向代理服务器并可以使用缓存加上反向代理同时完成负载均衡和容错提供对FastCGI、memcached等服务的缓存机制同时完成负载均衡和容错使用Nginx的模块化特性提供过滤器功能。Nginx基本过滤器包括gzip压缩、ranges支持、chunked响应、XSLT、SSI以及图像缩放等。其中针对包含多个SSI的页面经由FastCGI或反向代理SSI过滤器可以并行处理。支持HTTP下的安全套接层安全协议SSL.支持基于加权和依赖的优先权的HTTP/2
高级HTTP服务
支持基于名字和IP的虚拟主机设置支持HTTP/1.0中的KEEP-Alive模式和管线(PipeLined)模型连接自定义访问日志格式、带缓存的日志写操作以及快速日志轮转。提供3xx~5xx错误代码重定向功能支持重写Rewrite)模块扩展支持重新加载配置以及在线升级时无需中断正在处理的请求支持网络监控支持FLV和MP4流媒体传输
邮件服务
Nginx提供邮件代理服务也是其基本开发需求之一主要包含以下特性
支持IMPA/POP3代理服务功能支持内部SMTP代理服务功能
Nginx常用的功能模块
静态资源部署
Rewrite地址重写正则表达式
反向代理
负载均衡轮询、加权轮询、ip_hash、url_hash、fair
Web缓存
环境部署高可用的环境
用户认证模块...Nginx的核心组成
nginx 二进制可执行文件
nginx.conf 配置文件
error.log 错误的日志记录
access.log 访问日志记录二、Nginx环境准备
2.1 Nginx版本介绍
Nginx的官方网站为: http://nginx.org
打开源码可以看到如下的页面内容 Nginx的官方下载网站为http://nginx.org/en/download.html当然你也可以之间在首页选中右边的download进入版本下载网页。在下载页面我们会看到如下内容 2.2 获取Nginx源码
http://nginx.org/download/
打开上述网站就可以查看到Nginx的所有版本选中自己需要的版本进行下载。下载我们可以直接在windows上下载然后上传到服务器也可以直接从服务器上下载这个时候就需要准备一台服务器。 2.3 准备服务器系统
环境准备
VMware WorkStation
Centos7
MobaXtermxsheel,SecureCRT
网络(1)确认centos的内核
准备一个内核为2.6及以上版本的操作系统因为linux2.6及以上内核才支持epoll,而Nginx需要解决高并发压力问题是需要用到epoll所以我们需要有这样的版本要求。
我们可以使用uname -a命令来查询linux的内核版本。 (2)确保centos能联网
ping www.baidu.com(3)确认关闭防火墙
这一项的要求仅针对于那些对linux系统的防火墙设置规则不太清楚的建议大家把防火墙都关闭掉因为我们此次课程主要的内容是对Nginx的学习把防火墙关闭掉可以省掉后续Nginx学习过程中遇到的诸多问题。
关闭的方式有如下两种
systemctl stop firewalld 关闭运行的防火墙系统重新启动后防火墙将重新打开
systemctl disable firewalld 永久关闭防火墙系统重新启动后防火墙依然关闭
systemctl status firewalld 查看防火墙状态4确认停用selinux
selinux(security-enhanced linux),美国安全局对于强制访问控制的实现在linux2.6内核以后的版本中selinux已经成功内核中的一部分。可以说selinux是linux史上最杰出的新安全子系统之一。虽然有了selinux我们的系统会更安全但是对于我们的学习Nginx的历程中会多很多设置所以这块建议大家将selinux进行关闭。 sestatus查看状态 如果查看不是disabled状态我们可以通过修改配置文件来进行设置,修改SELINUXdisabled然后重启下系统即可生效。
vim /etc/selinux/config2.4 Nginx安装方式介绍
Nginx的安装方式有两种分别是:
通过Nginx源码通过Nginx源码简单安装 (1)通过Nginx源码复杂安装 (3)
通过yum安装 (2)如果通过Nginx源码安装需要提前准备的内容
2.4.1 前置环境
GCC编译器
Nginx是使用C语言编写的程序因此想要运行Nginx就需要安装一个编译工具。GCC就是一个开源的编译器集合用于处理各种各样的语言其中就包含了C语言。
使用命令yum install -y gcc来安装
安装成功后可以通过gcc --version来查看gcc是否安装成功
PCRE
Nginx在编译过程中需要使用到PCRE库perl Compatible Regular Expressoin 兼容正则表达式库)因为在Nginx的Rewrite模块和http核心模块都会使用到PCRE正则表达式语法。
可以使用命令yum install -y pcre pcre-devel来进行安装
安装成功后可以通过rpm -qa pcre pcre-devel来查看是否安装成功
zlib
zlib库提供了开发人员的压缩算法在Nginx的各个模块中需要使用gzip压缩所以我们也需要提前安装其库及源代码zlib和zlib-devel
可以使用命令yum install -y zlib zlib-devel来进行安装
安装成功后可以通过rpm -qa zlib zlib-devel来查看是否安装成功
OpenSSL
OpenSSL是一个开放源代码的软件库包应用程序可以使用这个包进行安全通信并且避免被窃听。
SSL:Secure Sockets Layer安全套接协议的缩写可以在Internet上提供秘密性传输其目标是保证两个应用间通信的保密性和可靠性。在Nginx中如果服务器需要提供安全网页时就需要用到OpenSSL库所以我们需要对OpenSSL的库文件及它的开发安装包进行一个安装。
可以使用命令yum install -y openssl openssl-devel来进行安装
安装成功后可以通过rpm -qa openssl openssl-devel来查看是否安装成功
上述命令一个个来的话比较麻烦我们也可以通过一条命令来进行安装
yum install -y gcc pcre pcre-devel zlib zlib-devel openssl openssl-devel进行全部安装。
2.4.2 方案一Nginx的源码简单安装
(1)进入官网查找需要下载版本的链接地址然后使用wget命令进行下载
wget http://nginx.org/download/nginx-1.16.1.tar.gz(2)建议大家将下载的资源进行包管理
mkdir -p nginx/core
mv nginx-1.16.1.tar.gz nginx/core(3)解压缩
tar -xzf nginx-1.16.1.tar.gz(4)进入资源文件中发现configure
./configure(5)编译
make(6)安装
make install(7)启动nginx
经过上述步骤nginx默认安装在/usr/local/nginx文件夹中
cd /usr/loca/nginx/sbin # 进入到nginx二进制可执行文件所在文件夹
./nginx # 启动nginx2.4.3 方案二yum安装
使用源码进行简单安装我们会发现安装的过程比较繁琐需要提前准备GCC编译器、PCRE兼容正则表达式库、zlib压缩库、OpenSSL安全通信的软件库包然后才能进行Nginx的安装。
1安装yum-utils
sudo yum install -y yum-utils2添加yum源文件
vim /etc/yum.repos.d/nginx.repo[nginx-stable]
namenginx stable repo
baseurlhttp://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck1
enabled1
gpgkeyhttps://nginx.org/keys/nginx_signing.key
module_hotfixestrue[nginx-mainline]
namenginx mainline repo
baseurlhttp://nginx.org/packages/mainline/centos/$releasever/$basearch/
gpgcheck1
enabled0
gpgkeyhttps://nginx.org/keys/nginx_signing.key
module_hotfixestrue3查看是否安装成功
yum list | grep nginx4使用yum进行安装
yum install -y nginx5查看nginx的安装位置
whereis nginx6启动测试
源码简单安装和yum安装的差异
这里先介绍一个命令: ./nginx -V,通过该命令可以查看到所安装Nginx的版本及相关配置信息。
简单安装 yum安装 解压Nginx目录
执行tar -zxvf nginx-1.16.1.tar.gz对下载的资源进行解压缩进入压缩后的目录可以看到如下结构 内容解释
auto:存放的是编译相关的脚本
CHANGES:版本变更记录
CHANGES.ru:俄罗斯文的版本变更记录
conf:nginx默认的配置文件
configure:nginx软件的自动脚本程序,是一个比较重要的文件作用如下
1检测环境及根据环境检测结果生成C代码
2生成编译代码需要的Makefile文件
contrib:存放的是几个特殊的脚本文件其中README中对脚本有着详细的说明
html:存放的是Nginx自带的两个html页面访问Nginx的首页和错误页面
LICENSE:许可证的相关描述文件
man:nginx的man手册
README:Nginx的阅读指南
src:Nginx的源代码
2.4.4 方案三:Nginx的源码复杂安装
这种方式和简单的安装配置不同的地方在第一步通过./configure来对编译参数进行设置需要我们手动来指定。那么都有哪些参数可以进行设置接下来我们进行一个详细的说明。
PATH:是和路径相关的配置信息
with:是启动模块默认是关闭的
without:是关闭模块默认是开启的
我们先来认识一些简单的路径配置以及通过这些配置来完成一个简单的编译
–prefixPATH
指向Nginx的安装目录默认值为/usr/local/nginx –sbin-pathPATH
指向(执行)程序文件(nginx)的路径,默认值为prefix/sbin/nginx–modules-pathPATH
指向Nginx动态模块安装目录默认值为prefix/modules–conf-pathPATH
指向配置文件(nginx.conf)的路径,默认值为prefix/conf/nginx.conf–error-log-pathPATH
指向错误日志文件的路径,默认值为prefix/logs/error.log–http-log-pathPATH
指向访问日志文件的路径,默认值为prefix/logs/access.log–pid-pathPATH
指向Nginx启动后进行ID的文件路径默认值为prefix/logs/nginx.pid–lock-pathPATH
指向Nginx锁文件的存放路径,默认值为prefix/logs/nginx.lock要想使用可以通过如下命令
./configure --prefix/usr/local/nginx \
--sbin-path/usr/local/nginx/sbin/nginx \
--modules-path/usr/local/nginx/modules \
--conf-path/usr/local/nginx/conf/nginx.conf \
--error-log-path/usr/local/nginx/logs/error.log \
--http-log-path/usr/local/nginx/logs/access.log \
--pid-path/usr/local/nginx/logs/nginx.pid \
--lock-path/usr/local/nginx/logs/nginx.lock在使用上述命令之前需要将之前服务器已经安装的nginx进行卸载卸载的步骤分为三步骤
步骤一需要将nginx的进程关闭须进入到nginx的sbin文件夹
./nginx -s stop步骤二:将安装的nginx进行删除
rm -rf /usr/local/nginx步骤三:将安装包之前编译的环境清除掉须进入到nginx解压的文件夹
make clean2.5 Nginx目录结构分析
在使用Nginx之前我们先对安装好的Nginx目录文件进行一个分析在这块给大家介绍一个工具tree通过tree我们可以很方面的去查看centos系统上的文件目录结构当然如果想使用tree工具就得先通过yum install -y tree来进行安装安装成功后可以通过执行tree /usr/local/nginx(tree后面跟的是Nginx的安装目录)获取的结果如下 conf:nginx所有配置文件目录
CGI(Common Gateway Interface)通用网关【接口】主要解决的问题是从客户端发送一个请求和数据服务端获取到请求和数据后可以调用调用CGI【程序】处理及相应结果给客户端的一种标准规范。
fastcgi.conf:fastcgi相关配置文件
fastcgi.conf.default:fastcgi.conf的备份文件
fastcgi_params:fastcgi的参数文件
fastcgi_params.default:fastcgi的参数备份文件
scgi_params:scgi的参数文件
scgi_params.defaultscgi的参数备份文件
uwsgi_params:uwsgi的参数文件
uwsgi_params.default:uwsgi的参数备份文件
mime.types:记录的是HTTP协议中的Content-Type的值和文件后缀名的对应关系
mime.types.default:mime.types的备份文件
nginx.conf:这个是Nginx的核心配置文件这个文件非常重要也是我们即将要学习的重点
nginx.conf.default:nginx.conf的备份文件
koi-utf、koi-win、win-utf这三个文件都是与编码转换映射相关的配置文件用来将一种编码转换成另一种编码
html:存放nginx自带的两个静态的html页面
50x.html:访问失败后的失败页面
index.html:成功访问的默认首页
logs:记录入门的文件当nginx服务器启动后这里面会有 access.log访问日志 error.log错误日志 和nginx.pidnginx进程的pid三个文件出现。
sbin:是存放执行程序文件nginx
nginx是用来控制Nginx的启动和停止等相关的命令。
2.6 Nginx服务器启停命令
Nginx安装完成后接下来我们要学习的是如何启动、重启和停止Nginx的服务。
对于Nginx的启停在linux系统中也有很多种方式我们本次课程介绍两种方式 Nginx服务的信号控制 Nginx的命令行控制
2.6.1 方式一:Nginx服务的信号控制
Nginx中的master和worker进程?
Nginx的工作方式?
如何获取进程的PID?
信号有哪些?
如何通过信号控制Nginx的启停等相关操作?前面在提到Nginx的高性能其实也和它的架构模式有关。Nginx默认采用的是多进程的方式来工作的当将Nginx启动后我们通过ps -ef | grep nginx命令可以查看到如下内容 从上图中可以看到,Nginx后台进程中包含一个master进程和多个worker进程master进程主要用来管理worker进程包含接收外界的信息并将接收到的信号发送给各个worker进程监控worker进程的状态当worker进程出现异常退出后会自动重新启动新的worker进程。而worker进程则是专门用来处理用户请求的各个worker进程之间是平等的并且相互独立处理请求的机会也是一样的。nginx的进程模型我们可以通过下图来说明下 我们现在作为管理员只需要通过给master进程发送信号就可以来控制Nginx,这个时候我们需要有两个前提条件一个是要操作的master进程一个是信号。
1要想操作Nginx的master进程就需要获取到master进程的进程号ID。获取方式简单介绍两个
方式一通过ps -ef | grep nginx
方式二在讲解nginx的./configure的配置参数的时候有一个参数是--pid-pathPATH默认是/usr/local/nginx/logs/nginx.pid,所以可以通过查看该文件来获取nginx的master进程ID.
2信号
信号作用TERM/INT立即关闭整个服务QUIT优雅地关闭整个服务HUP重读配置文件并使用服务对新配置项生效USR1重新打开日志文件可以用来进行日志切割USR2平滑升级到最新版的nginxWINCH所有子进程不在接收处理新连接相当于给work进程发送QUIT指令
调用命令为kill -signal PID
signal:即为信号PID即为获取到的master线程ID
发送TERM/INT信号给master进程会将Nginx服务立即关闭。
kill -TERM PID / kill -TERM cat /usr/local/nginx/logs/nginx.pid
kill -INT PID / kill -INT cat /usr/local/nginx/logs/nginx.pid发送QUIT信号给master进程master进程会控制所有的work进程不再接收新的请求等所有请求处理完后在把进程都关闭掉包括master进程。
kill -QUIT PID / kill -TERM cat /usr/local/nginx/logs/nginx.pid发送HUP信号给master进程master进程会把控制旧的work进程不再接收新的请求等处理完请求后将旧的work进程关闭掉然后根据nginx的配置文件重新启动新的work进程
kill -HUP PID / kill -TERM cat /usr/local/nginx/logs/nginx.pid发送USR1信号给master进程告诉Nginx重新开启日志文件比如删掉access.log/error.log日志文件后会重新创建日志文件
kill -USR1 PID / kill -TERM cat /usr/local/nginx/logs/nginx.pid发送USR2信号给master进程告诉master进程要平滑升级这个时候会重新开启对应的master进程和work进程整个系统中将会有两个master进程并且新的master进程的PID会被记录在/usr/local/nginx/logs/nginx.pid而之前的旧的master进程PID会被记录在/usr/local/nginx/logs/nginx.pid.oldbin文件中接着再次发送QUIT信号给旧的master进程让其处理完请求后再进行关闭
kill -USR2 PID / kill -USR2 cat /usr/local/nginx/logs/nginx.pidkill -QUIT PID / kill -QUIT cat /usr/local/nginx/logs/nginx.pid.oldbin发送WINCH信号给master进程让master进程控制不让所有的work进程在接收新的请求了请求处理完后关闭work进程。注意master进程不会被关闭掉。
kill -WINCH PID /kill -WINCHcat /usr/local/nginx/logs/nginx.pid2.6.2 方式二:Nginx的命令行控制
此方式是通过Nginx安装目录下的sbin下的可执行文件nginx来进行Nginx状态的控制我们可以通过nginx -h来查看都有哪些参数可以用 -?和-h:显示帮助信息
-v:打印版本号信息并退出
-V:打印版本号信息和配置信息并退出
-t:测试nginx的配置文件语法是否正确并退出
-T:测试nginx的配置文件语法是否正确并列出用到的配置文件信息然后退出
-q:在配置测试期间禁止显示非错误消息
-s:signal信号后面可以跟
stop[快速关闭类似于TERM/INT信号的作用]
quit[优雅的关闭类似于QUIT信号的作用]
reopen[重新打开日志文件类似于USR1信号的作用]
reload[类似于HUP信号的作用]
-p:prefix指定Nginx的prefix路径(默认为: /usr/local/nginx/)
-c:filename,指定Nginx的配置文件路径,(默认为: conf/nginx.conf)
-g:用来补充Nginx配置文件向Nginx服务指定启动时应用全局的配置
2.7 Nginx服务器版本升级和新增模块
如果想对Nginx的版本进行更新或者要应用一些新的模块最简单的做法就是停止当前的Nginx服务然后开启新的Nginx服务。但是这样会导致在一段时间内用户是无法访问服务器。为了解决这个问题我们就需要用到Nginx服务器提供的平滑升级功能。这个也是Nginx的一大特点使用这种方式就可以使Nginx在7*24小时不间断的提供服务了。接下来我们分析下需求
需求Nginx的版本最开始使用的是Nginx-1.14.2,由于服务升级需要将Nginx的版本升级到Nginx-1.16.1,要求Nginx不能中断提供服务。为了应对上述的需求这里我们给大家提供两种解决方案:
方案一:使用Nginx服务信号完成Nginx的升级
方案二:使用Nginx安装目录的make命令完成升级
2.7.1 环境准备
1先准备两个版本的Nginx分别是 1.14.2和1.16.1
2使用Nginx源码安装的方式将1.14.2版本安装成功并正确访问
进入安装目录
./configure
make make install3将Nginx1.16.1进行参数配置和编译不需要进行安装。
进入安装目录
./configure
make 2.7.2 方案一:使用Nginx服务信号进行升级
第一步:将1.14.2版本的sbin目录下的nginx进行备份
cd /usr/local/nginx/sbin
mv nginx nginxold第二步:将Nginx1.16.1安装目录编译后的objs目录下的nginx文件拷贝到原来/usr/local/nginx/sbin目录下
cd ~/nginx/core/nginx-1.16.1/objs
cp nginx /usr/local/nginx/sbin第三步:发送信号USR2给Nginx的1.14.2版本对应的master进程此时ps -ef|grep nginx会发现nginx有两个master进程
第四步:发送信号QUIT给Nginx的1.14.2版本对应的master进程
kill -QUIT more /usr/local/logs/nginx.pid.oldbin2.7.3 方案二:使用Nginx安装目录的make命令完成升级
第一步:将1.14.2版本的sbin目录下的nginx进行备份
cd /usr/local/nginx/sbin
mv nginx nginxold第二步:将Nginx1.16.1安装目录编译后的objs目录下的nginx文件拷贝到原来/usr/local/nginx/sbin目录下
cd ~/nginx/core/nginx-1.16.1/objs
cp nginx /usr/local/nginx/sbin第三步:进入到安装目录执行make upgrade可以看到下图的执行命令的过程正是我们上面手动的流程 第四步:查看是否更新成功
./nginx -v在整个过程中其实Nginx是一直对外提供服务的。并且当Nginx的服务器启动成功后我们是可以通过浏览器进行直接访问的同时我们可以通过更改html目录下的页面来修改我们在页面上所看到的内容那么问题来了为什么我们要修改html目录下的文件能不能多添加一些页面是Nginx的功能更加丰富还有前面聊到Nginx的前端功能又是如何来实现的这就需要我们对Nginx的核心配置文件进行一个详细的学习。
三、Nginx核心配置文件结构
从前面的内容学习中我们知道Nginx的核心配置文件默认是放在/usr/local/nginx/conf/nginx.conf这一节我们就来学习下nginx.conf的内容和基本配置方法。
读取Nginx自带的Nginx配置文件我们将其中的注释部分【学习一个技术点就是在Nginx的配置文件中可以使用#来注释】删除掉后就剩下下面内容:
worker_processes 1;events {worker_connections 1024;
}http {include mime.types;default_type application/octet-stream;sendfile on;keepalive_timeout 65;server {listen 80;server_name localhost;location / {root html;index index.html index.htm;}error_page 500 502 503 504 /50x.html;location /50x.html {root html;}}}指令名 指令值; #全局块主要设置Nginx服务器整体运行的配置指令#events块,主要设置,Nginx服务器与用户的网络连接,这一部分对Nginx服务器的性能影响较大
events { 指令名 指令值;
}#http块是Nginx服务器配置中的重要部分代理、缓存、日志记录、第三方模块配置...
http { 指令名 指令值;server { #server块是Nginx配置和虚拟主机相关的内容指令名 指令值;location / { #location块基于Nginx服务器接收请求字符串与location后面的值进行匹配对特定请求进行处理指令名 指令值;}}...
}简单小结下:
nginx.conf配置文件中默认有三大块全局块、events块、http块
http块中可以配置多个server块每个server块又可以配置多个location块。
3.1 全局块
3.1.1 user指令
1user:用于配置运行Nginx服务器的worker进程的用户和用户组。
语法user user [group]默认值nobody位置全局块
该属性也可以在编译的时候指定语法如下./configure --useruser --groupgroup,如果两 个地方都进行了设置最终生效的是配置文件中的配置。每次修改配置文件后记得使用./nginx -t检测配置文件是否有错误。
该指令的使用步骤:
(1)设置一个用户信息www
## 在nginx.conf设置user nobody;使用nginx -s reload后,使用ps -ef|grep nginx发现worker进程的所有者成了nobody
user www; (2) 创建一个用户
useradd www(3)修改user属性
user www(4)创建/root/html/index.html页面添加如下内容
!DOCTYPE html
html
head
titleWelcome to nginx!/title
stylebody {width: 35em;margin: 0 auto;font-family: Tahoma, Verdana, Arial, sans-serif;}
/style
/head
body
h1Welcome to nginx!/h1
pIf you see this page, the nginx web server is successfully installed and
working. Further configuration is required./ppFor online documentation and support please refer to
a hrefhttp://nginx.org/nginx.org/a.br/
Commercial support is available at
a hrefhttp://nginx.com/nginx.com/a./ppemThank you for using nginx./em/p
pemI am WWW/em/p
/body
/html(5)修改nginx.conf
location / {root /root/html;index index.html index.htm;
}(5)测试启动访问
页面会报403拒绝访问的错误(6)分析原因
因为当前用户没有访问/root/html目录的权限(7)将文件创建到 /home/www/html/index.html,修改配置
location / {root /home/www/html;index index.html index.htm;
}(8)再次测试启动访问
能正常访问。综上所述使用user指令可以指定启动运行工作进程的用户及用户组这样对于系统的权限访问控制的更加精细也更加安全。
3.1.2 work process指令
master_process:用来指定是否开启工作进程。
语法master_process on|off;默认值master_process on;位置全局块
在nginx.conf配置文件中配置该指令后需要重启使用nginx -s stop停止并使用./nginx启动则可看到没有工作进程了只有master主进程。
worker_processes:用于配置Nginx生成工作进程的数量这个是Nginx服务器实现并发处理服务的关键所在。理论上来说workder process的值越大可以支持的并发处理量也越多但事实上这个值的设定是需要受到来自服务器自身的限制建议将该值和服务器CPU的内核数保存一致。
语法worker_processes num/auto;默认值1位置全局块
如果将worker_processes设置成2则会看到如下内容前提是master_process指令必须配置成on并且修改后也需要重启: 3.1.3 其他指令
daemon设定Nginx是否以守护进程的方式启动。
守护式进程是linux后台执行的一种服务进程特点是独立于控制终端不会随着终端关闭而停止。
语法daemon on|off;默认值daemon on;位置全局块
修改后需要重启。当配置nginx不以守护进程启动时使用./nginx启动nginx后ctrlc关闭命令行nginx就会停止。
pid:用来配置Nginx当前master进程的进程号ID存储的文件路径。
语法pid file;默认值默认为:/usr/local/nginx/logs/nginx.pid位置全局块
该属性可以通过./configure --pid-pathPATH来指定
error_log:用来配置Nginx的错误日志存放路径
语法error_log file [日志级别];默认值error_log logs/error.log error;位置全局块、http、server、location
该属性可以通过./configure --error-log-pathPATH来指定
其中日志级别的值有debug|info|notice|warn|error|crit|alert|emerg翻译过来为试|信息|通知|警告|错误|临界|警报|紧急这块建议大家设置的时候不要设置成info以下的等级因为会带来大量的磁盘I/O消耗影响Nginx的性能。
include:用来引入其他配置文件使Nginx的配置更加灵活
语法include file;默认值无位置any
比如在与nginx.conf同文件夹下的main.conf配置文件如果要引入它可配置include main.conf;
3.2 events块
accept_mutex:用来设置Nginx网络连接序列化
语法accept_mutex on|off;默认值accept_mutex on;位置events
这个配置主要可以用来解决常说的惊群问题。大致意思是在某一个时刻客户端发来一个请求连接Nginx后台是以多进程的工作模式也就是说有多个worker进程会被同时唤醒但是最终只会有一个进程可以获取到连接如果每次唤醒的进程数目太多就会影响Nginx的整体性能。如果将上述值设置为on(开启状态)将会对多个Nginx进程接收连接进行序列号一个个来唤醒接收就防止了多个进程对连接的争抢。 multi_accept:用来设置是否允许同时接收多个网络连接
语法multi_accept on|off;默认值multi_accept off;位置events
如果multi_accept被禁止了nginx一个工作进程只能同时接受一个新的连接。否则一个工作进程可以同时接受所有的新连接
worker_connections用来配置单个worker进程最大的连接数
语法worker_connections number;默认值worker_commections 512;位置events
这里的连接数不仅仅包括和前端用户建立的连接数而是包括所有可能的连接数。另外number值不能大于操作系统支持打开的最大文件句柄数量。
use:用来设置Nginx服务器选择哪种事件驱动来处理网络消息。
语法use method;默认值根据操作系统定位置events
注意此处所选择事件处理模型是Nginx优化部分的一个重要内容method的可选值有select/poll/epoll/kqueue等之前在准备centos环境的时候我们强调过要使用linux内核在2.6以上就是为了能使用epoll函数来优化Nginx。
另外这些值的选择我们也可以在编译的时候使用
--with-select_module、--without-select_module、 --with-poll_module、 --without-poll_module来设置是否需要将对应的事件驱动模块编译到Nginx的内核。
events指令配置实例
打开Nginx的配置文件 nginx.conf,添加如下配置
events{accept_mutex on;multi_accept on;worker_commections 1024;use epoll;
}修改nginx.conf之后使用./nginx -s reload去重新加载启动测试
./nginx -t
./nginx -s reload3.3 http块
3.3.1 定义MIME-Type
我们都知道浏览器中可以显示的内容有HTML、XML、GIF等种类繁多的文件、媒体等资源浏览器为了区分这些资源就需要使用MIME Type。所以说MIME Type是网络资源的媒体类型。Nginx作为web服务器也需要能够识别前端请求的资源类型。
在Nginx的配置文件中默认有两行配置
include mime.types;
default_type application/octet-stream;default_type:用来配置Nginx响应前端请求默认的MIME类型。
语法default_type mime-type;默认值default_type text/plain位置http、server、location
在default_type之前还有一句include mime.types,include之前我们已经介绍过相当于把mime.types文件中MIMT类型与相关类型文件的文件后缀名的对应关系加入到当前的配置文件中。
举例来说明
有些时候请求某些接口的时候需要返回指定的文本字符串或者json字符串如果逻辑非常简单或者干脆是固定的字符串那么可以使用nginx快速实现这样就不用编写程序响应请求了可以减少服务器资源占用并且响应性能非常快。
如何实现:
location /get_text {#这里也可以设置成text/plaindefault_type text/html; # 这个将会写成 Content-type响应头返回给浏览器return 200 This is nginxs text;
}location /get_json{default_type application/json;return 200 {name:TOM,age:18};
}修改之后使用./nginx -s reload 重新载入配置即可。
3.3.2 自定义服务日志
Nginx中日志的类型分access.log、error.log。
access.log:用来记录用户所有的访问请求。
error.log:记录nginx本身运行时的错误信息不会记录用户的访问请求。
Nginx服务器支持对服务日志的格式、大小、输出等进行设置需要使用到两个指令分别是access_log和log_format指令。
access_log:用来设置用户访问日志的相关属性。
语法access_log path[format[buffersize]]默认值access_log logs/access.log combined;位置http, server, location
修改之后使用./nginx -s reload重新载入配置文件即可。
log_format:用来指定日志的输出格式。
语法log_format name [escapedefault|json|none] string…;默认值log_format combined “…”;位置http
注意这里配置log_format之后需要在上面的access_log指令后配置format为这里的名字然后使用./nginx -s reload重新载入配置文件。
3.3.3 其他配置指令
sendfile:用来设置Nginx服务器是否使用sendfile()传输文件该属性可以大大提高Nginx处理静态资源的性能
语法sendfile on|off默认值sendfile off;位置http、server、location
keepalive_timeout:用来设置长连接的超时时间。
为什么要使用keepalive
我们都知道HTTP是一种无状态协议客户端向服务端发送一个TCP请求服务端响应完毕后断开连接。
如何客户端向服务端发送多个请求每个请求都需要重新创建一次连接效率相对来说比较多使用keepalive模式可以告诉服务器端在处理完一个请求后保持这个TCP连接的打开状态若接收到来自这个客户端的其他请求服务端就会利用这个未被关闭的连接而不需要重新创建一个新连接提升效率但是这个连接也不能一直保持这样的话连接如果过多也会是服务端的性能下降这个时候就需要我们进行设置其的超时时间。语法keepalive_timeout time;默认值keepalive_timeout 75s;位置http、server、location
keepalive_requests:用来设置一个keep-alive连接使用的次数。
语法keepalive_requests number;默认值keepalive_requests 100;位置http、server、location
3.4 server块和location块
server块和location块都是我们要重点讲解和学习的内容因为我们后面会对Nginx的功能进行详细讲解所以这块内容就放到静态资源部署的地方给大家详细说明。
本节我们主要来认识下Nginx默认给的nginx.conf中的相关内容以及server块与location块在使用的时候需要注意的一些内容。 server {listen 80;server_name localhost;location / {root html; # root指定的是资源所在的目录index index.html index.htm; # index指定的是访问/默认的首页index.html和index.htm都要放在html目录} # 从前往后找找到第一个为止。error_page 500 502 503 504 404 /50x.html; # 当发生这些错误码时跳转到 /50x.htmllocation /50x.html {root html; # 50x.html要放在html目录}}