1.Nginx基本简述

Nginx是一个开源且高性能、可靠的Http Web服务、代理服务。
开源: 直接获取源代码
高性能: 支持海量并发
可靠: 服务稳定

我们为什么选择 Nginx服务
Nginx非常轻量
功能模块少 (源代码仅保留http与核心模块代码,其余不够核心代码会作为插件来安装)
代码模块化 (易读,便于二次开发,对于开发人员非常友好)

互联网公司都选择Nginx
1.Nginx技术成熟,具备的功能是企业最常使用而且最需要的
2.适合当前主流架构趋势, 微服务、云架构、中间层
3.统一技术栈, 降低维护成本, 降低技术更新成本。

Nginx采用Epool网络模型,Apache采用Select模型
Select: 当用户发起一次请求,select模型就会进行一次遍历扫描,从而导致性能低下。
Epool: 当用户发起请求,epool模型会直接进行处理,效率高效,并无连接限制。

Nginx 典型应用场景
**
02.Nginx Web快速入门 - 图1

2.Nginx快速安装

Nginx软件安装的方式有很多种

1.源码编译=>Nginx (1.版本随意 2.安装复杂 3.升级繁琐) 2.epel仓库=>Nginx (1.版本较低 2.安装简单 3.配置不易读) 3.官方仓库=>Nginx (1.版本较新 2.安装简单 3.配置易读,推荐)

1.安装Nginx软件所需依赖包

  1. [root@web ~]# yum install -y gcc gcc-c++ autoconf pcre pcre-devel make automake

2.配置nginx官方 yum源

  1. [root@web ~]# vim /etc/yum.repos.d/nginx.repo
  2. [nginx]
  3. name=nginx repo
  4. baseurl=http://nginx.org/packages/centos/7/$basearch/
  5. gpgcheck=0
  6. enabled=1

3.安装Nginx服务,启动并加入开机自启

  1. [root@web ~]# yum install nginx -y
  2. [root@web ~]# systemctl enable nginx
  3. [root@web ~]# systemctl start nginx

4.通过浏览器访问该服务器ip或url地址
02.Nginx Web快速入门 - 图2
5.检查Nginx软件版本以及编译参数

  1. [root@web ~]# nginx -v
  2. nginx version: nginx/1.14.0
  3. [root@web ~]# nginx -V

6.为了让大家更清晰的了解Nginx软件的全貌,可使用rpm -ql nginx查看整体的目录结构及对应的功能,如下表格整理了Nginx比较重要的配置文件
1.Nginx主配置文件

路径 类型 作用
/etc/nginx/nginx.conf 配置文件 nginx主配置文件
/etc/nginx/conf.d/default.conf 配置文件 默认网站配置文件

2.Nginx代理相关参数文件

路径 类型 作用
/etc/nginx/fastcgi_params 配置文件 Fastcgi代理配置文件
/etc/nginx/scgi_params 配置文件 scgi代理配置文件
/etc/nginx/uwsgi_params 配置文件 uwsgi代理配置文件

3.Nginx编码相关配置文件

路径 类型 作用
/etc/nginx/win-utf 配置文件 Nginx编码转换映射文件
/etc/nginx/koi-utf 配置文件 Nginx编码转换映射文件
/etc/nginx/koi-win 配置文件 Nginx编码转换映射文件
/etc/nginx/mime.types 配置文件 Content-Type与扩展名

4.Nginx管理相关命令

路径 类型 作用
/usr/sbin/nginx 命令 Nginx命令行管理终端工具
/usr/sbin/nginx-debug 命令 Nginx命令行与终端调试工具

4.Nginx日志相关目录与文件

路径 类型 作用
/var/log/nginx 目录 Nginx默认存放日志目录
/etc/logrotate.d/nginx 配置文件 Nginx默认的日志切割

3.Nginx默认配置

Nginx主配置文件/etc/nginx/nginx.conf是一个纯文本类型的文件,整个配置文件是以区块的形式组织的。一般,每个区块以一对大括号{}来表示开始与结束。
Nginx主配置文件整体分为三块进行学习,分别是CoreModule(核心模块),EventModule(事件驱动模块),HttpCoreModule(http内核模块)

CoreModule核心模块

  1. user www; #Nginx进程所使用的用户
  2. worker_processes 1; #Nginx运行的work进程数量(建议与CPU数量一致或auto)
  3. error_log /log/nginx/error.log #Nginx错误日志存放路径
  4. pid /var/run/nginx.pid #Nginx服务运行后产生的pid进程号

events事件模块

  1. events {
  2. worker_connections 25535; #每个worker进程支持的最大连接数
  3. use epoll; #事件驱动模型, epoll默认
  4. }

