keepalive高可用nginx(nginx动静分离)的实现

HA Cluster的配置前提:

        1、各节点时间要同步;
        2、确保iptables及selinux不会成为障碍;
        3、(可选)各节点之间可通过主机名互相通信;
             节点的名称设定与hosts文件中解析的主机名都要保持一致;
                # uname -n 获得的主机,与解析的主机名要相同;
        4、(可选)各节点之间基于密钥认证的方式通过ssh互信通信;

keepalive高可用nginx(nginx动静分离)的实现

一、各节点时间同步的实现方法

  在centos中安装chrony,其根据时间协议配置文件将多台主机的时间进行同步。
    本处master作为chrony的服务器端,backup主机作为chrony的客户端。
    1.在master中打开其配置文件/etc/chrony.conf,允许192.168.130.0/24网段的主机到该主机同步时间,同时该主机不去同步其他主机的时间。(见图)

    2.在backup中打开其配置文件/etc/chrony.conf,修改配置文件令本主机到192.168.130.128,同步时间(见图)

3.service chronyd start,启动master和backup主机的chrony服务,同时确保关闭防火墙,需等几十秒钟同步时间(注意如两台主机的时区不同,需修改两主机为同一时区)
4.用 watch -n 1 date 查看结果(见图)

二、配置master和backup主机规则

1.修改keepalived配置文件前先复制一份,避免修改错误。进入配置文件夹cd /etc/keepalived/  ,复制文件cp keepalived.conf keepalived.conf.bak。
2.master配置如下(下面全注释完)

3.backup配置如下(下面的全部注释完)

4.service keeplived start 启动keepalive服务,用ip a 查看ip地址是否配置成功(不要用ifconfig查看,该命令显示不完成查看不到的)(见图)

 5.开启keepalive的日志,编辑vim /etc/sysconfig/keepalived(见图)(该为开启日志功能)还需要一个日志文件,即是编辑/etc/rsyslog.conf (增加2图最后一行)最后重启日志,和keepalived,最后检查日志是否开启成功



三、配置nginx规则,开启nginx服务

 1.对master服务器和back服务器都启用nginx服务,同时其的配置文件内容应该要一致,因此在mater中配置好以后,可以直接传送一份给back服务器。



2.开启nginx服务前测试一下配置文件是否有错误,nginx -t -c /etc/nginx/nginx.conf

3.配置两个上游服务器upstream,一个为静态服务器,一个是动态服务器(本处动态服务器,暂用静态内容来响应,只为体现能分开反代而已,且本处是根据目录进行动静分离,且是httpd服务)


动态服务器(centos7 记得关闭防火墙)

四、结果展示

 1.master 功能正常时状态,

 2.当master 异常down机时,backup自动接替master的位置进行服务达到高可用目的.

原文地址:http://blog.51cto.com/14055961/2351006

时间: 2024-09-29 00:42:28

keepalive高可用nginx(nginx动静分离)的实现的相关文章

【Linux运维-集群技术进阶】Nginx+Keepalived+Tomcat搭建高可用/负载均衡/动静分离的Webserver集群

额.博客名字有点长.. . 前言 最终到这篇文章了,心情是有点激动的. 由于这篇文章会集中曾经博客讲到的全部Nginx功能点.包含主要的负载均衡,还有动静分离技术再加上这篇文章的重点.通过Keepalived实现的HA(High Available).为什么要实现高可用呢?曾经在搭建的时候仅仅用了一台Nginxserver,这种话假设Nginxserver宕机了,那么整个站点就会挂掉.所以要实现Nginx的高可用,一台挂掉还会有还有一台顶上去.从而保证站点能够持续的提供服务. 关于负载均衡和动静

nginx+tomcat动静分离结构

本文采用另一种策略对动静分离进行演示,它的大致结构如图 2 所示. 图 2. 本文设计的动静分离结构 在本文中,我们将静态资源放在 A 主机的一个目录上,将动态程序放在 B 主机上,同时在 A 上安装 Nginx 并且在 B 上安装 Tomcat.配置 Nginx,当请求的是 html.jpg 等静态资源时,就访问 A 主机上的静态资源目录:当用户提出动态资源的请求时,则将请求转发到后端的 B 服务器上,交由 Tomcat 处理,再由 Nginx 将结果返回给请求端. 提到这,可能有您会有疑问,

