基于RHCS+iscsi+glvm构建IP SAN共享存储                            2012-11-29 12:03:16    

标签:iscsi RHCS ip san

原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://laoguang.blog.51cto.com/6013350/1073891            

                   

目的:

四台主机,rs1、rs2、rs3、target,rs1,rs2,rs3提供http服务,target主机把自己的磁盘做成IP SAN 的target供rs1,rs2,rs3使用

规划:

rs1 172.16.1.11 hostname rs1.laoguang.me  rs2 172.16.1.12 hostname rs2.laoguang.me  rs3 172.16.1.13 hostname rs3.laoguang.me  target 172.16.1.14 hostname target.laoguang.me  VIP 172.16.1.1

一.先构建我们的RHCS高可用集群

准备工作:hostname设置,/etc/hosts下做好解析,ssh 互信,date统一,这是所有集群必须具备的。

1.1 配置准备工作.在rs1上演示,target不是高可用集群中的一个节点,可不配置,不过建议配置

配置hostname

hostname rs1.laoguang.me vim /etc/hosts 172.16.1.11     rs1.laoguang.me rs1  172.16.1.12     rs2.laoguang.me rs2  172.16.1.13     rs3.laoguang.me rs3 172.16.1.14     target.laoguang.me      target

配置互信

ssh-keygen -t rsa -P ""    ##会生成密钥在/root/.ssh下,公钥拷贝到rs2的/root/.ssh/authorized_keys ssh-copy-id -i /root/.ssh/id_rsa.pub rs2    ##rs1登录rs2不再需要密码 ssh-copy-id -i /root/.ssh/id_rsa.pub target

时间同步:(如果有NTP就同步NTP的时间)

date -s 20121127;ssh rs2 'date -s 20121127';ssh rs3 'date -s 20121127';\ssh target 'date -s 20121127'

1.2 rs1,rs2,rs3安装httpd

yum -y install httpd

建立测试页面rs1,rs2,rs3上分别为

echo "<h1>RS1</h1>" > /var/www/html/index.html echo "<h1>RS2</h1>" > /var/www/html/index.html echo "<h1>RS3</h1>" > /var/www/html/index.html

启动服务测试各各网站是否运行正常,如果正常继续。

service httpd start

关闭httpd,并关闭的开机自启动

service httpd stop chkconfig httpd off

1.3 安装RHCS套件需要的openais,cman,rgmanager,gfs2-utils(集群文件系统),system-config-cluster(此为GUI配置工具)

yum -y install cman rgmanager gfs2-utils

1.4 建立集群WebCluster

ccs_tool create WebCluster   ##会在/etc/cluster中生成cluster.conf集群的配置文件(xml格式)

1.5 加入node到WebCluster集群

ccs_tool addfence Manual fence_manual  ##RHCS需要先定义隔离设备 ccs_tool addnode -v 1 -n 1 -f Manual rs1.laoguang.me  ##加入rs1 ccs_tool addnode -v 1 -n 2 -f Manual rs2.laoguang.me  ##加入rs2 ccs_tool addnode -v 1 -n 3 -f Manual rs3.laoguang.me  ##加入rs3 -v 指定每个节点的票数 -n 指定节点ID -f 指定fence设备

1.6 rs1,rs2,rs3上启动cman

service cman start;      ##注:如果局域网内多台机器玩cman的话cman可能启动不成功,其它机器可能是同步的其它主机的CIB service rgmanager start; ##启动rgmanager

1.7 启动system-config-cluster 配置cluster ##由于cman的配置文件为xml格式,笔者还不会用

system-config-cluster

1.7.1 定义故障转移域

基于RHCS+iscsi+glvm构建IP SAN共享存储_linux clvm san

基于RHCS+iscsi+glvm构建IP SAN共享存储_linux clvm san_02

1.7.2 定义IP资源与httpd资源

基于RHCS+iscsi+glvm构建IP SAN共享存储_linux clvm san_03

httpd资源

基于RHCS+iscsi+glvm构建IP SAN共享存储_linux clvm san_04

1.7.3 定义服务

基于RHCS+iscsi+glvm构建IP SAN共享存储_linux clvm san_05

基于RHCS+iscsi+glvm构建IP SAN共享存储_linux clvm san_06

查看集群状态

clustat
Cluster Status for WebCluster @ Wed Nov 28 18:38:19 2012 Member Status: Quorate  Member Name                                     ID   Status ------ ----                                     ---- ------ rs1.laoguang.me                                     1 Online, rgmanager rs2.laoguang.me                                     2 Online, rgmanager rs3.laoguang.me                                     3 Online, Local, rgmanager  Service Name                           Owner (Last)                    State          ------- ----                           ----- ------                    -----          service:WebService                     rs1.laoguang.me                 started

由此可知WebService在rs1上运行,访问http://172.16.1.1测试

二,target中安装scsi-target-utils

2.1 安装rpm包

 yum -y install scsi-target-utils

2.2 建立一2G分区,我建的是/dev/sda5  ##不要格式化,记得partprobe