http内核模块

  1. http { #http层开始
  2. ...
  3. #使用Server配置网站, 每个Server{}代表一个网站(简称虚拟主机)
  4. 'server' {
  5. listen 80; #监听端口, 默认80
  6. server_name bgx.com; #提供的域名
  7. access_log access.log; #该网站的访问日志
  8. #控制网站访问路径
  9. 'location' / {
  10. root /usr/share/nginx/html; #存放网站源代码的位置
  11. index index.html index.htm; #默认返回网站的文件
  12. }
  13. }
  14. ...
  15. #第二个虚拟主机配置
  16. 'server' {
  17. ...
  18. }
  19. include /etc/nginx/conf.d/*.conf; #包含/etc/nginx/conf.d/目录下所有以.conf结尾的文件
  20. } #http层结束

http server location扩展了解项
http{}层下允许有多个Server{}层,一个Server{}层下又允许有多个Location
http{} 标签主要用来解决用户的请求与响应。
server{} 标签主要用来响应具体的某一个网站。
location{} 标签主要用于匹配网站具体URL路径。

4.Nginx网站配置

1.新增nginx配置文件

  1. [root@web01 conf.d]# cat /etc/nginx/conf.d/game.conf
  2. server {
  3. listen 80;
  4. server_name game.oldboy.com;
  5. location / {
  6. root /code;
  7. index index.html;
  8. }
  9. }

2.放置游戏源代码文件至nginx配置文件root指定的目录

  1. [root@web01 conf.d]# mkdir /code && cd /code
  2. [root@web01 code]# rz html5.zip
  3. [root@web01 code]# unzip html5.zip
  4. [root@web01 code]# ls
  5. ceshi game html5.zip img index.html readme.txt

3.检查nginx的语法是否存在错误

  1. [root@web01 code]# nginx -t
  2. nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
  3. nginx: configuration file /etc/nginx/nginx.conf test is successful

4.重载Nginx [reload|restart]

  1. [root@web01 code]# systemctl reload nginx

5.Nginx虚拟主机

通常在企业中可能会有很多业务系统,那么多套业务服务如何使用Nginx配置?
02.Nginx Web快速入门 - 图3
如果使用如上方式部署,则需要多台服务器配置Nginx,但如果使用虚拟主机方式,则在同一个Nginx上运行多套单独服务,这些服务是相互独立的。简单来说,看似多套业务系统,实则可以运行在一台Nginx服务上
02.Nginx Web快速入门 - 图4
Nginx配置虚拟主机有如下三种方式:
方式一、基于主机多IP方式
方式二、基于端口的配置方式
方式三、基于多个hosts名称方式(多域名方式)

1.基于多IP的虚拟主机配置实战
02.Nginx Web快速入门 - 图5
那么基于多IP的方式,有如下两种方式:
02.Nginx Web快速入门 - 图6
1.配置多网卡多IP的方式

  1. server {
  2. ...
  3. listen 10.0.0.10:80;
  4. ...
  5. }
  6. server {
  7. ...
  8. listen 10.0.0.11:80;
  9. ...
  10. }

1.配置单网卡多IP的方式

  1. #添加一个IP
  2. [root@web01 ~]# ip addr add 10.0.0.11/24 dev eth0
  3. # 虚拟机配置方案
  4. [root@web01 ~]# cat /etc/nginx/conf.d/addr1.conf
  5. server {
  6. ...
  7. listen 10.0.0.10:80;
  8. ...
  9. }
  10. [root@web01 ~]# cat /etc/nginx/conf.d/addr2.conf
  11. server {
  12. ...
  13. listen 10.0.0.11:80;
  14. ...
  15. }

2.基于端口虚拟主机配置实战
02.Nginx Web快速入门 - 图7
Nginx多端口虚拟主机方式,具体配置如下

  1. #仅修改listen监听端口即可, 但不能和系统端口出现冲突
  2. [root@web01 ~]# cat /etc/nginx/conf.d/port1.conf
  3. server {
  4. ...
  5. listen 80;
  6. ...
  7. }
  8. [root@web01 ~]# cat /etc/nginx/conf.d/port2.conf
  9. server {
  10. ...
  11. listen 81;
  12. ...
  13. }
  14. [root@web01 ~]# cat /etc/nginx/conf.d/port3.conf
  15. server {
  16. ...
  17. listen 82;
  18. ...
  19. }

3.基于host名称的虚拟主机方式配置实战
02.Nginx Web快速入门 - 图8
1.创建对应的web站点目录以及程序代码

  1. [root@web01 ~]# mkdir /soft/code/{server1,server2}
  2. [root@web01 ~]# echo "server1" > /code/server1/index.html
  3. [root@web01 ~]# echo "server2" > /code/server2/index.html

2.配置不同域名的虚拟主机

  1. [root@web02 ~]# cat /etc/nginx/conf.d/server1.conf
  2. server {
  3. listen 80;
  4. server_name 1.xuliangwei.com;
  5. root /code/server1;
  6. index index.html;
  7. ...
  8. }
  9. [root@web01 ~]# cat /etc/nginx/conf.d/server2.conf
  10. server {
  11. ...
  12. listen 80;
  13. server_name 2.xuliangwei.com;
  14. root /code/server2;
  15. index index.html;
  16. }

6.Nginx日志管理

Nginx有非常灵活的日志记录模式,每个级别的配置可以有各自独立的访问日志。日志格式通过log_format命令定义格式。
1.log_format定义日志格式语法

  1. # 配置语法: 包括: error.log access.log
  2. Syntax: log_format name [escape=default|json] string ...;
  3. Default: log_format combined "...";
  4. Context: http

2.默认Nginx定义语法格式如下

  1. log_format main '$remote_addr - $remote_user [$time_local] "$request" '
  2. '$status $body_bytes_sent "$http_referer" '
  3. '"$http_user_agent" "$http_x_forwarded_for"';

3.Nginx日志格式允许包含的内置变量

  1. $remote_addr # 记录客户端IP地址
  2. $remote_user # 记录客户端用户名
  3. $time_local # 记录通用的本地时间
  4. $time_iso8601 # 记录ISO8601标准格式下的本地时间
  5. $request # 记录请求的方法以及请求的http协议
  6. $status # 记录请求状态码(用于定位错误信息)
  7. $body_bytes_sent # 发送给客户端的资源字节数,不包括响应头的大小
  8. $bytes_sent # 发送给客户端的总字节数
  9. $msec # 日志写入时间。单位为秒,精度是毫秒。
  10. $http_referer # 记录从哪个页面链接访问过来的
  11. $http_user_agent # 记录客户端浏览器相关信息
  12. $http_x_forwarded_for #记录客户端IP地址
  13. $request_length # 请求的长度(包括请求行, 请求头和请求正文)。
  14. $request_time # 请求花费的时间,单位为秒,精度毫秒
  15. # 注:如果Nginx位于负载均衡器,nginx反向代理之后, web服务器无法直接获取到客 户端真实的IP地址。
  16. # $remote_addr获取的是反向代理的IP地址。 反向代理服务器在转发请求的http头信息中,
  17. # 增加X-Forwarded-For信息,用来记录客户端IP地址和客户端请求的服务器地址。

4.access_log日志配置语法

  1. Syntax: access_log path [format [buffer=size] [gzip[=level]] [flush=time] [if=condition]];
  2. access_log off;
  3. Default: access_log logs/access.log combined;
  4. Context: http, server, location, if in location, limit_except

5.Nginx Access日志配置实践

  1. server {
  2. listen 80;
  3. server_name code.oldboy.com;
  4. #将当前的server网站的访问日志记录至对应的目录,使用main格式
  5. access_log /var/log/nginx/code.oldboy.com.log main;
  6. location / {
  7. root /code;
  8. }
  9. #当有人请求改favicon.ico时,不记录日志
  10. location /favicon.ico {
  11. access_log off;
  12. return 200;
  13. }
  14. }

6.日志切割logrotate

  1. [root@nginx conf.d]# cat /etc/logrotate.d/nginx
  2. /var/log/nginx/*.log {
  3. daily # 每天切割日志
  4. missingok # 日志丢失忽略
  5. rotate 52 # 日志保留52天
  6. compress # 日志文件压缩
  7. delaycompress # 延迟压缩日志
  8. notifempty # 不切割空文件
  9. create 640 nginx adm # 日志文件权限
  10. sharedscripts
  11. postrotate # 切割日志执行的命令
  12. if [ -f /var/run/nginx.pid ]; then
  13. kill -USR1 `cat /var/run/nginx.pid`
  14. fi
  15. endscript
  16. }

7.日志切割后的效果

  1. [root@bgx ~]# ll /var/log/nginx/
  2. total 4044
  3. -rw-r----- 1 www adm 54438 Oct 12 03:28 access.log-20181012.gz
  4. -rw-r----- 1 www adm 28657 Oct 13 03:48 access.log-20181013.gz
  5. -rw-r----- 1 www adm 10135 Oct 12 03:28 error.log-20181130.gz
  6. -rw-r----- 1 www adm 7452 Oct 13 03:48 error.log-20181201.gz