一篇文章带你了解轻量级Web服务器——Nginx简单入门

一篇文章带你了解轻量级Web服务器——Nginx简单入门

Nginx是一款轻量级的Web服务器/反向代理服务器及电子邮件代理服务器

在本篇中我们会简单介绍Nginx的特点,安装,相关指令使用以及配置信息和具体应用等

本篇内容属于《瑞吉外卖》的知识科普部分,有兴趣可以查看一下《瑞吉外卖》的相关文章内容

Nginx概述

我们先来对Nginx做一个的简单的了解

Nginx介绍

Nginx是一款轻量级的Web服务器/反向代理服务器及电子邮件代理服务器

本身具有占用内存少,并发能力强等特点,其并发能力在同类型的网页服务器中表现较好,包括百度,京东等众多服务器都是采用Nginx

Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点开发的,第一个公开版本0.1.0发布于2004年10月4日。

下面附上官方:nginx news

Nginx下载与安装

我们的Nginx通常使用在Linux服务器系统上,我们这里使用虚拟机来进行操作:

  1. 安装依赖包
# 我们首先来下载一些关于Nginx安装的依赖包
yum -y install gcc pcre-devel zlib-devel openssl oepnssl-devel
  1. 下载Nginx安装包
# 我们借助wget网上下载插件来实现
yum install wget

# 我们使用wget下载安装包
wget //nginx.org/download/nginx-1.16.1.tar.gz
  1. 解压安装包
# 解压安装包在当前文件夹root
tar -zxvf nginx-1.16.1.tar.gz
  1. 跳转页面,进入内部
# 跳转页面
cd nginx-1.16.1
  1. 安装Nginx在usr目录下
# 创建文件夹
mkdir /usr/local/nginx

# 安装
./configure --prefix=/usr/local/nginx
  1. 安装
# 安装
make && make install

至此我们的Nginx安装完成

Nginx目录介绍

在安装完Nginx后,我们可以到相应文件下查看,可以看到主要分为四个文件包:

  • conf:存放配置文件
  • html:存放静态资源
  • logs:存放日志信息
  • sbin:存放二进制文件

其中我们主要使用的两个文件是:

  • conf/nginx.conf:用于修改nginx配置信息
  • sbin/nginx:用于启动停止nginx服务

这里我们介绍一个Linux插件,可以详细查看该目录下所有的文件内容:

# Tree插件(需要先下载yum install tree)
tree

我们可以看到其文件逻辑结构:

Nginx命令

下面我们将着重介绍几个Nginx常用命令

Nginx查看版本号

首先我们需要来到sbin目录下:

# 跳转页面
cd /usr/local/nignx/sbin

我们使用查看命令:

# 查看版本号
./nginx -v

Nginx检查正确性

首先我们需要来到sbin目录下:

# 跳转页面
cd /usr/local/nignx/sbin

我们使用检查命令:

# 检查版本以及配置信息
./nginx -t

Nginx启动与停止

首先我们需要来到sbin目录下:

# 跳转页面
cd /usr/local/nignx/sbin

我们使用相关命令:

# 启动命令
./nginx

# 停止命令
./nginx -s stop

# 重启命令
./nginx -s reload

# 查看nginx进程
ps -ef|grep nginx

Nginx配置文件

下面我们来简单介绍一下配置文件

Nginx配置文件整体介绍

我们通常将其配置文件分为三部分:

  • 全局块:和Nginx运行相关的全局配置
  • events块:和网络连接相关的配置
  • http块:代理,缓存,日志记录,虚拟主机配置

其中http块还分为两部分:

  • http全局快
  • server块

其中server还分为两部分:

  • Server全局快
  • location块

我们需要注意的是:

  • http块中可以配置多个Server块,每个Server块中可以配置多个location块

我们可以到具体配置文件中去查看相关配置:

# 查看配置文件
vim /usr/local/nignx/conf/nignx.conf

# 以下为配置文件内容(已将#注释部分删除)

# 第一部分是全局块

worker_processes  1; # 这里表示可以同时有多少个进程

# 第二部分是events块

events {
    worker_connections  1024; # 单个工作进程可以允许同时建立外部连接的数量,数字越大,能同时处理的连接越多
}

# 第三部分是http块,里面包含了代理,缓存,日志记录,虚拟主机配置等相关信息,我们后续会详细介绍