2.3 编辑配置文件/etc/tgt/targets.conf,添加一个target,如下

    <target iqn.2012-11.me.laoguang.target:sda5>         backing-store /dev/sda5           ##后备存储,一般指一个分区,或lvm设备         initiator-address 172.16.0.0/16   ##指定intiaor只能是这个地址范围         #direct-store /dev/sdb          ##直接存储,通常指一个磁盘如/dev/sda5         #incominguser hadoop redhat    ##定义基于账户认证Initiator,后面的是账号与密码         #outgoinguser userA secretpassA  ##Initiator也可以验证target,这个target的账号密码     </target>     ##targetname 格式 iqn-name: iqn.yyyy-mm.<reversed domain name>[identifer]
-------------------------------不是很华丽的分隔线-------------------------------------    我们也可以有命令行来配置,只不过重启后会失效哦     用法:tgtadm --lld [driver] --op [operation] --mode [mode] [OPTION]..     新增target:     tgtadm --lld iscsi --op new --mode target --tid 1 --targetname \    iqn.2012-11.me.laoguang.target:sda5     显示新增的target:     tgtadm --lld iscsi --op show --mode target     新增一localunit:     tgtadm --lld -iscsi --op new --mode localunit --tid 1 --lun 1 --backing-store /dev/sda5     新增ACL允许172.16.0.0/16网段使用:     tgtadm --lld iscsi --op bind --tid 1 --initiator-address 172.16.0.0/16     新增账户认证:     建立账户:     tgtadm --lld iscsi --op new --mode account  --user hadoop --password redhat     查看新建账户:     tgtadm --lld iscsi --op show --mode account     绑定账户到target:     tgtadm --lld iscsi --op bind --mode account --tid 1 --user hadoop     查看target信息:     tgtadm --lld iscsi --op show --mode target     -------------------------------不是很华丽的分隔线---------------------------

2.4 启动tgtd服务,验证target是否分享出去

service tgtd start tgtadm --lld iscsi --op show --mode target      Target 1: iqn.2012-11.me.laoguang.target:sda5     System information:         Driver: iscsi         State: ready     I_T nexus information:     LUN information:         LUN: 0             Type: controller             SCSI ID: IET     00010000             SCSI SN: beaf10             Size: 0 MB, Block size: 1             Online: Yes             Removable media: No             Readonly: No             Backing store type: null             Backing store path: None             Backing store flags:          LUN: 1             Type: disk             SCSI ID: IET     00010001             SCSI SN: beaf11             Size: 1012 MB, Block size: 512             Online: Yes             Removable media: No             Readonly: No             Backing store type: rdwr             Backing store path: /dev/sda5             Backing store flags:      Account information:     ACL information:         172.16.0.0/16

验证正常,禁止tgt开机启动

chkconfig tgtd off

三,在rs1,rs2,rs3上安装iscsi-initiator-utils

yum -y install iscsi-initator-utils ##很可能已经安装了 echo "InitiatorAlias=rs1" >> /etc/iscsi/initiatorname.iscsi  ##分别给个别名 echo "InitiatorAlias=rs2" >> /etc/iscsi/initiatorname.iscsi echo "InitiatorAlias=rs3" >> /etc/iscsi/initiatorname.iscsi

3.1 启动iscsi,发现共享磁盘target

service iscsi start iscsiadm -m discovery -t sendtargets -p 172.16.1.14   ##发现target 172.16.1.14:3260,1 iqn.2012-11.me.laoguang.target:sda5

3.2 挂载(登录)共享磁盘

iscsiadm -m node -T  iqn.2012-11.me.laoguang.target:sda5 -p 172.16.1.14 -l -m 指定模式 man 一下 -t sendtargets 在discovery模式下使用 -p portal 指定target的IP与端口,如果是默认端口3260可省略 -l login  登录 -u logout 个为登出
fdisk -l   ##查看新磁盘我的是sda5

rs1,rs2,rs3同样登录

禁止它们开机启动

chkconfig iscsi off;chkconfig iscsid off

3.3 安装lvm2-cluster,让gfs2支持卷组

lvmconf --enable-cluster service clvmd start

3.4 rs1上对/data/sdb创建lvm卷组

pvcreate /dev/sdb vgcreate myvg /dev/sdb lvcreate -L 800M --name mydata myvg

查看其它节点中是否生成了lvm

ls /dev/myvg/mydata

3.5 rs1,rs2,rs3启动gfs2,在rs1中格式化gfs格式的磁盘

mkfs.gfs2 -p lock_dlm -t WebCluster:mylvm -j 3 /dev/myvg/mydata

3.6 rs1,rs2,rs3挂载/dev/myvg/mydata到/var/www/html中,建立测试文件

mount /dev/myvg/mydata /var/www/html echo "GFS Storage" > /var/www/html/index.html

rs1,rs2同时打开/var/www/html/index.html 查看是否有上锁警告

访问http://172.16.1.1查看是否能显示新主页

到此整个过程演示完毕,最后表示cman不好用啊,kill 掉ccsd重启服务,实在不行重启主机。记的不要让资源开机启动,比如iscsi,如要连接不上target,机器会等timeout后才会继续的。如果 有问题请留言。如果觉的不错就赞一下吧,写篇文档不容易啊,每个命令都是试过以后复制过来的,所以尽管实验。