Docker构建Nginx+Tomcat动静分离架构

随着主流Nginx WEB服务器的发展,现在基于Nginx的WEB服务器已广泛应用于各大互联网企业.今天我们来使用docker构建我们的Linux+Nginx+Tomcat动静分离服务器. 1)    启动docker镜像 查看当前系统存在的镜像,我这里为centos6.6,大家可以参考我第一篇文章进行下载相应的镜像文件,然后启动. 启动方式如下:   docker run -i -t  centos6.6:v2 /bin/bash 然后进入新的docker容器里,查看ip为172.17.0.6

Nginx+Apache动静分离

Nginx的静态处理能力很强,但是动态处理能力不足,因此,在企业中常用动静分离技术. 针对PHP的动静分离:静态页面交给Nginx处理,动态页面交给PHP-FPM模块或Apache处理. 在Nginx的配置中,是通过location配置段配合正则匹配实现静态与动态页面的不同处理方式 一.Nginx正则匹配 常用的正则匹配规则 ^~ : 标识符后面跟一个字符串.Nginx将在这个字符串匹配后停止进行正则表达式的匹配,如 location  ^~ /images/,它在匹配了/images/这个字符

Linux深入篇之四:构建Nginx+Tomcat动静分离架构

Linux深入篇之四:构建Nginx+Tomcat动静分离架构 Nginx动静分离简单来说就是把动态跟静态请求分开,不能理解成只是单纯的把动态页面和静态页面物理分离.严格意义上说应该是:动态请求跟静态请求分开,可以理解成使用Nginx处理静态页面,Tomcat.Resin处理动态页面. 动静分离从目前实现角度来讲大致分为两种: 一种是纯粹的把静态文件独立成单独的域名,放在独立的服务器上,也是目前主流推崇的方案: 另外一种方法就是动态跟静态文件混合在一起发布,通过nginx来分开. 具体怎么来实现

nginx实现动静分离负载均衡集群

LB 负载均衡集群分两类: LVS (四层)和 nginx 或 haproxy (七层) 客户端通过访问分发器的 VIP 来访问网站 | 现在应用更复杂,比如现在网站页面有: .php .html .png .jpeg .jsp 等, 有劢态页面有静 态页面.静态页面一般是丌变的,想访问更快些,前面学习过 SQUID. | 但是前面的 LVS 是四层的.基于 IP 的.现在需要在应用层基于丌同的应用迚行分发. | 七层 LB , Nginx / Haproxy 都可以支持 7 层 LB 现在实现

Nginx实现动静分离

一.简介 通过Nginx的动静分离技术,可以实现将服务器单独只提供一种页面,例如,一台web服务器专门提供图片,css,js等静态资源,另外的一台服务器专门处理例如.php,.jsp等动态处理的请求.这样可以减轻双方服务器的压力,同时又可以做到负载分担. 二.拓扑 三.配置实现 0.开启Nginx的路由转发  #vi  /etc/sysctl.conf    net.ipv4.ip_forward = 1  #sysctl  -p 配置Nginx的动静分离 #user  nobody; work

Nginx+Tomcat动静分离架构

Nginx+Tomcat动静分离架构 Nginx+tomcat是目前主流的java web架构,Nginx动静分离简单来说就是把动态跟静态请求分开,不能理解成只是单纯的把动态页面和静态页面物理分离.严格意义上说应该是动态请求跟静态请求分开,可以理解成使用Nginx处理静态页面,Tomcat.Resin出来动态页面. 动静分离从目前实现角度来讲大致分为两种,一种是纯粹的把静态文件独立成单独的域名,放在独立的服务器上,也是目前主流推崇的方案:另外一种方法就是动态跟静态文件混合在一起发布,通过ngin

Nginx系列-9.配置NFS实现Nginx实现动静分离

Nginx系列-9.配置NFS实现Nginx实现动静分离 目录 - Nginx系列 Nginx系列-1.Linux下安装Nginx Nginx系列-2.配置LNMP(Linux.Nginx.MySQL.PHP)架构 Nginx系列-3.配置Nginx虚拟主机 Nginx系列-4.Nginx日志配置及日志切割 Nginx系列-5.配置Nginx的防盗链 Nginx系列-6.配置Nginx的HTTPS Nginx系列-7.配置Nginx使用uwsgi支持web.py框架 Nginx系列-8.配置Ng