Nginx实现负载均衡和文件服务器

为热爱编程的你点赞!
学习SpringBoot实战课程 https://edu.csdn.net/course/detail/31433
学习SpringCloud入门课程 https://edu.csdn.net/course/detail/31451


概述

本文将介绍目前非常流行的Nginx服务器,我们将了解反向代理、负载均衡等概念,然后掌握Nginx的安装、配置,可以使用Nginx+Vsftp配置文件上传服务器,以及实现负载均衡的配置。

1、Nginx简介

Nginx是一个轻量级、高性能、稳定性高、并发性强的HTTP和反向代理服务器。目前在互联网企业中应用非常广泛,如:百度、京东、新浪、网易、腾讯、淘宝等。

1.1 Nginx能做什么

Nginx的作用主要有:

  • http服务器

    Nginx一般用于部署静态资源,和部署动态资源的服务器(如:Tomcat) 分开部署,实现动静分离,达到服务器性能的最大化。

  • 反向代理

    代理后台服务器,通过配置实现灵活的路由

  • 负载均衡

    将大量的用户请求,均衡的分配给多台服务器,提高系统的负载能力

1.2 正向/反向代理

Nginx的一个重要作用是反向代理,那么我们首先需要搞清楚什么是反向代理。

在这里插入图片描述

正向代理和反向代理的区别是:

  • 正向代理,代理的是客户端

    如:用户不能直接访问企业的内部服务器,可以通过VPN代理服务器间接访问,这就是一种正向代理

  • 反向代理,代理的是服务器

    如:淘宝的业务部署到不同的服务器上,如商品服务器、商户服务器、订单服务器等,用户访问淘宝时,通过Nginx将请求转发到不同的后台服务器上

2、Nginx的安装

2.1 Linux中安装Nginx

1) 安装依赖库

yum install -y gcc-c++
yum install -y pcre pcre-devel
yum install -y zlib zlib-devel
yum install -y openssl openssl-devel

2) 下载Nginx

cd /usr/local
wget -c https://nginx.org/download/nginx-1.12.0.tar.gz

3) 解压

tar -zxvf nginx-1.12.0.tar.gz

4)进行默认配置

cd nginx-1.12.0
./configure

5)编译安装

make
make install

6)启动nginx

编译安装后,会出现nginx目录

cd /usr/local/nginx/sbin/
./nginx 

其他命令:

停止
./nginx -s stop
退出
./nginx -s quit
重启
./nginx -s reload

7) 打开80端口

firewall-cmd --zone=public --add-port=80/tcp --permanent 

打开浏览器,输入IP地址,出现Nginx页面

在这里插入图片描述

2.2 Windows中安装Nginx

1)去官网下载Nginx

http://nginx.org/en/download.html

2)解压,双击nginx.exe就可以了

在这里插入图片描述

3、Nginx+Vsftp搭建文件服务器

Nginx作为http服务器部署静态资源的性能非常高,Linux中的Vsftp组件可以实现文件的传输,Nginx+Vsftp可以组合搭建高性能的文件服务器,实现项目文件上传的功能。

3.1 安装vsftp

1) 安装vsftp组件

yum -y install vsftpd

2) 添加ftp用户

useradd ftpuser

登录后默认的路径为 /home/ftpuser.

3) 给ftp用户添加密码

passwd ftpuser

4) 修改配置

配置文件在/etc/vsftpd/vsftpd.conf

vi /etc/vsftpd/vsftpd.conf

修改配置

在这里插入图片描述

关闭匿名访问

在这里插入图片描述

添加端口范围

在这里插入图片描述

5) 重启vsftp

service vsftpd restart

6) 设置开机启动

chkconfig vsftpd on

7) 修改用户权限

chown ftpuser /home/ftpuser
chmod 777 -R /home/ftpuser

3.2 Nginx配置Vsftp

1) 新建目录用于保存图片

cd /home/ftpuser/
mkdir www
cd www
mkdir images
cd images
pwd
/home/ftpuser/www/images

2) 配置Nginx

nginx的配置文件是 nginx/conf/nginx.conf

在server中添加location

location /images {
	root  /home/ftpuser/www/;
	autoindex on;
}  

3) 重启nginx

./nginx -s reload

在浏览器输入 http://服务器地址/images , 可以看到上传目录下的文件列表

在这里插入图片描述

4、Nginx负载均衡

4.1 负载均衡概念

每台服务器处理请求数都有上限,超过这个上限就可能挂掉,那么多部署几台服务器就可以解决这个问题吗?

也不一定,假设所有请求都打到一台服务器上,还是会挂掉。

负载均衡(Load balancing),是一种计算机技术,能将用户请求按一定的负载均衡算法,分配给集群中的每一台服务器上,从而避免单台服务器过载,也提高了服务器集群处理请求的响应速度,达到服务器资源的优化配置。

在这里插入图片描述

负载均衡可以通过客户端、服务器端和硬件实现,Nginx属于服务器端负载均衡技术。

4.2 负载均衡配置

1) 服务器设置

为了测试方便起见,可以在一台电脑上启动几个SpringBoot项目,以端口区别,模拟多台服务器

RestController
public class HelloController
{
    @GetMapping("/hello")
    public String hello(){
        return "Hello 8081";
    }
}

2) 修改Nginx配置

在http中添加upstream,配置服务器列表,myservers是列表名称,内部每个server后面是服务器的IP和端口

upstream myservers { 
	server 192.168.0.113:8081;
	server 192.168.0.113:8082;
	server 192.168.0.113:8083;
}

添加server,配置代理将请求发送给myservers处理

server {
        listen       8088;
        server_name  localhost;
        charset utf-8;
        location / {
			proxy_pass http://myservers;
        }
}

3) 重启Nginx

./nginx -s reload

4) 测试

在浏览器测试8088端口访问hello接口时,发现接口的调用是轮询式的。

每个服务器的处理能力不同,可以配置权重weight,让能力强的服务器处理更多请求

upstream myservers { 
	server 192.168.0.113:8081 weight=1;
	server 192.168.0.113:8082 weight=2;
	server 192.168.0.113:8083 weight=1;
}

结束

以上就是Nginx的基本使用了,如果你感觉有用,那就点个赞吧,有问题也可以一起交流。


大家如果需要学习其他Java知识点,戳这里 超详细的Java知识点汇总

猜你喜欢

转载自blog.csdn.net/u013343114/article/details/112170264
今日推荐