架构设计
ip
服务应用
192.168.166.128
nginx/tomcat/keepalived
192.168.166.129
nginx/tomcat/keepalived
192.168.166.130
虚拟ip
我这是测试环境,防火墙全部关闭了。
?
1
2
3
4
# 查看防火墙状态
systemctl status firewalld
# 关闭防火墙
systemctl stop firewalld
安装tomcat服务
192.168.166.128
在tomcat服务webapps下创建一个目录:zkc
当前目录:
?
1
2
3
4
mdkir -p webapps/zkc
echo “192.168.166.128” >> webapps/zkc/a.html
#启动tomcat
./bin/startup.sh
访问地址:http://192.168.166.128:8080/zkc/a.html
192.168.166.129
在tomcat服务webapps下创建一个目录:zkc
当前目录:
?
1
2
3
4
mdkir -p webapps/zkc
echo “192.168.166.129” >> webapps/zkc/a.html
#启动tomcat
./bin/startup.sh
访问地址:http://192.168.166.129:8080/zkc/a.html
安装nginx服务
可以直接到官网下载或者通过yum下载
两台机器安装步骤一样
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
# 安装nginx
yum -y install nginx
# 进入配置文件目录
cd /etc/nginx/
# 修改配置文件
vim nginx.conf
upstream app_server{
server 192.168.166.128:8080 weight=1 max_fails=1 fail_timeout=100;
server 192.168.166.129:8080 weight=1 max_fails=1 fail_timeout=100;
}
server {
listen 80;
listen [::]:80;
server_name _;
root /usr/share/nginx/html;
# load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
location /zkc {
proxy_set_header host $host:$server_port;
proxy_set_header x-real-ip $remote_addr;
proxy_set_header x-forwarded-for $proxy_add_x_forwarded_for;
proxy_connect_timeout 10;
proxy_read_timeout 600;
proxy_send_timeout 600;
proxy_pass http://app_server;
access_log /var/log/nginx/access-app.log main;
}
# 启动
nginx
访问: curl http://192.168.166.128/zkc/a.html
访问:curl http://192.168.166.129/zkc/a.html
安装keepalived
安装keepalived两台机器一样
可以上网下载keepalived或者通过yum安装
?
1
2
3
4
5
6
7
# 安装
yum -y install keepalived
cd /etc/keepalived/
# 创建检测文件
vim chk_nginx.sh
# 赋予可执行权限
chmod +x chk_nginx.sh
chk_nginx.sh 内容
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#!/bin/bash
status=$(ps aux|grep nginx | grep -v grep | grep -v bash | wc -l)
#echo $status >> check.log
if [ “${status}” = “0” ]; then
#echo “nginx已关闭,正在重启” >> check.log
# 启动nginx
/usr/sbin/nginx
status=$(ps -c nginx –no-header|wc -l)
#echo $status >> check.log
# 再次判断
if [ $status -eq 0 ];then
# echo “nginx已关闭,正在重启” >> check.log
# 关闭keepalived
systemctl stop keepalived;
fi
fi
创建keepalived配置文件
?
1
2
3
# 备份原有keepalived.conf内容
mv keepalived.conf keepalived.conf_bk
vim keepalived.conf
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
global_defs {
router_id lvs_ha2
}
vrrp_script chk_mysql {
script “/etc/keepalived/chk_nginx.sh”
interval 2
}
vrrp_instance ha_1 {
state backup
interface ens33
virtual_router_id 80
priority 80
advert_int 2
nopreempt
authentication {
auth_type pass
auth_pass 1111
}
virtual_ipaddress {
192.168.166.130
}
track_script {
chk_mysql
}
}
启动keepalived
?
1
systemctl start keepalived
访问虚拟ip环境:curl http://192.168.166.130/zkc/a.html
说明环境已经搭建成功
验证
1、192.168.166.128 中nginx突发故障,但是keepalived使得nginx又重新启动
2、重启服务器模拟服务器故障死机
192.168.166.128重启
192.168.166.129,此时发现虚拟ip漂移到此服务器上
为什么没有128呢,是因为刚才服务重启,但是tomcat、nginx、keepalived服务没有做开机自启。
到此这篇关于nginx+tomcat+keepalived实现高可用的文章就介绍到这了,更多相关nginx+tomcat+keepalived高可用内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/wqww_1/article/details/123548008
声明: 猿站网有关资源均来自网络搜集与网友提供,任何涉及商业盈利目的的均不得使用,否则产生的一切后果将由您自己承担! 本平台资源仅供个人学习交流、测试使用 所有内容请在下载后24小时内删除,制止非法恶意传播,不对任何下载或转载者造成的危害负任何法律责任!也请大家支持、购置正版! 。本站一律禁止以任何方式发布或转载任何违法的相关信息访客发现请向站长举报,会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。本网站的资源部分来源于网络,如有侵权烦请发送邮件至:2697268773@qq.com进行处理。