项目部署(Nginx、反向代理、负载均衡)

项目部署



一、Nginx介绍及使用

1.1 什么是nginx?

Nginx是一款轻量级的 Web服务器 , 反向代理服务器 及 电子邮件代理服务器 。
优点:

  1. 占用内存少,并发能力强
  2. Nginx专为性能优化而开发, 在高连接并发的情况下,能够支持高达 50,000 个并发连接数的响应. 3. Nginx支持热部署, 可以在不间断服务的情况下,对软件版本进行升级

1.2 应用场景

  1. http服务器: Nginx是一个http服务可以独立提供http服务。可以做网页静态服务器。
  2. 虚拟主机: 可以实现在一台服务器虚拟出多个网站。例如个人网站使用的虚拟主机。
  3. 反向代理,负载均衡 : 当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群可以使用nginx做反向代理。并且多台服务器可以平均分担负载,不会因为某台服务器负载高宕机而某台服务器闲置的情况。

1.3 Nginx安装

下载nginx, 官方网站:http://nginx.org/en/download.html
我们使用的版本是1.17.8版本。
在这里插入图片描述
安装环境配置
1.因为Nginx是C语言编写的,所以需要配置C语言编译环境 (一定要在联网状态下安装)

需要安装gcc的环境。
执行命令: yum install gcc-c++

2.第三方的开发包, 在编译之前需要安装这些第三方包。

  • PCRE
    nginx的http模块使用pcre来解析正则表达式,所以需要在linux上安装pcre库

安装命令: yum install -y pcre pcre-devel

  • zlibnginx
    使用zlib对http包的内容进行gzip,所以需要在linux上安装zlib库。

安装命令: yum install -y zlib zlib-devel

  • openssl
    OpenSSL 是一个强大的安全套接字层密码库,nginx不仅支持http协议,还支持https,所以需要在linux安装
    openssl库。

安装命令: yum install -y openssl openssl-devel

安装Nginx 步骤

  1. 将Nginx的源码包上传到 Linux 的root目录下
    在这里插入图片描述

  2. 解压Nginx

tar -xvf nginx-1.17.8.tar
在这里插入图片描述

  1. 进入到解压之后的目录 nginx-1.17.8

cd nginx-1.17.8
在这里插入图片描述
1).创建一个临时目录 mkdir /var/temp/nginx/client -p
2).执行命令 configure,生成 Mikefile 文件
命令:./configure
–prefix=/usr/local/nginx
–pid-path=/var/run/nginx/nginx.pid
–lock-path=/var/lock/nginx.lock
–error-log-path=/var/log/nginx/error.log
–http-log-path=/var/log/nginx/access.log
–with-http_gzip_static_module
–http-client-body-temp-path=/var/temp/nginx/client
–http-proxy-temp-path=/var/temp/nginx/proxy
–http-fastcgi-temp-path=/var/temp/nginx/fastcgi
–http-uwsgi-temp-path=/var/temp/nginx/uwsgi
–http-scgi-temp-path=/var/temp/nginx/scgi
在这里插入图片描述
执行命令后, 生成了MakeFile文件
在这里插入图片描述
执行make命令,进行编译:make
安装:make install
在这里插入图片描述

3.启动并访问 Nginx
1)进入到nginx 安装目录

cd /usr/local/nginx/
在这里插入图片描述

2)进入到 sbin目录,执行 nginx 命令
在这里插入图片描述

./nginx 启动
./nginx -s stop 关闭
./nginx -s reload 重启
ps aux | grep nginx 查看进程

通过浏览器进行访问 ,默认端口 80 (注意:是否关闭防火墙。)
在这里插入图片描述

1.4 配置虚拟主机

虚拟主机指的是,在一台服务器中,我们使用Nginx,来配置多个网站.
如何区分不同的网站:

  1. 端口不同
  2. 域名不同

通过端口区分不同的虚拟主机
Nginx配置文件
1.Nginx配置文件的位置

cd /usr/local/nginx/conf
nginx.conf 就是Nginx的配置文件

2.Nginx核心配置文件说明

worker_processes  1; #work的进程数,默认为1
#配置 影响nginx服务器与用户的网络连接
events {
    worker_connections  1024; #单个work 最大并发连接数
}
# http块是配置最频繁的部分 可以嵌套多个server,配置代理,缓存,日志定义等绝大多数功能
http {
     # 引入mime类型定义文件
     include    mime.types;
     default_type application/octet-stream;
     sendfile    on;
     keepalive_timeout  65; # 超时时间
 
     #server 配置虚拟主机的相关参数 可以有多个,一个server就是一个虚拟主机
     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;
         }
    }
}

访问流程图
在这里插入图片描述

使用Notpad,连接Linux
使用notepad++来连接linux,好处是使用notepad++来编辑linux中文件的批量文字,会比直接在linux中操作方便快捷很多

  1. Notepad 插件中安装NppFTP
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  2. 配置nginx.conf
    1) 使用Notpad 在nginx.conf 中添加一个 新的server
    在这里插入图片描述

http {
     include    mime.types;
     default_type application/octet-stream;
     sendfile    on;
     #tcp_nopush   on;
     #keepalive_timeout 0;
     keepalive_timeout  65;
     #gzip on;
     server {
         listen    80;
         server_name localhost;
         location / {
             root  html;
             index index.html index.htm;
         }
     }
    # 配置新的server
     server {
         listen    81; # 修改端口
         server_name localhost;
         location / {
              root  html81; # 重新制定一个目录
              index index.html index.htm;
         }
     }
}

