一.实验环境
data:image/s3,"s3://crabby-images/b35ff/b35ff424763ffa8b1072b00882a19af79bd37e62" alt="在这里插入图片描述" 二.实验目的
实验目的 通过www.magedu.org访问个人站点 本机的hosts(windows环境)添加解析到vip 通过haproxy实现反向代理 要求 两台nginx+php的web环境 实现站点高可用 任何一台宕机不影响访问 nginx要相同版本 普通用户启动 博客要正常上传,并且在两个web读取 共享基于共享存储NFS实现 对nfs实现实时跨主机数据同步备份 部署数据库主从 **言简意赅的说:**就是客户端通过本机设置的vip,通过haproxy实现反向代理 轮询访问web1和2 ,创建一个博客账号,并上传图片,图片要在两台web主机读取,并且实时备份在nfs1和2服务器 ,同时修改的数据要存放在mysql两台主从服务器里
三.部署步骤
1.配置主从 data:image/s3,"s3://crabby-images/f7e9e/f7e9ef7842ee8476ea44f3fe2afecf054e3a098c" alt="" mysql安装可以用编译,也可以用yum 版本一致就可以,我这里用的是yum安装
yum -y install mysql-server ;systemctl enable --now mysqld ; systemctl start mysqld
https://blog.csdn.net/Lcongming/article/details/117090768 (详细配置主从步骤) 由于后面要搭建博客,所以这里我们要在10.0.0.8上先创建一个WordPress的账号并授权; 步骤如下图 data:image/s3,"s3://crabby-images/fa97c/fa97c49d732e8ade2f1c7f8cf8eabcf1e51cb1ae" alt="在这里插入图片描述" 在slave验证
mysql -uwordpress -p123456 -h10.0.0.8
data:image/s3,"s3://crabby-images/58044/58044f3065bcd6f22cc2fe8f58a437a5fb5051ba" alt="在这里插入图片描述" 2.实现NFS实时同步 data:image/s3,"s3://crabby-images/5333c/5333c43261ac144e7c1979bdd1416eed391e277c" alt="" 我采用的是基于远程shell 实现 sersync 在47和57两台机器开启了ssh免密登录( https://blog.csdn.net/Lcongming/article/details/117405991 免密登录设置) 我们现在10.0.0.5710.0.0.57NFS2上操作 安装并且启动rsync :
yum -y install rsync ; systemctl enable --now rysncd ; systemctl start rsyncd
修改配置文件;vim /etc/rsyncd.conf 在最后添加
uid = root
gid = root
max connections = 0
ignore errors
exclude = lost+found/
log file = /var/log/rsyncd.log
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsyncd.lock
reverse lookup = no
[backup]
path = /data/backup/
comment = backup dir
read only = no
再接着建立backup
mkdir /data/backup/
由于用户和组都是root 所以不需要改权限 再重启一下服务;systemctl restart rsyncd
而在NFS1安装了sersync 和nfs-utils 安装的大致步骤如下 将安装包上传 将下载好的软件上传后,解压;tar xf sersync2.5.4_64bit_binary_stable_final.tar.gz 拷贝至相应的目录,设置PATH变量
cp -a GNU-Linux-x86 /usr/local/sersync
echo 'PATH=/usr/local/sersync:$PATH' > /etc/profile.d/sersync.sh
source /etc/profile.d/sersync.sh
#sersync目录只有两个文件:一个是二进制程序文件,一个是xml格式的配置文件 data:image/s3,"s3://crabby-images/1b2d6/1b2d63284284e5c60ecbbbd74aa406a0e35d4b61" alt="在这里插入图片描述" #备份sersync配置文件
cp /usr/local/sersync/confxml.xml{,.bak}
#修改sersync配置文件
vim /usr/local/sersync/confxml.xml
(说明图中1234是常规设置,由于使用了基于shell远程实现sersync,开启了ssh所以④设置false 就是不需要账号密码,而⑤开启了ssh) data:image/s3,"s3://crabby-images/32772/32772864b95647991eeaa68ac2bfaf196d884a67" alt="在这里插入图片描述" 然后执行
sersync2 -dro /usr/local/sersync/confxml.xml
(以后台方式运行同步,这步不执行,备用服务器上数据无法同步)
3.搭建Keepalive高可用并配置haproxy data:image/s3,"s3://crabby-images/ceddc/ceddcfbdaaa93199e34212d813e65d3ad8eb9763" alt="在这里插入图片描述"
10.0.0.7 kp1 10.0.0.17 kp2 安装的软件 keepalived和haproxy 安装后 分别要 设置开机启动
systemctl enable --now keepalived.service
systemctl enable --now haproxy.service
搭建keepalived**实现单主 (步骤可以参考:https://blog.csdn.net/Lcongming/article/details/118103893) 以下作参考; kp1 /etc/keepalived/keepalived.conf data:image/s3,"s3://crabby-images/02878/02878645d87ff40fad54367ae16729b6f36baa7c" alt="在这里插入图片描述"
/etc/haproxy/haproxy.conf
(说明有简化配置 和frontend+backend 两种方式,这里用的 是简化配置) data:image/s3,"s3://crabby-images/1183f/1183f36139df6d5b4ba2414915c8b6b00a64b9a5" alt="在这里插入图片描述" kp2 /etc/keepalived/keepalived.conf data:image/s3,"s3://crabby-images/43373/43373b933d290d838c713275a400a89ff5a40867" alt="在这里插入图片描述" /etc/haproxy/haproxy.conf data:image/s3,"s3://crabby-images/c21f3/c21f3df62fe67327db6e3d3112984e79221e1076" alt="在这里插入图片描述" 在两个ka1和ka2两个节点启用内核参数
vim /etc/sysctl.conf
net.ipv4.ip_nonlocal_bind = 1
再执行sysctl -p 抓包观察
tcpdump -i eth0 -nn host 224.0.100.100 data:image/s3,"s3://crabby-images/d32e5/d32e523be91d45210e8c936907ea20c167cfdc1f" alt="在这里插入图片描述" (说明,这里看需求,目前实验环境、单主、双主都是可以的)
5.搭建WordPress并挂载
安装的软件 nginx php-fpm nfs-utils data:image/s3,"s3://crabby-images/50e4e/50e4e06edc9219980e0e827036be1029cea7a658" alt="在这里插入图片描述" 说明一下,除了nginx和php-fpm要安装之外,nfs-untils也要安装,因为涉及挂载 https://blog.csdn.net/Lcongming/article/details/118046181 安装php-fpm参考 data:image/s3,"s3://crabby-images/3caed/3caed5e9d0e02377dd9ccf4f11e7b23b64fe81c4" alt="" 接着执行挂载 分别将图中1机器2机器 和3进行挂载 data:image/s3,"s3://crabby-images/b4738/b473808662f2ef4c6326898d3c8c008839588b6d" alt="在这里插入图片描述" 在web1和2上
mkdir -p /data/nginx/wordpress
这个时候 nfs服务一定要启动,执行 systemctl start nfs
mount 10.0.0.47:/data/vmdata/wordpress /data/nginx/wordpress
chown -r nginx.nginx wordpress
查看挂载结果 data:image/s3,"s3://crabby-images/34881/348814a6bcb623dcbeab0ddf87a5857c84292f7f" alt="在这里插入图片描述" 这个时候,已经实现了web1 web2 nfs1 nfs2上数据同步 目的是后续使1机器和2机器上的网页,php等文件实时同步到NFS服务器中,而数据则存放在主从数据库 补充 如果要机器重启后挂载还在,设置永久挂载就好了 vim /etc/fstab data:image/s3,"s3://crabby-images/20813/20813ce54ac100f7f240fc1501e2e00932eb5ce9" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/126fc/126fc968e435f6ec9a22ad5f174caa0db2fbec72" alt="在这里插入图片描述"
6.设置hosts并设置博客 在本地windows下设置 data:image/s3,"s3://crabby-images/6a68b/6a68b12f517ab779c04cc93964fa59c051bcf0ab" alt="在这里插入图片描述" 访问域名www.magedu.org data:image/s3,"s3://crabby-images/7a993/7a993e81de68e84eb84c87ef154ab5b4ffd7605a" alt="在这里插入图片描述" 设置完成后,登录微博发表图片; data:image/s3,"s3://crabby-images/10075/10075113d994e7f510145ef2dde6999be06c11a2" alt="在这里插入图片描述" 当web2故障的时候 data:image/s3,"s3://crabby-images/d12ca/d12ca5d701274b933d78d1c50a4362678d476706" alt="在这里插入图片描述" 查看网页访问依旧正常 data:image/s3,"s3://crabby-images/8cd20/8cd204147b32017476ed7f31e0a37d96cf57d26a" alt="在这里插入图片描述"
7.查看数据是否同步存储 这是在nfs1里的对应数据 data:image/s3,"s3://crabby-images/36cf9/36cf9a5506a88312dfd595161f101c37eebfc168" alt="在这里插入图片描述" 下载后就是这个图片 data:image/s3,"s3://crabby-images/55433/554339cf8f6b1fadb9b643bfc8121f1a1e49d584" alt="在这里插入图片描述" 这是在nfs2里查看到的 data:image/s3,"s3://crabby-images/c53cc/c53ccbf5a242848523a7525210fbc9ad26fc3121" alt="在这里插入图片描述" 这是在web1中查看到的 data:image/s3,"s3://crabby-images/4afe2/4afe2a4a440fecd34df6ab338f9e9f540abbcce5" alt="在这里插入图片描述" 这是在web2中查看到的 data:image/s3,"s3://crabby-images/5fc4d/5fc4d3e2b96c39f8cbfd612e31781f644ce3cce0" alt="在这里插入图片描述"
8.报错的处理 上传图片过程中提示报错无法建立目录wp-content/uploads/2021/07。有没有上级目录的写权限? 在master下mysql里操作 update wp_options set option_value = “wp-content/uploads” where option_name = “upload_path”; 将WordPress下将wp-content文件夹的读写权限更改为777即可
|