Nginx 入门
1. 基本概念
Nginx 是一款轻量级的 Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,在 BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上 Nginx 的并发能力在同类型的网页服务器中表现较好。以上内容来自百度百科,由百度百科给出的介绍我们不难发现,Nginx 其实是一个反向代理服务器,作用其实有很多,最突出的是其负载均衡能力,Nginx 的并发能力在同类型的网页服务器中是较为出色的。
2. 安装
首先到官网下载 Nginx 的解压包
下载完成后通过 rz 命令将其上传至 Linux,然后进行解压
tar -zxvf nginx-1.21.6.tar.gz
解压完成后进入解压后的目录,在该目录下有一个名为configure
的脚本,通过执行该脚本即可安装 Nginx
./configure
正常情况下终端会提示缺少一些环境
它提示缺少什么,我们就安装什么就行。这里的提示信息说的是找不到C语言编译器,所以来安装一下C语言的编译器
yum install -y gcc
安装完成后,重新执行configure
脚本,该脚本还可以携带参数,通过指定 prefix 参数即可将 Nginx 安装在指定的目录下。不出意外,此时终端会再一次提醒你缺少相应的依赖
./configure --prefix=/usr/local/nginx
同样的,安装上就好了
yum install -y pcre pcre-devel
安装完成后再次执行configure
脚本,终端还是提示缺少相应的依赖
把它也安装上
yum install -y zlib zlib-devel
再一次来执行configure
脚本,这应该是我们第四次执行该脚本了,此时应该是能够安装成功了
接下来执行 make 指令
make
该指令是 Linux 提供的一个编译指令,通过 make 指令即可对安装后的 Nginx 进行编译操作,编译完成后进行安装操作
make install
此时我们可以来到/usr/local
目录下查看 nginx 是否安装成功
可以看到在该目录下多出了一个nginx
的目录,这就是安装好的 nginx 了,我们进入到 nginx 的 sbin 目录下,通过执行 nginx 脚本即可启动 nginx
cd nginx/sbin ./nginx
此时在浏览器上访问 http:// + Linux 的 ip 地址(ip 地址可通过命令 ifconfig
查看,ens33对应)
这个页面说明 nginx 启动成功!如果你访问不到,可以先看看防火墙是不是关闭状态,如果不是,那就把防火墙关闭再访问试试
# 查看防火墙状态 systemctl status firewalld # 关闭防火墙 systemctl stop firewalld
若是想停止 nginx,则执行./nginx -s quit
或./nginx -s stop
指令,这两种方式的结果都是一样的,都会停止 nginx,但过程不同,./nginx -s stop
是直接停止 nginx,而./nginx -s quit
与之相比要柔和一些,它会等待已经接收的连接请求处理完毕后再结束。
一般情况下,我们都会制作一个 nginx 脚本服务,然后使用脚本来启动它,这样的好处是不用来到 nginx 的 sbin 目录执行 nginx 脚本了,当我们需要启动 nginx 时,在任何位置都可以启动。首先创建脚本服务
touch /usr/lib/systemd/system/nginx.service
通过vi /usr/lib/systemd/system/nginx.service
命令在该文件中填入如下内容(需要注意的是如果你的 nginx 不是安装在/usr/local/nginx
下,则需要相应地修改下面的路径)
[Unit] Description=nginx - web server After=network.target remote-fs.target nss-lookup.target [Service] Type=forking PIDFile=/usr/local/nginx/logs/nginx.pid ExecStartPre=/usr/local/nginx/sbin/nginx -t -c /usr/local/nginx/conf/nginx.conf ExecStart=/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf ExecReload=/usr/local/nginx/sbin/nginx -s reload ExecStop=/usr/local/nginx/sbin/nginx -s stop ExecQuit=/usr/local/nginx/sbin/nginx -s quit PrivateTmp=true [Install] wantedBy=multi-user.target
将其写入文件后,需要重新加载一下系统服务
systemctl daemon-reload
现在尝试使用系统服务启动 nginx
systemctl start nginx.service # 也可以简写成 systemctl start nginx
查看服务是否启动
systemctl status nginx
也可以通过查看进程的方式验证
ps -ef | grep nginx
3. 目录结构
1. conf
conf 为配置文件目录,里面存放的都是 nginx 的配置信息,nginx.conf 为 nginx 的主要配置文件,其它配置文件都是被该文件引用的
2. html
html 目录存放的是静态文件,比如访问 nginx 时出现的Welcome to nginx!
页面就是该目录下的 index.html 文件
3. logs
logs 目录存放的是日志文件,access.log 是访问日志,当通过 nginx 访问某个资源时就会在该文件中被记录;error.log 是错误日志,当然就是用来记录一些错误操作了,比如404
4. sbin
该目录下只有一个 nginx 主进程文件,用来启动 nginx。
4. 基础配置
在 nginx 中,最为关键的就属 conf 目录下的 nginx.conf 配置文件了,nginx 的所有功能都需要在该配置文件中进行配置,nginx.conf 文件中的内容较多,其中大部门配置都被注释了,我们将这些被注释的内容先删掉,看看 nginx 究竟配置了些什么
#其中位于第一行的配置 worker_processes 1 表示开始一个业务进程,在 nginx 中的工作模式是这样的, #nginx 会开启一个 master 进程和多个 worker 进程,这里的 worker 进程就是业务进程,master 进程并不处理业务, #而是负责调度 worker 进程,业务由 worker 进程负责处理。所以这里配置的就是 worker 进程数了 worker_processes 1; events { worker_connections 1024;#表示每个 worker 进程可以创建的连接数 } http { include mime.types;#表示引入了一个名为 mime.types 的外部配置文件 default_type application/octet-stream;#表示的是如果在 mime.types 文件中没有找到对应的映射,则统一返回给浏览器 application/octet-stream 类型,这是一个兜底的方案 sendfile on;#指的是数据零拷贝,当你通过 nginx 下载一个资源时,因为 nginx 始终还是个运行在操作系统中的软件,所以网络请求一定是先由操作系统接收, #操作系统再将请求交给 nginx,nginx 再从磁盘上获取到用户请求的资源,先将其读取到 nginx 的缓存中,再将其复制到操作系统的缓存,最后由操作系统交给客户端。 #以上是不开启数据零拷贝的情况,如果开启了数据零拷贝,则 nginx 将资源赋值给操作系统的这一步骤会被省略,操作系统将直接从磁盘上读取资源并交给客户端,这就是该项配置的作用 keepalive_timeout 65;#指的是保持连接的超时时间 #server 表示 nginx 中的一个主机,在 nginx 中可以配置多个主机,每个主机相当于是一个独立的站点,主机之间相互并不影响 server { listen 80;#表示监听80端口 server_name localhost;#表示当前主机的主机名 location / {#表示匹配请求的URI资源,当匹配上了资源后,就会进入 location 配置块 root html;#指的是资源目录,此时的资源将从 nginx 中的 html 目录中寻找 index index.html index.htm; } error_page 500 502 503 504 /50x.html;#表示当产生这几个状态码的错误时,将访问 /50x.html 资源 location = /50x.html { root html; } } }
mime.types 的作用
types { text/html html htm shtml; text/css css; text/xml xml; image/gif gif; image/jpeg jpeg jpg; application/javascript js; application/atom+xml atom; application/rss+xml rss; ...... }
这里截取了一部分,但能够看出这似乎是一个映射表,其实它是用来告诉浏览器返回的资源类型的,不知道大家有没有注意过,当你在浏览器上访问一张图片时,浏览器会直接显示图片,而当你访问的是一个 .exe 可执行文件时,浏览器又会进行下载。那么浏览器是如何知道什么资源需要显示,而什么资源又需要下载呢?其实,浏览器靠的是请求头中的资源类型来辨别的,我们来访问一张百度的logo图片
再来访问一个可执行文件
发现区别了吗,它们的 Content-Type 值是不同的,浏览器正是通过这些值才能够对不同的资源做出不同的处理。回到 nginx中 的 mime.types 文件,它是用来对资源做一个对应的,举个例子,如果文件是html、htm、shtml,那么 nginx 会统一返回Content-Type:text/html
给浏览器;而如果文件是 jpeg、jpg,那么 nginx 会统一返回Content-Type:image/jpeg
给浏览器,这个告知资源类型的过程是由该文件完成的。事实上,互联网中的文件类型非常多,这个文件不可能全部都能例举到,如果有没映射的类型,你当然可以手动将映射添加到 mime.types 中,比如
type{ ...... video/mp4 mp4 mp7 mp8; ...... }
通过这段配置,如果文件类型为 mp4、mp7、mp8,nginx 将统一返回给浏览器video/mp4
类型
在前面我们就介绍到了 server_name,它表示的是当前主机的主机名,也就是说,只有当请求匹配到了该主机名,对应的主机配置才会生效,举一个例子,在 nginx.conf 中配置两个主机
http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; server { listen 80; server_name www.test1.com; location / { root /mysite/test1; index index.html index.htm; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } server { listen 80; server_name www.test2.com; location / { root /mysite/test2; index index.html index.htm; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } }
在这段配置中一共配置了两个主机,这两个主机分别指向/mysite
目录下的两个资源,所以先来创建这两个资源,在 Linux 根目录/
下创建mysite
目录,并在mysite
目录下分别创建 test1 和 test2 目录,这两个目录下分别有一个 index.html 文件
#详细步骤 cd / mkdir mysite cd mysite mkdir test1 mkdir test2 cd test1 vi index.html i 复制 <!DOCTYPE html> <html> <head> <title>test1</title> </head> <body> <h1>test1 page</h1> </body> </html> 点击Esc :wq! cp index.html ../test2 cd ../test2 vi index.html i 将test1修改为test2 点击Esc :wq! cd .. ll
接着在 Windows 的 hosts 文件中配置一下域名映射
虚拟机ip www.test1.com 虚拟机ip www.test2.com
现在试着访问一下这两个站点,首先是www.test1.com
其次是www.test2.com
而事实上,对于监听相同端口的不同域名,如果它们获取的资源需要是一样的,那么它们可以配置在一个 server 块中
server { listen 80; server_name www.test1.com; server_name www.test2.com; #也可以将域名配置写在一个 server_name 上:server_name www.test1.com; www.test2.com; location / { root /mysite/test1; index index.html index.htm; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } }
此时访问www.test1.com
和www.test2.com
都将显示的是test1 page!