zoukankan      html  css  js  c++  java
  • 构建企业分布式存储glusterfs

    1.硬件要求

    服务器:2U SATA盘4T 如果I/O要求比较高,可以采购SSD固态硬盘  RAID卡有缓存,缓存越大,性能越好  一般建议做RAID10/RAID5  多层冗余(分布式系统层和硬盘层级) 多台服务器硬件配置要尽量一致 

    系统要求:centos6  最小化安装

    分区:/ boot swap 

    2.网络要求

    千兆网卡 双网卡绑定

    3.构建高性能、高可用存储

    卷类型:分布式复制卷

    防火墙端口:只开启必备的端口 

    参数优化:访问权限控制、用户访问超时时间、读写的buff cache设置

    监控:

    主机层:zabbix自己的插件模板

    应用层:每隔15分钟dd命令向挂载卷写数据

    4.故障处理

    如果底层做了 RAID 配置,有硬件故障,直接更换硬盘,会自动同步数据。
    如果没有做 RAID,处理方法如下:

    正常节点上执行 gluster volume status,记录故障节点 uuid
    执行:getfattr -d -m ‘.*’ /brick 记录 trusted.gluster.volume-id 及 trusted.gfid

    以下为故障模拟及修复过程:

    在 VMware Workstation 上移除 mystorage1 主机的第三块硬盘(对应 sdc /storage/brick2),相当于硬盘故障

    复制代码
    # 系统提示如下:
    Message from syslogd@linux-node01 at Jul 30 08:41:46 ...
     storage-brick2[5893]: [2016-07-30 00:41:46.729896] M [MSGID: 113075] [posix-helpers.c:1844:posix_health_check_thread_proc] 0-gv2-posix: health-check failed, going down
    
    Message from syslogd@linux-node01 at Jul 30 08:42:16 ...
     storage-brick2[5893]: [2016-07-30 00:42:16.730518] M [MSGID: 113075] [posix-helpers.c:1850:posix_health_check_thread_proc] 0-gv2-posix: still alive! -> SIGTERM
    
     # 查看卷状态,mystorage1:/storage/brick2 不在线了,不过这是分布式复制卷,还可以访问另外 brick 上的数据
    [root@mystorage1 ~]# gluster volume status gv2 
    Status of volume: gv2
    Gluster process                             TCP Port  RDMA Port  Online  Pid
    ------------------------------------------------------------------------------
    Brick mystorage1:/storage/brick2            N/A       N/A        N       N/A  
    复制代码

    在 VMware Workstation 上新增 mystorage1 一块硬盘,相当于更换了新硬盘,下面先格式挂载新硬盘:

     
    复制代码
    # mkfs.xfs -f /dev/sdc
    # mkdir -p /storage/brick2
    # mount -a
    # df -h
    
    # 新硬盘挂载后目录为空
    [root@mystorage1 ~]# ll /storage/brick2
    total 0
    复制代码

    开始手动配置新增硬盘的 gluster 参数

    复制代码
    # 在 mystorage2 是获取 glusterfs 相关参数:
    [root@mystorage2 tmp]# getfattr -d -m '.*'  /storage/brick2
    getfattr: Removing leading '/' from absolute path names
    # file: storage/brick2
    trusted.gfid=0sAAAAAAAAAAAAAAAAAAAAAQ==
    trusted.glusterfs.dht=0sAAAAAQAAAAAAAAAAf////g==
    trusted.glusterfs.dht.commithash="3168624641"
    trusted.glusterfs.quota.dirty=0sMAA=
    trusted.glusterfs.quota.size.1=0sAAAAAATiAAAAAAAAAAAAAwAAAAAAAAAE
    trusted.glusterfs.volume-id=0sEZKGliY6THqhVVEVrykiHw==
    
    # 在 mystorage1 上执行配置 glusterfs 参数和上述一样
    
    setfattr -n trusted.gfid -v 0sAAAAAAAAAAAAAAAAAAAAAQ== /storage/brick2
    setfattr -n trusted.glusterfs.dht -v 0sAAAAAQAAAAAAAAAAf////g== /storage/brick2
    setfattr -n trusted.glusterfs.dht.commithash -v "3168624641" /storage/brick2
    setfattr -n trusted.glusterfs.quota.dirty -v 0sMAA= /storage/brick2
    setfattr -n trusted.glusterfs.quota.size.1 -v 0sAAAAAATiAAAAAAAAAAAAAwAAAAAAAAAE /storage/brick2
    setfattr -n trusted.glusterfs.volume-id -v 0sEZKGliY6THqhVVEVrykiHw== /storage/brick2
    
    [root@mystorage1 ~]# /etc/init.d/glusterd restart
    Starting glusterd:                                         [  OK  ]
    
    
    [root@mystorage1 ~]# gluster volume heal gv2 info
    Brick mystorage1:/storage/brick2
    Status: Connected
    Number of entries: 0
    
    Brick mystorage2:/storage/brick2
    /data 
    Status: Connected
    Number of entries: 1        # 显示一个条目在修复,自动修复完成后会为 0
    
    Brick mystorage3:/storage/brick1
    Status: Connected
    Number of entries: 0
    
    Brick mystorage4:/storage/brick1
    Status: Connected
    Number of entries: 0
    
    # 自动修复同步完成后,查看新硬盘的数据同步过来了
    [root@mystorage1 ~]# ll /storage/brick2
    total 40012
    -rw-r--r-- 2 root root 20480000 Jul 30 02:41 20M.file
    -rw-r--r-- 2 root root 20480000 Jul 30 03:13 20M.file1
    drwxr-xr-x 2 root root       21 Jul 30 09:14 data
    复制代码

     

    一台节点故障的情况包含以下情况:

    • 物理故障
    • 同时有多块硬盘故障,造成数据丢失
    • 系统损坏不可修复

    解决方法:

    找一台完全一样的机器,至少要保证硬盘数量和大小一致,安装系统,配置和故障机同样的 IP,安装 gluster 软件,
    保证配置一样,在其他健康节点上执行命令 gluster peer status,查看故障服务器的 uuid

    复制代码
    [root@mystorage2 ~]# gluster peer status
    Number of Peers: 3
    
    Hostname: mystorage3
    Uuid: 36e4c45c-466f-47b0-b829-dcd4a69ca2e7
    State: Peer in Cluster (Connected)
    
    Hostname: mystorage4
    Uuid: c607f6c2-bdcb-4768-bc82-4bc2243b1b7a
    State: Peer in Cluster (Connected)
    
    Hostname: mystorage1
    Uuid: 6e6a84af-ac7a-44eb-85c9-50f1f46acef1
    State: Peer in Cluster (Disconnected)
    复制代码

    修改新加机器的 /var/lib/glusterd/glusterd.info 和 故障机器一样

    [root@mystorage1 ~]# cat /var/lib/glusterd/glusterd.info
    UUID=6e6a84af-ac7a-44eb-85c9-50f1f46acef1
    operating-version=30712

    在信任存储池中任意节点执行

    # gluster volume heal gv2 full

    就会自动开始同步,但在同步的时候会影响整个系统的性能。

    可以查看状态

    # gluster volume heal gv2 info
  • 相关阅读:
    php-有时候你会疑惑的小问题
    phpDocumentor生成文档
    mongodb重命名集合、数据库
    资料网站
    Service(服务)
    Component(组件)
    Module(模块)
    你不屑于大器晚成,就只能平庸一生
    是狼就磨好牙,是羊就练好腿!
    将Excel数据导入数据库
  • 原文地址:https://www.cnblogs.com/wanyp/p/6923718.html
Copyright © 2011-2022 走看看