docker 搭建keepalived+nginx高可用
前言
最近工作 中 有用到keepalived,就想着 在 本地 搭建一套环境验证一下相关的功能。因为创建虚拟机比较麻烦,就借助 docker来搭建这样 一套 环境 ,顺带学习 巩固下docker的相关 命令;
1.准备工作
本地 安装好docker环境,我本地 使用的win10,已经安装好了docker环境;
2.下载centos7.6基础镜像
docker pull centos:7.6.
我已经安装好了,所以执行结果 如下

3.在centos7.6中安装keepalived和nginx 以及其他软件
启动容器:
docker run -it f1cb7c7d58b7 /bin/bash

使用 ip和 ifconfig命令需要安装 下面两个
yum install iproute yum install net-tools
4.使用yum 安装 keepalived
yum install keepalived

一直确认 y即可,安装完成

Keepalived检测nginx的脚本
/etc/keepalived 中 新建 check_nginx.sh
脚本 如下 :注意grep nginx: 冒号 ,因为执行的 时候脚本 的名字中也有nginx,会导致计算出来 的 数量不对 ,所以要 用nginx:
#!/bin/bash
A=$(ps -ef | grep nginx: | grep -v grep | wc -l)
if [ $A -eq ];then
nginx
echo "restart nginx, sleep 2 s"
sleep
num=$(ps -ef | grep nginx: | grep -v grep | wc -l)
if [ $num -eq ];then
ps -ef | grep keepalived | grep -v grep | awk '{print $2}'| xargs kill -
echo "start nginx failed,kill keepalived"
fi
else
echo "nginx not dead"
fi

查看 本机 IP
ip a

Keepalived配置
注释vrrp_strict 否则会导致 VIP 无法访问

增加检测脚本
添加VIP,注意 VIP 和本机IP在 同一个 网段内,否则也 无法访问
本机172.17.0.6/16 虚IP设置 为172.17.0.8/16

5.使用yum安装nginx
参考链接:https://www.cnblogs.com/opsprobe/p/10773582.html
yum install yum-utils

