负载均衡种类

第一种:通过硬件负载解决,常见的有NetScaler、F5、Radware和Array等商用的负载均衡器,价格比较昂贵

第二种:通过软件负载解决,常见的软件有LVS、Nginx、apache等,它们是基于Linux系统并且开源的负载均衡策略.

nginx简介

Nginx是一款高性能的http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。由俄罗斯的程序设计师Igor Sysoev所开发,官方测试nginx能够支支撑5万并发链接,并且cpu、内存等资源消耗却非常低,运行非常稳定。

nginx应用场景

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

环境配置

操作系统:Centos Linux 7.6

nginx版本:nginx-1.16.1

服务器配置

服务器1:106.53.73.200 作为nginx负载服务(tomcat服务1)

服务器2:182.254.184.102  (tomcat服务2)

结构图

安装部署

下载好nginx安装包:wget http://nginx.org/download/nginx-1.16.1.tar.gz

1.安装nginx(服务器1)

1)首先安装好编译环境

 [root@VM_0_10_centos tmp]# yum -y install gcc gcc-c++ pcre pcre-devel zlib zlib-devel openssl openssl-devel

2)解压nginx

 [root@VM_0_10_centos tmp]# tar -zxf nginx-1.16.1.tar.gz

切换到解压目录

3)编译安装

首先创建nginx的临时文件,存放在/var/tmp/nginx

 [root@VM_0_10_centos nginx-1.16.1]# mkdir -p /var/tmp/nginx

执行命令

./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/tmp/nginx/client \
--http-proxy-temp-path=/var/tmp/nginx/proxy \
--http-fastcgi-temp-path=/var/tmp/nginx/fastcgi \
--http-uwsgi-temp-path=/var/tmp/nginx/uwsgi \
--http-scgi-temp-path=/var/tmp/nginx/scgi \
--with-http_stub_status_module \
--with-http_ssl_module \
--with-http_realip_module

出现如下图即成功

编译源码,安装nginx

 [root@VM_0_10_centos nginx-1.16.1]# make
[root@VM_0_10_centos nginx-1.16.1]# make install

安装完成,查看安装目录

4)启动nginx服务

 [root@VM_0_10_centos nginx]# cd sbin/
[root@VM_0_10_centos sbin]# ./nginx -c /usr/local/nginx/conf/nginx.conf

查看nginx进程是否启动

 [root@VM_0_10_centos sbin]# ps -aux | grep nginx

注意:其中master为主进程worker为工作进程

5)退出nginx

 [root@VM_0_10_centos sbin]# ./nginx -s quit

6)重启nginx

 [root@VM_0_10_centos sbin]# pwd
/usr/local/nginx/sbin
[root@VM_0_10_centos sbin]# ./nginx -s reload

7)测试nginx

在浏览器上通过ip访问:http://localhost,出现如下界面即成功

2.安装tomcat服务(服务器1,服务器2)

下载tomcat:https://tomcat.apache.org/

wget下载: wget http://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-8/v8.5.45/bin/apache-tomcat-8.5.45.tar.gz

我选择的是tomcat8版本

1)解压到指定目录

 [root@VM_0_10_centos tmp]# tar -zxf apache-tomcat-8.5.45.tar.gz -C /usr/local/

tomcat依赖于jdk,在安装tomcat服务之前先配置jdk的环境,可以参考我之前的jdk安装配置文章,这里不作介绍

2)配置tomcat服务

修改tomcat端口

 [root@VM_0_10_centos tmp]# cd /usr/local/apache-tomcat-8.5.45/conf
[root@VM_0_10_centos conf]# pwd
/usr/local/apache-tomcat-8.5.45/conf
[root@VM_0_10_centos conf]# vi server.xml

将默认的启动端口8080修改为8888端口

修改之后保存退出

3)启动tomcat服务

进入tomcat的bin目录,启动startup.sh启动脚本

 [root@VM_0_10_centos bin]# pwd
/usr/local/apache-tomcat-8.5.45/bin
[root@VM_0_10_centos bin]# ./startup.sh

查看是否开启成功

4)测试是否开启服务

通过浏览器访问http://ip:端口号。如下图所示则成功 

5)编写测试负载的index.html文件

创建test目录存放测试页面

服务器1:

[root@VM_0_10_centos webapps]# pwd
/usr/local/apache-tomcat-8.5.45/webapps/

[root@VM_0_10_centos webapps]# mkdir -p test
  [root@VM_0_10_centos webapps]# ls test/
  index.html

[root@VM_0_10_centos webapps]# vi test/index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<title>106.53.73.200</title>
</head>
<body>
<h1>server1:106.53.73.200</h1>
</body>
</html>

服务器2:

[root@VM_0_10_centos webapps]# pwd
/usr/local/apache-tomcat-8.5./webapps/
[root@VM_0_10_centos webapps]# mkdir -p test
[root@VM_0_10_centos webapps]# ls test/
index.html
[root@VM_0_10_centos webapps]# vi test/index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<title>182.254.184.102</title>
</head>
<body>
<h1>server2:182.254.184.102</h1>
</body>
</html>

通过http://ip:port/项目名/测试页面访问

至此tomcat安装完成

3.配置nginx负载(服务器1)

1)修改配置文件nginx.conf

[root@VM_0_10_centos ~]# cd /usr/local/nginx/conf/
[root@VM_0_10_centos conf]# vi nginx.conf

配置负载均衡,配置完保存并退出

 #20190827添加
upstream testTomcat{
#设置分权,权重越高优先访问
server 106.53.73.200: weight=;
server 182.254.184.102: weight=;
} server {
listen ;
server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; #所有请求都在这里去找分配
location / {
#root html;
index index.html index.htm;
#使用test分配规则,即刚刚自定义添加的upstream节点
proxy_pass http://testTomcat/test/;
}

重新启动nginx服务

 [root@VM_0_10_centos conf]# /usr/local/nginx/sbin/nginx -s reload

2)测试负载均衡