http {
	
	# 3.1 http全局块
	
    include       mime.types;
    default_type  application/octet-stream;
    
    sendfile        on;

    keepalive_timeout  65;

	# 3.2 Server块

    server {
    
    	# 3.2.1 Server全局块
    
        listen       80; 
        server_name  localhost; 

		# 3.2.2 location块

        location / {
            root   html; 
            index  index.html index.htm; 
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
        
}

Nginx具体应用

Nginx具有三方面应用,下面我们将一一讲解

Nginx部署动态资源

Nginx可以作为静态web服务器来部署静态资源。

静态资源指在服务端真实存在并且能够直接展示的一些文件,比如常见的htm页面、Css文件、 js文件、 图片、视频等资源。

我们可以直接将静态资源放置在Nginx的html文件夹下即可完成部署,同时Nginx处理静态资源的能力甚至相比于Tomcat来说更加高效

那么Nginx为什么能够自动配置静态资源呢?

# 主要依赖于我们的conf配置文件中的http块中的Server块

	# Server块
	
    server {
    
    	# 3.2.1 Server全局块
    
        listen       80; # 表示监听端口(即我们访问网页的端口号,本机查询为192.168.44.128:80)
        server_name  localhost; # 端口名称(无所谓命名,一般是我们的域名)

		# 3.2.2 location块

        location / {
            root   html; # 静态资源来源(设置在html文件夹下,所以我们查找静态资源会在html文件夹下查找)
            index  index.html index.htm; # 默认主页,即访问192.168.44.128:80时出现的页面
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
        
	}

Nginx进行反向代理

在接触反向代理之前我们先来讲解正向代理:

  • 正向代理是一个位于客户端和原始服务器(origin server)之间的服务器
  • 客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。

其正向代理的主要功能:

  • 正向代理的典型用途是为在防火墙内的局域网客户端提供访问internet的途径。

其正向代理的主要特点:

  • 正向代理一般是在客户端设置代理服务器,通过代理服务器转发请求,最终访问到目标服务器。

正向代理图:

然后我们再来介绍反向代理:

  • 反向代理也是是一个位于客户端和原始服务器(origin server)之间的服务器
  • 但是对于用户而言,反向代理服务器就相当于目标服务器,即用于直接访问反向代理服务器就可以获得目标服务器的资源
  • 用户不需要知道目标服务器的地址,也无需在用户端做任何事顶,反向代理服务器会将用户的请求转发给目标服务器并给出反馈

其反向代理的主要功能:

  • 官方可能拥有很多资源的入口,反向代理服务器将作为统一的入口用来管理服务器
  • 官方的服务器大部分都在内网里,我们的正常访问是无法访问成功的,因此需要借助反向代理服务器来进行访问

其反向代理的主要特点:

  • 反向代理一般是在服务端设置代理服务器,客户端通过代理服务器转发请求,最终访问到目标服务器。

反向代理图:

最后我们简单介绍一下如何配置反向代理:

# 我们同样来修改配置文件
vim /usr/local/nignx/conf/nignx.conf

# 进入后设置server块

	# Server块
	
    server {
    
    	# 3.2.1 Server全局块
    
        listen       82; # 表示监听端口(即我们访问网页的端口号,本机查询为192.168.44.128:82)
        server_name  localhost; # 端口名称(无所谓命名,一般是我们的域名)

		# 3.2.2 location块

        location / {
            proxy_pass //192.168.44.129:8080; #我们将该请求转移到//192.168.44.129:8080指定服务中
        }
        
	}

Nginx实现负载均衡

我们首先来简单介绍一下负载均衡:

  • 早期网站流量和业务功能相对简单,单台服务器可以满足基本需求
  • 后期业务量逐渐增大,我们就需要采用多台服务器组成应用集群,进行性能的水平拓展以及避免单点故障出现

我们来简单解释两个概念:

  • 负载均衡器:将用户请求根据对应的负载均衡算法分发到应用集群中的一台服务器进行处理
  • 应用集群:将一个应用部署到多台机器上,形成应用集群,接受负载均衡器分发的请求,进行业务处理并做出反馈

负载均衡图:

最后我们简单介绍一下如何配置负载均衡:

# 我们同样来修改配置文件
vim /usr/local/nignx/conf/nignx.conf

# 首先我们需要在http中配置应用集群

http {
	
	# 3.1 http全局块(配置应用集群)
	
    include       mime.types;
    default_type  application/octet-stream;
    
    sendfile        on;

    keepalive_timeout  65;
    
    upstream targetserver{ # upstream表示定义应用集群,targetserver为名称
    	server 192.168.44.129:8080; # server表示配置其转发服务器端口,192.168.44.129:8080为自己配置即可
    	server 192.168.44.129:8081; # server表示配置其转发服务器端口,192.168.44.129:8081为自己配置即可
    }

	# 3.2 Server块

    server {
    
    	# 3.2.1 Server全局块
    
        listen       8080; # 我们访问时采用192.168.44.128
        server_name  localhost;

		# 3.2.2 location块

        location / {
            proxy_pass targetserver; #我们将该请求转移到targetserver应用集群中去
        }
        
}

结束语

该篇内容到这里就结束了,希望能为你带来帮助~

附录

该文章属于学习内容,具体参考B站黑马程序员的Java项目实战《瑞吉外卖》

这里附上视频链接:项目优化Day2-08-Nginx课程内容介绍&概述_哔哩哔哩_bilibili