复制一份 html目录

cp -r html html81
在这里插入图片描述
html和html81做细微区分
在这里插入图片描述

重新加载配置文件

sbin/nginx -s reload
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
通过域名区分不同的虚拟主机
配置域名映射

  1. 本地测试可以修改hosts文件。修改window的hosts文件:(C:\Windows\System32\drivers\etc)
  • 可以配置域名和ip的映射关系,如果hosts文件中配置了域名和ip的对应关系,不需要走dns服务器。

配置一下nginx的映射
182.168.80.100 www.ng.com

在这里插入图片描述
在这里插入图片描述
配置nginx.conf

#通过域名区分虚拟主机
    server {
        listen 80;
        server_name www.taobao.com;
        location / {
            root taobao;
            index taobao.html;
        }
    }
    server {
        listen 80;
        server_name www.jd.com;
        location / {
            root jd;
            index jd.html;
    }
}

修改一下index.html 中,刷新

sbin/nginx -s reload

访问
在这里插入图片描述

1.5 反向代理

正向代理
比如我们国内访问谷歌,直接访问访问不到,我们可以通过一个正向代理服务器,先将请求发送到到代理服,代理服务器能够访问谷歌,这样由代理去谷歌取到返回数据,再返回给我们,这样我们就能访问谷歌了
在这里插入图片描述
Nginx实现反向代理
Nginx作为反向代理服务器安装在服务端,Nginx的功能就是把请求转发给后面的应用服务器
在这里插入图片描述
在这里插入图片描述

配置步骤

  • 第一步:简单的使用2个tomcat实例模拟两台http服务器,分别将tomcat的端口改为8080和8081
    在这里插入图片描述

  • 第二步:启动两个tomcat。

./bin/startup.sh 访问两个tomcat http://192.168.80.100:8080/ http://192.168.80.100:8081/

  • 第三步:反向代理服务器的配置
#反向代理配置
#upstream中的server是真正处理请求的应用服务器地址
upstream lagou1{
#用server定义HTTP地址
    server 192.168.80.100:8080;
}
 
server {
    listen    80;
    server_name www.lagou1.com;
    location / {
    # 利用 proxy_ pass可以将请求代理到upstream命名的HTTP服务
        proxy_pass http://lagou1;  #转发到的地址
        index index.html index.htm;
    }
}
 
upstream lagou2{
    #用server定义HTTP地址
    server 192.168.80.100:8081;
}
 
server {
    listen    80;
    server_name www.lagou2.com;
    location / {
        proxy_pass http://lagou2;
        index index.html index.htm;
    }
}
  • 第四步:nginx重新加载配置文件

nginx -s reload

  • 第五步:配置域名, 在hosts文件中添加域名和ip的映射关系

192.168.80.100 www.lagou1.com
192.168.80.100 www.lagou2.com

1.6 负载均衡

什么是负载均衡
当一个请求发送过来的时候,Nginx作为反向代理服务器,会根据请求找到后面的目标服务器去处理请求,这就是反向代理. 那么, 如果目标服务器有多台的话,找哪一个服务器去处理当前请求呢 ? 这个合理分配请求到服务器的过程就叫做负载均衡.
在这里插入图片描述
为什么用负载均衡
当系统面临大量用户访问,负载过高的时候,通常会使用增加服务器数量来进行横向扩展, 负载均衡主要是为了分担访问量,将请求合理分发给不同的服务器, 避免临时的网络堵塞
负载均衡策略
轮询

  • 默认策略, 每个请求按照时间顺序逐一分配到不同的服务器,如果某一个服务器下线,能自动剔除
  • 配置方式
    负载均衡
#配置负载均衡
upstream lagouedu{ 
 
	# 用server定义 HTTP地址 
	server 192.168.80.100:8080; 
	server 192.168.80.100:8081; 
}
 
server { 
	listen 80; 
 
	server_name www.lagouedu.com;
 
	location / {
		# 利用 proxy_ pass可以将请求代理到upstream命名的HTTP服务
		proxy_pass http://lagouedu;
		index index.html;
	}
}

weight

可以根据服务器的实际情况调整服务器权重。权重越高分配的请求越多,权重越低,请求越少。默认是都是1.

#负载均衡
upstream lagouServer{
# 用server定义 HTTP地址
server 192.168.52.100:8080 weight=1;
server 192.168.52.100:8081 weight=10;
}

2.发布web项目

1.项目打包

在这里插入图片描述

2.发布web项目到tomcat下

复制到linux中tomcat1 和tomcat2的webapps目录下
在这里插入图片描述
启动tomcat1 tomcat2

[root@centos7-1 bin]# ./startup.sh && tail -100f …/logs/catalina.out

3.配置nginx负载均衡

upstream vis{ 
    # 用server定义 HTTP地址 
    server 192.168.80.100:8080; 
    server 192.168.80.100:8081; 
}
    
server { 
    listen 80; 
    server_name www.vis.com;
    location / {
        # 利用 proxy_ pass可以将请求代理到upstream命名的HTTP服务
        proxy_pass http://vis;
        index login.html ;
    }
}

猜你喜欢

转载自blog.csdn.net/weixin_47134119/article/details/112253597