通过浏览器访问负载ip,出现下图即负载成功

Linux搭建nginx负载均衡(两台服务器之间)的更多相关文章

  1. Nginx系列篇二:linux搭建Nginx负载均衡

    建议先搭建好Nginx环境 可阅读--->Linux中搭建Nginx 1.准备好三台服务器[标配] 一.nginx负载均衡服务器:192.168.102.110,配置好Nginx 二.tomca ...

  2. Net分布式系统之二:CentOS系统搭建Nginx负载均衡

    一.关于CentOS系统介绍 CentOS(Community Enterprise Operating System,中文意思是:社区企业操作系统)是Linux发行版之一,它是来自于Red Hat ...

  3. Nginx系列一:正向代理和反向代理、Nginx工作原理、Nginx常用命令和升级、搭建Nginx负载均衡

    转自https://www.cnblogs.com/leeSmall/p/9351343.html 仅供个人学习 一.什么是正向代理.什么是反向代理 1. 正向代理,意思是一个位于客户端和原始服务器( ...

  4. docker 搭建 nginx负载均衡

    本文描述如何在一台机器上搭建nginx负载均衡,我将会启动3个nginx的docker,分别是1台前置nginx负责分发,后面2台负责处理请求. 首先我切换到/usr/local/docker/文件夹 ...

  5. Linux之nginx负载均衡

    Nginx负载均衡概述 Web服务器,直接面向用户,往往要承载大量并发请求,单台服务器难以负荷,我使用多台WEB服务器组成集群,前端使用Nginx负载均衡,将请求分散的打到我们的后端服务器集群中,实现 ...

  6. 【原】linux两台服务器之间免密登录方法

    搭建集群机器192.168.0.100和192.168.0.200里,需要两台机器中间相互拷贝文件: 方式一:下载192.168.0.100机器文件到本地,再将本地文件拷贝到B机器 方式二:192.1 ...

  7. Linux 两台服务器之间传输文件和文件夹

    今天处理一个项目要迁移的问题,突然发现这么多图片怎么移过去,可能第一时间想到的是先从这台服务器下载下来,然后再上传到另外一台服务器上面去,这个方法确实是可行,但是实在是太费时间了,今天我就教大家怎么快 ...

  8. rsync配置两台服务器之间的文件备份(同步)

    rsync配置两台服务器之间的文件备份(同步) 前情提要 环境: 192.168.1.2 主服务器 centos 7.7 192.168.1.3 备份服务器 centos 7.7 rsync 安装(两 ...

  9. Tomcat WEB搭建+Nginx负载均衡动静分离+DNS解析的实验

    实验拓扑图: 实验环境: 在VMware workstation搭建虚拟环境,利用网络适配器的Nat和桥接模式模拟内网和外网环境. 实验过程中需要安装的工具包包括:vim unzip lrzsz ls ...

随机推荐

  1. 基于ReentrantLock的非公平锁理解AQS

    AQS AQS概述 ​ AbstractQueuedSynchronizer抽象队列同步器简称AQS,它是实现同步器的基础组件,juc下面Lock的实现以及一些并发工具类就是通过AQS来实现的,这里我 ...

  2. Tomcat发布War包或者Maven项目

    在tomcat的conf目录下面的server.xml中修改如下: Host name="localhost"  appBase="webapps" unpac ...

  3. DesignPattern系列__04里氏替换原则

    1.内容引入--继承体系的思考 在继承中,凡是在父类已经实现的方法,其实算是一种契约或者规范,子类不应该在进行更改(重写):但是,由于这一点不是强制要求,所以当子类进行重写的时候,就会对继承体系产生破 ...

  4. 学好C/C++编程,走遍天下都不怕

    C++这门语言从诞生到今天已经经历了将近30个年头.不可否认,它的学习难度都比其它语言较高.而它的学习难度,主要来自于它的复杂性.现在C++的使用范围比以前已经少了很多,java.C#.python等 ...

  5. 9.源码分析---SOFARPC是如何实现故障剔除的?

    SOFARPC源码解析系列: 1. 源码分析---SOFARPC可扩展的机制SPI 2. 源码分析---SOFARPC客户端服务引用 3. 源码分析---SOFARPC客户端服务调用 4. 源码分析- ...

  6. SprintBoot

    简述 推出时间:从Maven仓库的时间看是2016.7.28 目的:摆脱大量的XML配置文件以及复杂的Bean依赖关系,快速.敏捷地开发新一代基于Spring框架的应用程序 思想:约定优于配置(con ...

  7. hadoop的基础思想

    转载 http://www.superwu.cn/2014/01/10/963 1.1.1. hadoop的核心思想 Hadoop包括两大核心,分布式存储系统和分布式计算系统.1.1.1.1. 分布式 ...

  8. SonarQube系列二、分析dotnet core/C#代码

    [前言] 本系列主要讲述sonarqube的安装部署以及如何集成jenkins自动化分析.netcore项目.目录如下: SonarQube系列一.Linux安装与部署 SonarQube系列二.分析 ...

  9. Vue 路由模块化配置

    博客地址:https://ainyi.com/77 企业运营后台页面很多,路由如若不区分模块化配置,所有路由挤在同一个文件将不好维护,所以路由的配置也要模块化 分享两个解决方案 -- Vue 路由配置 ...

  10. p2p 打洞专场(转)

    就像1000个人眼中有1000个哈姆雷特一样,每个人眼中的区块链也是不一样的!作为技术人员眼中的区块链就是将各种技术的融合,包括密码学,p2p网络,分布式共识机制以及博弈论等.我们今天就来讨论一下区块 ...