centos7下的glusterfs的安装与使用
环境说明:
两台虚拟主机,IP分别为192.168.1.222和192.168.1.233,分别装上glusterfs。
一、下载glusterfs源码包
https://download.gluster.org/pub/gluster/glusterfs/3.6/
如:glusterfs-3.6.9.tar.gz
二、编译安装
安装必要的依赖
> yum install flex bison openssl openssl-devel acl libacl libacl-devel sqlite-devel libxml2-devel python-devel
安装liburcu
https://github.com/urcu/userspace-rcu
> yum install autoconf automake libtool
> unzip userspace-rcu-master.zip
> cd userspace-rcu-master
> ./bootstrap
> ./configure
> make && make install
> ldconfig
解压并编译安装
> tar xf glusterfs-3.6.9.tar.gz
> cd glusterfs-3.6.9
> ./configure --prefix=/data/glusterfs
> make && make install
添加环境变量
> echo 'export PATH=/data/glusterfs/sbin:$PATH' >> /etc/profile
> source /etc/profile
三、使用glusterfs
分别启动两台主机上的glusterfs
> /data/glusterfs/sbin/glusterd
在222主机上配置可信池
> gluster peer probe 192.168.1.233
如果出现如下问题:
peer probe: failed: Probe returned with unknown errno 107
请查看防火墙是否关闭
查看可信池
> gluster peer status
要使用gluster必须要创建卷,卷有三种类型:
1、分布式卷,把数据写在不同的brick上。
在两台主机上分别创建exp1和exp2目录
> mkdir -p /data/exp1
> mkdir -p /data/exp2
创建分布式卷,exp-volume为卷名,可自定义
> gluster volume create exp-volume 192.168.1.222:/data/exp1 192.168.1.233:/data/exp2
查看卷信息
> gluster volume info
查看卷状态
> gluster volume status
2、复制卷
在两台主机上分别创建exp3和exp4目录
> mkdir -p /data/exp3
> mkdir -p /data/exp4
创建复制卷,复制两份,以tcp协议传输
注意brick数量与replica指定数相等
> gluster volume create rep-volume replica 2 transport tcp 192.168.1.222:/data/exp3 192.168.1.233:/data/exp4
3、条带卷,把一个文件分开存,像条带一样
在两台主机上分别创建exp5和exp6目录
> mkdir -p /data/exp5
> mkdir -p /data/exp6
创建条带卷
注意brick的数量与stripe指定数量相等
> gluster volume create str-volume stripe 2 transport tcp 192.168.1.222:/data/exp5 192.168.1.233:/data/exp6
分别启动我们上面创建的三种卷
> gluster volume start exp-volume
> gluster volume start rep-volume
> gluster volume start str-volume
安装gluster-clinet
> yum install glusterfs-client
挂载卷
> mkdir /mnt/m1 /mnt/m2 /mnt/m3
> mount.glusterfs 192.168.1.222:/exp-volume /mnt/m1
> mount.glusterfs 192.168.1.222:/rep-volume /mnt/m2
> mount.glusterfs 192.168.1.222:/str-volume /mnt/m3
我们创建几个文件写到/mnt/m1下
> echo '1' >> /mnt/m1/test1.txt
> echo '2' >> /mnt/m1/test2.txt
> echo '3' >> /mnt/m1/test3.txt
上面三个文件分别放在了222和233主机下的exp1和exp2目录。
我们创建文件到复制卷/mnt/m2下
> echo 'rep' >> /mnt/m2/rep.txt
rep.txt文件同时会存在222和233主机下的exp3和exp4目录下。
我们创建文件到条带卷/mnt/m3下
> echo '123456789' >> /mnt/m3/str.txt
str.txt文件会被折分成多个小文件保存在222和233主机下的exp5和exp6目录下。
三、分布式复制卷的创建与使用
分别在222和233主机上创建
> mkdir -p /data/t1 /data/t2
文件存放与这里的服务器顺序有关系
注意brick必须为replica指定数量K的N倍,brick以K个为一组,形成N个复制卷
> gluster volume create t-volume replica 2 transport tcp \
192.168.1.222:/data/t1 \
192.168.1.233:/data/t1 \
192.168.1.222:/data/t2 \
192.168.1.233:/data/t2
启动卷
> gluster volume start t-volume
挂载卷
> mkdir /mnt/m4
> mount.glusterfs 192.168.1.222:/t-volume /mnt/m4
创建文件测试
> echo '1' >> /mnt/m4/1.txt
> echo '1' >> /mnt/m4/2.txt
> echo '1' >> /mnt/m4/3.txt
> echo '1' >> /mnt/m4/4.txt
四、卷的设置
启用卷的配额
> gluster volume quota exp-volume enable
关闭卷的配额
> gluster volume quota exp-volume disable
设置配额大小,以系统挂载目录为根目录,即/mnt/m1/data
> gluster volume quota exp-volume limit-usage /data 10GB
查看卷的配额列表
> gluster volume quota exp-volume list
增加brick
> gluster volume add-brick exp-volume 192.168.1.222:/data/exp8
重新均衡一下卷,上面增加的卷才生效
> gluster volume rebalance exp-volume start
删除brick
> gluster volume remove-brick exp-volume 192.168.1.222:/data/exp8 force
> gluster volume rebalance exp-volume start
centos7下的glusterfs的安装与使用的更多相关文章
- SVN CentOS7 下配置svn的安装及基础配置介绍
CentOS7 下配置svn的安装及基础配置介绍 by:授客 QQ:1033553122 目录 一. 二. 三. 四. 五. 六. 七. 一. 实践环境 CentOS 7操作系统(CentO ...
- centos7下源码方式安装gitlab8.9+发送邮件+ldap
CentOS7下源码方式安装gitlab 环境描述 操作系统: centos7 redis: >=2.8 mysql >=5.5.14 git >=2.7.4 架构设计 一台gitl ...
- centos7下mysql5.7的安装与配置
centos7下MySQL5.7的安装与配置 下载 下载地址 根据系统和版本选择红框中的四个RPM包下载即可,然后放到centos7系统中的/opt目录下,等待稍后安装. 安装前的准备 1. 检查系统 ...
- inux centos7下源码 tar安装5.7.26详解
inux centos7下源码 tar安装5.7.26图文详解 官网地址 https://dev.mysql.com/downloads/mysql/ 1.卸载Linux系统上自带的mysql插件(o ...
- CentOS7下MySQL5.7的安装-RPM方式
Installing MySQL on Linux Using RPM Packages 下载安装包 mysql下载地址:https://dev.mysql.com/downloads/mysql/ ...
- CentOS7下通过rpm方式安装MySQL及插入中文问题解决 [原创]
一 CentOS下通过rpm方式安装MySQL CentOS版本:CentOS-7 MySQL版本:MySQL-5.6.22 在网上搜了一下,Linux下安装MYSQL有三种方式: 1) 通过yum命 ...
- centos7下keepalived1.3.4安装与使用
keepalived是集群管理中保证集群高可用的一个服务软件,其功能类似于heartbeat,用来防止单点故障. 一.下载keepalived http://www.keepalived.org/ 如 ...
- 【CentOS】在Centos7 下无图形界面安装 Oracle11g
目标 - 在虚拟机CentOS7中无图形界面安装Oracle11G R2版本 ① 系统要求以及准备 1. 物理内存不小于1G: 查看方式: # grep MemTotal /proc/meminfo ...
- centos7下redis和php-redis安装
centos7下redis安装和php-redis扩展安装 //一直yes就可以了 yum install redis //配置 whereis redis.conf vi /etc/redis.co ...
随机推荐
- css给文字加下划线
语法:linear-gradient(direction, color-stop 1, color-stop 2,……) 简单用法:background-image: linear-gradient( ...
- mongoDB如何处理多对多关系
问题描述: 例如在关系数据库中有一个Team表,一个User表,两者是多对多的关系,即一个Team可以有多个User,一个User也可能属于多个Team,请问这样的关系在MongoDB中如何存储? 如 ...
- unity3d assetbundle打包策略
由于assetbundle打包存在依赖的问题,所有资源要进行合理的分包 零.代码 代码都放在本地,包括NGUI等插件的代码.shader代码(内置的shader无需打包,而自定义的shader还是需要 ...
- 学习JS的心路历程-范围Scope和提升(Hoisting)
在上一篇提到了JS有三种声明变量的方式,分别是var.const及let,var和const let最大区别就是范围(scope)的限制.所以在这一篇我们会详谈何谓范围链及他们的复写优先级. 范围Sc ...
- LDA线性判别分析(转)
线性判别分析LDA详解 1 Linear Discriminant Analysis 相较于FLD(Fisher Linear Decriminant),LDA假设:1.样本数据服从正态分布,2 ...
- ubuntu18.04获取root权限并用root用户登录
1.为root设置初始密码 (1)登录系统,打开终端,输入命令:sudo passwd root(使用root权限为root更改密码) (2)设置root密码(建议简单点,没必要那么复杂): (3)重 ...
- python基础学习 Day19 面向对象的三大特性之多态、封装 property的用法(1)
一.课前内容回顾 继承作用:提高代码的重用性(要继承父类的子类都实现相同的方法:抽象类.接口) 继承解释:当你开始编写两个类的时候,出现了重复的代码,通过继承来简化代码,把重复的代码放在父类中. 单继 ...
- SpringBoot整合RabbitMQ,实现消息发送和消费以及多个消费者的情况
下载安装Erlang和RabbitMQ Erlang和RabbitMQ:https://www.cnblogs.com/theRhyme/p/10069611.html AMQP协议 https:// ...
- SpringCloud报错:com.netflix.discovery.shared.transport.TransportException: Cannot execute request on any known server
启动SpringCloudEureka 报错:com.netflix.discovery.shared.transport.TransportException: Cannot execute req ...
- vue, js 正则邮箱验证、匹配非法字符、匹配中文
验证邮箱 let self = this let regEmail= /^([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|\_|\.]?)* ...