KVM+GFS分布式复制卷

网友投稿 237 2022-10-12

KVM+GFS分布式复制卷

KVM+GFS虚拟平台的搭建

实验拓扑图:

实验需求

为了搭建KVM虚拟平台,我们需要创建一个条带复制卷,为虚拟主机提供搭建环境和分布式存储功能,

GFS 群集的搭建

环境搭建

1、为4台node节点,每台添加一块20G的移动硬盘,并且在客户端上开启虚拟化引擎

2、修改node节点的名称

分别修改为node1、node2、node3、node4

[root@localhost ~]#hostnamectl set-hostname node1 [root@localhost ~]# su

3、将四台服务器上的磁盘格式化,并挂载

在这里我们使用脚本执行挂载

#进入opt目录 [root@node1 ~]# cd /opt #磁盘格式化、挂载脚本 [root@node1 opt]# vim a.sh #! /bin/bash echo "the disks exist list:" fdisk -l |grep '磁盘 /dev/sd[a-z]' echo "==================================================" PS3="chose which disk you want to create:" select VAR in `ls /dev/sd*|grep -o 'sd[b-z]'|uniq` quit do case $VAR in sda) fdisk -l /dev/sda break ;; sd[b-z]) #create partitions echo "n p w" | fdisk /dev/$VAR #make filesystem mkfs.xfs -i size=512 /dev/${VAR}"1" &> /dev/null #mount the system mkdir -p /data/${VAR}"1" &> /dev/null echo -e "/dev/${VAR}"1" /data/${VAR}"1" xfs defaults 0 0\n" >> /etc/fstab mount -a &> /dev/null break ;; quit) break;; *) echo "wrong disk,please check again";; esac done #给于脚本执行权限 [root@node1 opt]# chmod +x a.sh

将脚本通过scp推送到其他三台服务器上

scp a.sh root@192.168.45.134:/opt scp a.sh root@192.168.45.130:/opt scp a.sh root@192.168.45.136:/opt

在四台服务器上执行脚本,并完成

这个只是样本

[root@node1 opt]# ./a.sh the disks exist list: ================================================== 1) sdb 2) quit chose which disk you want to create:1 //选择要格式化的盘 Welcome to fdisk (util-linux 2.23.2). Changes will remain in memory only, until you decide to write them. Be careful before using the write command. Device does not contain a recognized partition table Building a new DOS disklabel with disk identifier 0x37029e96. Command (m for help): Partition type: p primary (0 primary, 0 extended, 4 free) e extended Select (default p): Partition number (1-4, default 1): First sector (2048-41943039, default 2048): Using default value 2048 Last sector, +sectors or +size{K,M,G} (2048-41943039, default 41943039): Using default value 41943039 Partition 1 of type Linux and of size 20 GiB is set Command (m for help): The partition table has been altered! Calling ioctl() to re-read partition table. Syncing disks.

4、设置hosts文件

在第一台node1上修改

#在文件末尾添加 vim /etc/hosts 192.168.45.133 node1 192.168.45.130 node2 192.168.45.134 node3 192.168.45.136 node4

通过scp将hosts文件推送给其他服务器和客户端

#将/etc/hosts文件推送给其他主机 [root@node1 opt]# scp /etc/hosts root@192.168.45.130:/etc/hosts root@192.168.45.130's password: hosts 100% 242 23.6KB/s 00:00 [root@node1 opt]# scp /etc/hosts root@192.168.45.134:/etc/hosts root@192.168.45.134's password: hosts 100% 242 146.0KB/s 00:00 [root@node1 opt]# scp /etc/hosts root@192.168.45.136:/etc/hosts root@192.168.45.136's password: hosts

关闭所有服务器和客户端的防火墙

[root@node1 ~]# systemctl stop firewalld.service [root@node1 ~]# setenforce 0

在客户端和node服务器上搭建yum仓库

#进入yum文件路径 [root@node1 ~]# cd /etc/yum.repos.d/ #创建一个空文件夹 [root@node1 yum.repos.d]# mkdir abc #将CentOS-文件全部移到到abc下 [root@node1 yum.repos.d]# mv CentOS-* abc #创建私有yum源 [root@node1 yum.repos.d]# vim GLFS.repo [demo] name=demo baseurl=http://123.56.134.27/demo gpgcheck=0 enable=1 [gfsrepo] name=gfsrepo baseurl=http://123.56.134.27/gfsrepo gpgcheck=0 enable=1 #重新加载yum源 [root@node1 yum.repos.d]# yum list