添加源
到 cd /etc/yum.repos.d/ 目录下
新建
vim nginx.repo
文件
输入以下信息
[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=
enabled=
gpgkey=https://nginx.org/keys/nginx_signing.key [nginx-mainline]
name=nginx mainline repo
baseurl=http://nginx.org/packages/mainline/centos/$releasever/$basearch/
gpgcheck=
enabled=
gpgkey=https://nginx.org/keys/nginx_signing.key

yum install nginx

安装完成

启动查看是否成功
nginx
curl localhost:

6.退出 ,制作 镜像
docker ps -a
找到 刚才 的容器

docker commit 5f781fbe483e keepavled_nginx:v1

7.启动主备keepalived容器
docker run --privileged -it --name keepalived_master 8dfe8c83bfae /usr/sbin/init docker run --privileged -it --name keepalived_salve 8dfe8c83bfae /usr/sbin/init


8.进入容器
docker ps
找到 启动 的容器

分别 进入容器
主 :172.17.0.7
备:172.17.0.6

备 keepalived修改 配置

9.验证keepalived
启动主keepalived,发现虚IP 已经绑定

systemctl status keepalived
查看启动状态

备keepalived启动,虚IP没有绑定

Kill 掉主的keepalived进程 后,主不再绑定VIP


重新查看 备,发现 绑定了VIP

再启动主keepalived,会发现VIP重新绑定在 主keepalived服务器
10.验证 nginx
Kill 掉nginx进程之后,再次查看 会发现nginx被重新 启动,因为 keepalived检测 脚本 会 自动检查 ,没有 进程 会自动重启,启动不成功则把keepalived kill掉。
见脚本check_nginx.sh
注意:check_nginx.sh必须要 加 权限 ,否则 不会执行;
chmod +x check_nginx.sh
VIP访问nginx测试
先分别修改主备 nginx的页面并重启
vi /usr/share/nginx/html/index.html


主备分别启动keepalived,此时 VIP绑定在主服务器 ;
访问nginx: curl 172.17.0.8:80,此时访问的是主服务器

把主服务器 的keepalived kill掉 之后验证 ,此时VIP绑定在备服务器,访问 的备服务器 的nginx

11.遇到的几个 问题
VIP无法访问的问题:
Vrrp_strict 注释掉
VIP在一个网段
Check_nginx.sh脚本 问题:
grep nginx: 冒号要加上否则执行过程中会grep 到脚本名称导致判断进程数量一直不为0;
脚本必须加权限,否则无法执行
参考链接:
https://www.cnblogs.com/jinjiangongzuoshi/p/9313438.html
docker 搭建keepalived+nginx高可用的更多相关文章
- Nginx(四):Keepalived+Nginx 高可用集群
Keepalived+Nginx 高可用集群 (主从模式) 集群架构图 安装keepalived [root@localhost ~]# yum install -y keepalived 查看状态 ...
- Keepalived+Nginx高可用实例
Keepalived+Nginx高可用实例 注意事项: 1.VIP不需要在服务器网络配置文件中配置. 2.nginx主不可用时,需要kill掉nginx主的keepalived服务,这样才可以实现VI ...
- Keepalived+nginx高可用
这种方法会把Keepalived进程结束掉,在教育机构学习到的方法,我个人对这种方法不认可. 参考: https://www.cnblogs.com/gshelldon/p/14504236.html ...
- keepalived+nginx高可用负载均衡环境搭建
上篇说道keepalived的环境搭建,本来keepalived结合lvs更有优势,但是也可以结合nginx来使用.下面接着说下nginx的环境搭建 环境信息: nginx(master) 192. ...
- LVS+KeepAlived+Nginx高可用实现方案
文章目录概念LVSKeepAlived为什么要使用准备软件安装KeepAlived 安装源码安装yum安装服务启动.重启.关闭安装ipvsadmnginx安装防火墙(iptables)防火墙配置(方式 ...
- Keepalived+Nginx高可用集群
Keepalived简介 Keepalived的作用是检测服务器的状态,如果有一台web服务器宕机,或工作出现故障,Keepalived将检测到,并将有故障的服务器从系统中剔除,同时使用其他服务器代替 ...
- keepalived+nginx 高可用集群
一.什么是高可用? nginx做负载均衡,能达到分发请求的目的,但是不能很好的避免单点故障. 1.nginx集群单点问题 分发器宕机怎么处理? 假如nginx服务器挂掉了,那么所有的服务也会跟着瘫 ...
- keepalived+nginx高可用实现
1.keepalived介绍 keepalived最初是专为LVS负载均衡软件设计的,用来管理并监控LVS集群系统中各个服务节点的状态,后来又加入了实现高可用的VRRP功能.keepalived除了能 ...
- centos安装与配置keepalived+nginx高可用
一.安装启动keepalived 1.下载keepalived 在centos系统中,用wget下载最新版本: mkdir tool cd tool wget https://www.keepaliv ...
随机推荐
- centos7搭建ceph集群
一.服务器规划 主机名 主机IP 磁盘配比 角色 node1 public-ip:10.0.0.130cluster-ip:192.168.2.130 sda,sdb,sdcsda是系统盘,另外两块数 ...
- SpringBoot图文教程12—SpringData Jpa的基本使用
有天上飞的概念,就要有落地的实现 概念十遍不如代码一遍,朋友,希望你把文中所有的代码案例都敲一遍 先赞后看,养成习惯 SpringBoot 图文教程系列文章目录 SpringBoot图文教程1「概念+ ...
- 【Java面试题】关于String,最近被问到了这2道面试题
1. 前言 最近面试了几家公司,体验了一下电话面试和今年刚火起来的视频面试, 虽然之前就有一些公司会先通过电话面试的形式先评估下候选人的能力水平,但好像不多,至少我以前的面试形式100%都是现场面试. ...
- Rust入坑指南:智能指针
在了解了Rust中的所有权.所有权借用.生命周期这些概念后,相信各位坑友对Rust已经有了比较深刻的认识了,今天又是一个连环坑,我们一起来把智能指针刨出来,一探究竟. 智能指针是Rust中一种特殊的数 ...
- 数据挖掘入门系列教程(四)之基于scikit-lean实现决策树
目录 数据挖掘入门系列教程(四)之基于scikit-lean决策树处理Iris 加载数据集 数据特征 训练 随机森林 调参工程师 结尾 数据挖掘入门系列教程(四)之基于scikit-lean决策树处理 ...
- 设计模式之委派模式,大名鼎鼎的Spring都在用
什么是委派模式 虽然说委派模式不属于Gof23中设计模式,但这并不影响它成为一种经典的设计模式. "委派"字面意思就是指派一件事情给某人.类比到生活中的场景,比如项目leader指 ...
- java集合-把商品放入集合中调用(新手)
//创建的一个包名. package qige; //导入的一个包.import java.util.*; //定义一个类.public class Ipcs { //公共静态的主方法. public ...
- Elasticsearch 之聚合分析入门
本文主要介绍 Elasticsearch 的聚合功能,介绍什么是 Bucket 和 Metric 聚合,以及如何实现嵌套的聚合. 首先来看下聚合(Aggregation): 什么是 Aggregati ...
- LeetCode42题,单调栈、构造法、two pointers,这道Hard题的解法这么多?
本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是LeetCode专题的第23篇文章. 今天来看一道很有意思的题,它的难度是Hard,并且有许多种解法. 首先我们来看题面,说是我们有若 ...
- asp.net core 3.x 微信小程序登录库(也可用于abp)
视频教程(使用+实现原理):https://share.weiyun.com/57HKopT 建议直接看视频 源码地址:https://github.com/bxjg1987/abpGeneralMo ...