Nginx+Keepalived配置
1. Nginx安装
(1) 环境:分别在2台服务器上部署nginx且步骤一致: 如192.138.86.1和192.138.86.2
(2) 下载官网最新稳定版,地址:https://nginx.org/en/download.html,本教程使用的是1.14.2版
(3) 安装Nginx的依赖包
a. 源码编译使用gcc: yum -y install ggc-c++
b. 正则表达式解析时使用pcre:yum -y install pcre pcre-devel
c. 压缩时使用的zlib:yum -y install zlib zlib-devel
d. openssl: yum -y install openssl openssl-devel
(4) 解压:tar –zxvf nginx-1.14.2.tar.gz; cd nginx-1.14.2
(5) 配置并编译:./configure –prefix=/usr/local/nginx && make && make install
(6) 启动nginx: cd /usr/local/nginx/sbin/; ./nginx
(7) 关闭nginx: ./nginx -s stop
(8) 重新加载配置文件:./nginx -s reload
(9) 设置开机自启:在/etc/rc.local中增加一行"/usr/local/nginx/sbin/nginx",并增加执行权限 chmod 755 /etc/rc.local
2. Keepalived安装配置
(1) 环境准备:安装服务器与nginx相同,vip分别为192.138.86.3和192.138.86.4
(2) 安装依赖:yum -y install libnl libnl-devel libnfnetlink-devel
(3) 官网下载稳定版的Keepalived,地址:http://www.keepalived.org/download.html,本文下载的是2.0.10
(4) 解压缩:tar -zxvf keepalived-2.0.10.tar.gz
(5) 配置并编译:./configure –prefix=/usr/local/keepalived && make && make install
(6) keepalived注册为系统服务:
a. cp /usr/local/src/keepalived-2.0.10/keepalived/etc/init.d/keepalived /etc/init.d/
b. cp /usr/local/src/keepalived-2.0.10/keepalived/etc/sysconfig/keepalived /etc/sysconfig/
c. cp /usr/local/src/keepalived-2.0.10/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/
(7) keepalived启动:service keepalvied start|stop|restart
(8) 86.1上的配置文件/etc/keepalived/keepalived.conf的内容如下:
! Configuration File for keepalived
global_defs {
notification_email {
test@example.com
}
notification_email_from research@nagios3.com
smtp_server 127.0.0.1
smtp_connect_timeout
router_id NGINX_DEVEL
}
vrrp_script chk_http_port {
script "/usr/local/nginx/monitor_nginx.sh"
interval
weight -
fall
rise
}
vrrp_instance VI_1 {
state MASTER
interface em1
virtual_router_id
priority
advert_int
mcast_src_ip 192.138.86.1
authentication {
auth_type PASS
auth_pass
}
virtual_ipaddress {
192.138.86.3
}
track_interface {
em1
}
track_script {
chk_http_port
}
}
vrrp_instance VI_2 {
state BACKUP
interface em1
virtual_router_id
priority
advert_int
mcast_src_ip 192.138.86.1
authentication {
auth_type PASS
auth_pass
}
virtual_ipaddress {
192.138.86.4
}
track_interface {
em1
}
track_script {
chk_http_port
}
}
(9) 86.2上的配置文件/etc/keepalived/keepalived.conf的内容如下:
! Configuration File for keepalived
global_defs {
notification_email {
test@example.com
}
notification_email_from research@nagios3.com
smtp_server 127.0.0.1
smtp_connect_timeout
router_id NGINX_DEVEL
}
vrrp_script chk_http_port {
script "/usr/local/nginx/monitor_nginx.sh"
interval
weight -
fall
rise
}
vrrp_instance VI_1 {
state BACKUP
interface em1
virtual_router_id
priority
advert_int
mcast_src_ip 192.138.86.2
authentication {
auth_type PASS
auth_pass
}
virtual_ipaddress {
192.138.86.3
}
track_interface {
em1
}
track_script {
chk_http_port
}
}
vrrp_instance VI_2 {
state MASTER
interface em1
virtual_router_id
priority
advert_int
mcast_src_ip 192.138.86.2
authentication {
auth_type PASS
auth_pass
}
virtual_ipaddress {
192.138.86.4
}
track_interface {
em1
}
track_script {
chk_http_port
}
}
说明:
a. 1和2上分别有虚拟ip3和4
b. 1和2上的keepalived基于vip互为主从
c. vrrp_script中的内容为nginx的心跳检测,其内容为:
#!/bin/bash DATE=$(date)
LogName=$(date +"%Y%m%d")
A=`ps -C nginx --no-header |wc -l`
logs=/usr/local/nginx/logs/nginx_check.$LogName.logs if [ $A -eq 0 ];then
cd /usr/local/nginx
echo "$DATE keepalived monitor start nginx" >> $logs
sudo ./sbin/nginx
sleep 3
if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then
echo "$DATE killall keepalived" >> $logs
sudo killall keepalived
fi
else
echo "$DATE keepalived monitornginx is ok" >> $logs
f
(10) 重启keepalived,然后尝试关闭主keepalived和nginx验证配置是否生效
Nginx+Keepalived配置的更多相关文章
- nginx:负载均衡实战(四)nginx+keepalived配置双机热备
1.下载安装 下载keepalived地址:http://www.keepalived.org/download.html 解压安装: tar -zxvf keepalived-.tar.gz 安装o ...
- nginx;keepalived配置出现主主的解决方法(脑裂问题)
1.查看日志 tail -f /var/log/messages 发现master和backup机都是mastaer模式启动的 通过查看别人的经历,发现VRRP基于报文实现的.master设置一定时间 ...
- Nginx+Keepalived 主备高可用 安装与配置
环境说明:操作系统:CentOS6.7 x86_64Nginx版本:nginx-1.9.7Keepalived版本:keepalived-1.2.24 主nginx + Keepalived :10. ...
- Nginx +keepalived
Nginx +keepalived 配置高可用的Nginx 准备环境: 节点node17,node18 lftp 172.16.0.1:/pub/Sources/6.x86_64/nginx ...
- Keepalived+Nginx+Tomcat配置高可用负载均衡系统示例
前言 此示例为keepalived+nginx+tomcat的基础配置示例,某些特定配置此例中不会出现,在示例中会用到三个虚拟机:两个纯命令行用于模拟服务端配置,一个带桌面环境的用于模拟客户端访问,这 ...
- nginx+keepalived+tomcat之具体配置档
前沿知识点: nginx负责负载均衡(反向代理) msm(memcached session manager)负责缓存会话信息,从而实现会话保持 所需包: nginx和memcached采用最新稳定版 ...
- Nginx keepalived实现高可用负载均衡详细配置步骤
Keepalived是一个免费开源的,用C编写的类似于layer3, 4 & 7交换机制软件,具备我们平时说的第3层.第4层和第7层交换机的功能.主要提供loadbalancing(负载均衡) ...
- 使用Keepalived配置主从热备实现Nginx高可用(HA)
Keepalived 简要介绍 Keepalived 是一种高性能的服务器高可用或热备解决方案,Keepalived 可以用来防止服务器单点故障的发生,通过配合 Nginx 可以实现 web 前端服务 ...
- centos LB负载均衡集群 三种模式区别 LVS/NAT 配置 LVS/DR 配置 LVS/DR + keepalived配置 nginx ip_hash 实现长连接 LVS是四层LB 注意down掉网卡的方法 nginx效率没有LVS高 ipvsadm命令集 测试LVS方法 第三十三节课
centos LB负载均衡集群 三种模式区别 LVS/NAT 配置 LVS/DR 配置 LVS/DR + keepalived配置 nginx ip_hash 实现长连接 LVS是四层LB ...
随机推荐
- 一个数组:1,1,2,3,5,8,13,21...+m,求第30位数是多少?用递归实现;(常考!!!)
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Cons ...
- C# 调接口
上一个项目,需要mvc管理后台调接口项目,以便后期的重构扩展,调研后发现后台用的ajax请求,直接调接口可能会有跨域问题,最终在c#代码中实现了这个需求. 1,Ajax请求后台 将接口所需参数传入 2 ...
- 《C#多线程编程实战》1.10 lock关键字
lock关键字是锁定资源用的. 书上的代码解释很好. /// <summary> /// 抽象类 加减法 /// </summary> abstract class Count ...
- C# 多态(2)
接上面讲 我们知道虚方法,和重写方法. 但是有没有发现 override和new的作用是差不多的. 但为什么还要单独写出来两个呢? 首先,咱们要明白一个问题,继承是具有线性传播的. class Fat ...
- Liunx常用的100条命令汇存
1.关机 shutdown -h now 立刻关机 poweroff shutdown -r now 立刻重启 reboot logout 注销 2.进入图形界面 startx 3.vi编辑器 [vi ...
- CF1137F Matches Are Not a Child's Play(树链剖分)
题面 我们定义一棵树的删除序列为:每一次将树中编号最小的叶子删掉,将该节点编号加入到当前序列的最末端,最后只剩下一个节点时将该节点的编号加入到结尾. 例如对于上图中的树,它的删除序列为:2 4 3 1 ...
- xz
- nginx关闭默认站点/空主机头(禁止IP直接访问、防止域名恶意解析)
监控时做了负载均衡,所以只能让nginx指定域名访问,那我们就可以防止因为域名不对跳到默认的页面去. curl -I -H “host:域名” --include https://19 ...
- 洛谷P2146 [NOI2015]软件包管理器
https://www.luogu.org/problemnew/show/P2146 传送门 简单的树链剖分......维护下当前安装了多少个包......修改后查询下就行了......附上极其丑陋 ...
- 【算法笔记】B1042 字符统计
1042 字符统计 (20 分) 请编写程序,找出一段给定文字中出现最频繁的那个英文字母. 输入格式: 输入在一行中给出一个长度不超过 1000 的字符串.字符串由 ASCII 码表中任意可见字符及空 ...