安装必要软件包

[root@node1 yum.repos.d]# yum -y install glusterfs glusterfs-server glusterfs-fuse glusterfs-rdma

在四台服务器上启动glusterd,并设置为开机自启动

[root@node1 yum.repos.d]# systemctl start glusterd.service [root@node1 yum.repos.d]# systemctl enable glusterd.service

添加节点信息

[root@node1 yum.repos.d]# gluster peer probe node2 peer probe: success. [root@node1 yum.repos.d]# gluster peer probe node3 peer probe: success. [root@node1 yum.repos.d]# gluster peer probe node4 peer probe: success.

在其他服务器上查看节点信息

[root@node1 yum.repos.d]# gluster peer status

创建分布式复制卷

#创建分布式复制卷 [root@node2 yum.repos.d]# gluster volume create dis-rep replica 2 node1:/data/sdb1 node2:/data/sdb1 node3:/data/sdb1 node4:/data/sdb1 force volume create: dis-rep: success: please start the volume to access data #开启复制卷 [root@node2 yum.repos.d]# gluster volume start dis-rep volume start: dis-rep: success

KVM虚拟主机操作

1、将我们需要安装的系统镜像包挂载到虚拟机上

#挂载软件包 mount.cifs //192.168.100.3/lzp /mnt #先将安装镜像包复制到/opt/目录下 cp -r /mnt/CentOS-7-x86_64-DVD-1708.iso /opt/ &

2、配置自己的源

#进入yum文件路径 [root@node1 ~]# cd /etc/yum.repos.d/ #删除刚才在客户端上创建的私有源 [root@node1 yum.repos.d]# rm -rf GLFS.repo #将CentOS-文件全部移到到yum.repos.d下 [root@node1 abc]# mv CentOS-* ../ # 重新加载公有源 root@node1 yum.repos.d]#

3、配置KVM必须环境包

#安装桌面环境 yum groupinstall "GNOME Desktop" -y #KVM模块 yum install qemu-kvm -y # 调试工具 yum install qemu-kvm-tools -y #构建虚拟主机的命令工具 yum install virt-install -y #qemu组件,创建磁盘,启动虚拟机 yum install qemu-img -y #网络支持工具 yum install -y bridge-utils #虚拟机管理工具 yum install libvirt -y #图形化管理虚拟机 yum install virt-manager -y

4、判断cpu是否支持虚拟化。并查看虚拟机模块

egrep '(vmx|svm)' /proc/cpuinfo #查看,模块 lsmod | grep kvm

5、开启服务,并设置开机自启动

#开启服务 systemctl start libvirtd #开机自启动 systemctl enable libvirtd

移动软件包,将挂载的软件包移动到/data/目录下

#创建挂载点 mkdir /data/ #将刚才创建好的条带复制卷挂碍到data目录下 mount.glusterfs node3:dis-rep /data/ #创建两个文件 mkdir vdisk viso #复制并调到后台运行 cp -r /mnt/CentOS-7-x86_64-DVD-1708.iso /data/viso &

配置虚拟机的桥接网卡

#进入网卡文件 cd /etc/sysconfig/network-scripts/ #复制创建br0网卡 cp -p ifcfg-ens33 ifcfg-br0 #进入ens33网卡,设置桥接命令 vim ifcfg-ens33 #桥接命令 BRIDGE=br0 #配置桥接网卡,将桥接网卡设置为静态的地址 vim ifcfg-br0 TYPE=bridge PROXY_METHOD=none BROWSER_ONLY=no BOOTPROTO=static DEFROUTE=yes IPV4_FAILURE_FATAL=no IPV6INIT=yes IPV6_AUTOCONF=yes IPV6_DEFROUTE=yes IPV6_FAILURE_FATAL=no IPV6_ADDR_GEN_MODE=stable-privacy NAME=br0 DEVICE=br0 ONBOOT=yes IPADDR=192.168.45.140 NETMASK=255.255.255.0 GATEWAY=192.168.45.2 #重启网卡 service network restart

查看网卡信息

进入图像化管理界面

virt-manager

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:SpringBoot多数据源切换实现代码(Mybaitis)
下一篇:FasterDFS配置安装
相关文章

 发表评论

暂时没有评论,来抢沙发吧~