文档章节

ceph技巧总结(一)

加油2018
 加油2018
发布于 2014/11/04 16:11
字数 1546
阅读 531
收藏 5

1. ceph rbd在线resize

扩容前

[root@mon0 ceph]# rbd create myrbd/rbd1 -s 1024 --image-format=2
[root@mon0 ceph]# rbd ls myrbd
rbd1
[root@mon0 ceph]# rbd info myrbd/rbd1
rbd image 'rbd1':
	size 1024 MB in 256 objects
	order 22 (4096 kB objects)
	block_name_prefix: rbd_data.12ce6b8b4567
	format: 2
	features: layering

扩容

[root@mon0 ceph]# rbd resize myrbd/rbd1 -s 2048
Resizing image: 100% complete...done.
在rbd1未格式化和挂载之前,直接resize就可以了。如果rbd1已经格式化并挂载了,需要一些额外的操作:
[root@mon0 ceph]# rbd map myrbd/rbd1
[root@mon0 ceph]# rbd showmapped
id pool  image    snap device    
0  test  test.img -    /dev/rbd0 
1  myrbd rbd1     -    /dev/rbd1 
[root@mon0 ceph]# mkfs.xfs /dev/rbd1
log stripe unit (4194304 bytes) is too large (maximum is 256KiB)
log stripe unit adjusted to 32KiB
meta-data=/dev/rbd1              isize=256    agcount=9, agsize=64512 blks
         =                       sectsz=512   attr=2, projid32bit=0
data     =                       bsize=4096   blocks=524288, imaxpct=25
         =                       sunit=1024   swidth=1024 blks
naming   =version 2              bsize=4096   ascii-ci=0
log      =internal log           bsize=4096   blocks=2560, version=2
         =                       sectsz=512   sunit=8 blks, lazy-count=1
realtime =none                   extsz=4096   blocks=0, rtextents=0
[root@mon0 ceph]# mount /dev/rbd1 /mnt
[root@mon0 ceph]# df -h
Filesystem      Size  Used Avail Use% Mounted on
/dev/sda1       529G   20G  482G   4% /
tmpfs            16G  408K   16G   1% /dev/shm
/dev/sdb        559G   33G  527G   6% /openstack
/dev/sdc        1.9T   75M  1.9T   1% /cephmp1
/dev/sdd        1.9T   61M  1.9T   1% /cephmp2
/dev/rbd1       2.0G   33M  2.0G   2% /mnt
[root@mon0 ceph]# rbd resize myrbd/rbd1 -s 4096
Resizing image: 100% complete...done.
[root@mon0 ceph]# df -h
Filesystem      Size  Used Avail Use% Mounted on
/dev/sda1       529G   20G  482G   4% /
tmpfs            16G  408K   16G   1% /dev/shm
/dev/sdb        559G   33G  527G   6% /openstack
/dev/sdc        1.9T   75M  1.9T   1% /cephmp1
/dev/sdd        1.9T   61M  1.9T   1% /cephmp2
/dev/rbd1       2.0G   33M  2.0G   2% /mnt
[root@mon0 ceph]# xfs_growfs /mnt
meta-data=/dev/rbd1              isize=256    agcount=9, agsize=64512 blks
         =                       sectsz=512   attr=2, projid32bit=0
data     =                       bsize=4096   blocks=524288, imaxpct=25
         =                       sunit=1024   swidth=1024 blks
naming   =version 2              bsize=4096   ascii-ci=0
log      =internal               bsize=4096   blocks=2560, version=2
         =                       sectsz=512   sunit=8 blks, lazy-count=1
realtime =none                   extsz=4096   blocks=0, rtextents=0
data blocks changed from 524288 to 1048576
[root@mon0 ceph]# df -h
Filesystem      Size  Used Avail Use% Mounted on
/dev/sda1       529G   20G  482G   4% /
tmpfs            16G  408K   16G   1% /dev/shm
/dev/sdb        559G   33G  527G   6% /openstack
/dev/sdc        1.9T   75M  1.9T   1% /cephmp1
/dev/sdd        1.9T   61M  1.9T   1% /cephmp2
/dev/rbd1       4.0G   33M  4.0G   1% /mnt
还有一种情况是,rbd1已经被挂载到一个vm上:
virsh domblklist myvm
rbd resize myrbd/rbd1
#这里需要通过virsh blockresize进行操作
virsh blockresize --domain myvm --path vdb --size 100G
rbd info myrbd/rbd1

2. 利用ceph-deploy

利用ceph-deploy安装ceph非常简单,可以在安装后根据需要调整ceph.conf。

mkdir ceph-deploy; cd ceph-deploy
ceph-deploy install $cluster
ceph-deploy new cephnode-01 cephnode-02 cephnode-03
ceph-deploy --overwrite-conf mon create cephnode-01 cephnode-02 cephnode-03
ceph-deploy gatherkeys cephnode-01
ceph-deploy osd create \
    cephnode-01:/dev/sdb:/dev/sda5 \
    cephnode-01:/dev/sdc:/dev/sda6 \
    cephnode-01:/dev/sdd:/dev/sda7 \
    cephnode-02:/dev/sdb:/dev/sda5 \
    cephnode-02:/dev/sdc:/dev/sda6 \
    cephnode-02:/dev/sdd:/dev/sda7 \
    cephnode-03:/dev/sdb:/dev/sda5 \
    cephnode-03:/dev/sdc:/dev/sda6 \
    cephnode-03:/dev/sdd:/dev/sda7 \
    cephnode-04:/dev/sdb:/dev/sda5 \
    cephnode-04:/dev/sdc:/dev/sda6 \
    cephnode-04:/dev/sdd:/dev/sda7 \
    cephnode-05:/dev/sdb:/dev/sda5 \
    cephnode-05:/dev/sdc:/dev/sda6 \
    cephnode-05:/dev/sdd:/dev/sda7
利用ceph-deploy进行卸载:
ceph-deploy purgedata $cluster
ceph-deploy purge $cluster

for host in $cluster
  do
    ssh $host <<EOF
      sudo dd if=/dev/zero of=/dev/sdb bs=1M count=100
      sudo dd if=/dev/zero of=/dev/sdc bs=1M count=100
      sudo dd if=/dev/zero of=/dev/sdd bs=1M count=100
      sudo sgdisk -g --clear /dev/sdb
      sudo sgdisk -g --clear /dev/sdc
      sudo sgdisk -g --clear /dev/sdd
    EOF
  done

3. 删除rbd前先删除相应快照

rbd snap ls myrbd/rbd1
SNAPID NAME       SIZE 
    10 snap1 102400 KB 
    12 snap2 102400 KB 
rbd snap purge myrbd/rbd1
Removing all snapshots: 100% complete...done.
rbd rm myrbd/rbd1
Removing image: 100% complete...done.

4. 测试rbd snap

创建并挂载rbd1:

[root@mon0 ceph]# rbd create myrbd/rbd1 -s 1024 --image-format=2
[root@mon0 ceph]# rbd map myrbd/rbd1
[root@mon0 ceph]# rbd showmapped
id pool  image    snap device    
0  test  test.img -    /dev/rbd0 
1  myrbd rbd1     -    /dev/rbd1 
[root@mon0 ceph]# mkfs.xfs /dev/rbd1
log stripe unit (4194304 bytes) is too large (maximum is 256KiB)
log stripe unit adjusted to 32KiB
meta-data=/dev/rbd1              isize=256    agcount=9, agsize=31744 blks
         =                       sectsz=512   attr=2, projid32bit=0
data     =                       bsize=4096   blocks=262144, imaxpct=25
         =                       sunit=1024   swidth=1024 blks
naming   =version 2              bsize=4096   ascii-ci=0
log      =internal log           bsize=4096   blocks=2560, version=2
         =                       sectsz=512   sunit=8 blks, lazy-count=1
realtime =none                   extsz=4096   blocks=0, rtextents=0
[root@mon0 ceph]# blkid|grep rbd1
/dev/rbd1: UUID="643b509f-406b-411b-b3a5-fa220fbdfe47" TYPE="xfs" 
[root@mon0 ceph]# mount /dev/rbd1 /mnt
[root@mon0 ceph]# mount | grep rbd1
/dev/rbd1 on /mnt type xfs (rw)
创建snap并回滚:
[root@mon0 ceph]# rbd snap ls myrbd/rbd1
SNAPID NAME     SIZE 
     2 snap1 1024 MB 
[root@mon0 ceph]# rbd snap rollback myrbd/rbd1@snap1
Rolling back to snapshot: 100% complete...done.
[root@mon0 ceph]# ls /mnt
v2
[root@mon0 ceph]# umount /mnt
[root@mon0 ceph]# mount /dev/rbd1 /mnt
[root@mon0 ceph]# ls /mnt
v1
通过快照挂载:
[root@mon0 ceph]# rbd map myrbd/rbd1@snap1
[root@mon0 ceph]# rbd showmapped
id pool  image    snap  device    
0  test  test.img -     /dev/rbd0 
1  myrbd rbd1     -     /dev/rbd1 
2  myrbd rbd1     snap1 /dev/rbd2 

[root@mon0 ceph]# mount -t xfs -o ro,norecovery,nouuid /dev/rbd2 /tmp
[root@mon0 ceph]# ls /tmp
v1

5. 定位文件位置

利用rados put上传并利用map查看文件

[root@osd2 software]# md5sum epel-release-6-8.noarch.rpm 
2cd0ae668a585a14e07c2ea4f264d79b  epel-release-6-8.noarch.rpm
[root@osd2 software]# rados put -p myrbd epel.rpm ./epel-release-6-8.noarch.rpm 
[root@osd2 software]# ceph osd map myrbd epel.rpm
osdmap e88 pool 'myrbd' (4) object 'epel.rpm' -> pg 4.e9ddf5be (4.be) -> up ([4,2], p4) acting ([4,2], p4)
查看所在位置并验证:
[root@osd2 software]# ceph osd tree
# id	weight	type name	up/down	reweight
-1	10.92	root default
-2	3.64		host mon0
0	1.82			osd.0	up	1	
1	1.82			osd.1	up	1	
-3	3.64		host osd1
2	1.82			osd.2	up	1	
3	1.82			osd.3	up	1	
-4	3.64		host osd2
4	1.82			osd.4	up	1	
5	1.82			osd.5	up	1	
[root@osd2 software]# cd /cephmp1/current/4.be_head/
[root@osd2 4.be_head]# ls
epel.rpm__head_E9DDF5BE__4
[root@osd2 4.be_head]# md5sum epel.rpm__head_E9DDF5BE__4 
2cd0ae668a585a14e07c2ea4f264d79b  epel.rpm__head_E9DDF5BE__4
[root@osd2 4.be_head]# ll -h
total 20K
-rw-r--r--. 1 root root 15K Nov  4 17:59 epel.rpm__head_E9DDF5BE__4
利用rbd input上传后进行验证:
[root@osd2 software]# touch hello.txt
[root@osd2 software]# echo "hello world" >> hello.txt
[root@osd2 software]# rbd import ./hello.txt myrbd/hello.txt
Importing image: 100% complete...done.
[root@osd2 software]# rbd info myrbd/hello.txt
rbd image 'hello.txt':
	size 12 bytes in 1 objects
	order 22 (4096 kB objects)
	block_name_prefix: rb.0.1365.6b8b4567
	format: 1
[root@osd2 software]# rados ls -p myrbd
rbd_data.13446b8b4567.00000000000000ba
rbd_directory
rbd_data.13446b8b4567.000000000000007d
rbd_data.13446b8b4567.000000000000007c
rbd_data.13446b8b4567.000000000000005d
rbd_data.13446b8b4567.000000000000007e
rbd_data.13446b8b4567.00000000000000ff
rb.0.1365.6b8b4567.000000000000
hello.txt.rbd
rbd_data.13446b8b4567.00000000000000d9
rbd_data.13446b8b4567.00000000000000f8
rbd_data.13446b8b4567.000000000000009b
rbd_data.13446b8b4567.0000000000000001
rbd_header.13446b8b4567
epel.rpm
rbd_data.13446b8b4567.000000000000001f
rbd_data.13446b8b4567.000000000000003e
rbd_id.rbd1
rbd_data.13446b8b4567.0000000000000000

#这样得到的位置信息是错误的
[root@osd2 software]# ceph osd map myrbd hello.txt
osdmap e88 pool 'myrbd' (4) object 'hello.txt' -> pg 4.d92fd82b (4.2b) -> up ([4,3], p4) acting ([4,3], p4)

#需要加上.rbd
[root@osd2 current]# ceph osd map myrbd hello.txt.rbd
osdmap e88 pool 'myrbd' (4) object 'hello.txt.rbd' -> pg 4.9b9bf373 (4.73) -> up ([3,1], p3) acting ([3,1], p3)
[root@osd2 current]# ssh osd1
[root@osd1 ~]# cd /cephmp2/current/4.73_head/
[root@osd1 4.73_head]# ll -h
total 8.0K
-rw-r--r-- 1 root root 112 Nov  4 18:08 hello.txt.rbd__head_9B9BF373__4
[root@osd1 4.73_head]# cat hello.txt.rbd__head_9B9BF373__4 
<<< Rados Block Device Image >>>
rb.0.1365.6b8b4567RBD001.005

#如果是普通的rbd块,format-1类型的rbd块:
#ceph osd map test test.img.rbd
#format-2类型的rbd块:
#ceph osd map test rbd_id.test.img

© 著作权归作者所有

下一篇: iscsi、nfs与ceph
加油2018
粉丝 150
博文 276
码字总数 246145
作品 0
海淀
架构师
私信 提问
快速构建ceph可视化监控系统

前言 ceph的可视化方案很多,本篇介绍的是比较简单的一种方式,并且对包都进行了二次封装,所以能够在极短的时间内构建出一个可视化的监控系统 本系统组件如下: ceph-jewel版本 ceph_expor...

万建宁
2018/07/19
220
0
利用ceph-deploy在ubuntu server14.04上部署ceph并进行其它配置

环境与说明 在ubuntu14.04 server上部署ceph-0.87;设置rbdmap自动挂载/卸载rbd块设备;利用带rbd支持的tgt导出iscsi的rbd块。 2. 安装ceph 1)配置hostname与无密码登录 root@mon0:/etc/cep...

加油2018
2014/11/11
4.7K
16
Installation【快速安装】

Installation【快速安装】 第1步:预检 在部署Ceph分布式存储集群,Ceph客户端和Ceph的节点之前,可能需要一些基本的配置工作。您还可以利用在Ceph的社区帮助文件的“入门”中获取帮助。 Pr...

天空冰雨
2015/03/25
125
0
苦尽甘来——Ceph中国社区2016

作者 | 孙琦 耿航校对 2016年12月11日,北京万寿宾馆,Ceph中国社区迎来了2016年最后一场活动,这是第一次、也是唯一一次全天的活动,到下午会议结束的一刻,整个会场仍然是满坑满谷,这也大...

Devin
2016/12/20
0
0
ceph0.80安装及使用(CentOS7/ceph-deploy)

Ceph的主要目标是设计成基于POSIX的没有单点故障的分布式文件系统,使数据能容错和无缝的复制。详见:http://www.oschina.net/p/ceph 目前大部分部署ceph基本都是在Ubuntu,因为它的内核默认...

fkkeee
2014/09/22
6.5K
4

没有更多内容

加载失败,请刷新页面

加载更多

每天AC系列(一):三数之和

1 题目 LeetCode第15题,难度中等,题目描述: 给定一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?找出所有满足条件且不重复的三元组。 注意:答...

Blueeeeeee
42分钟前
56
0
OSChina 周四乱弹 —— 水果你们都没吃全

Osc乱弹歌单(2020)请戳(这里) 【今日歌曲】 @ 莱布妮子:分享五月天的单曲《温柔》@小小编辑 @cIouddyy @clouddyy 《温柔》- 五月天 手机党少年们想听歌,请使劲儿戳(这里) @FalconChe...

小小编辑
今天
99
1
聚合支付网站被黑客攻击 导致数据库被篡改的防御办法

2020春节即将来临,收到新聚合支付平台网站客户的求助电话给我们Sinesafe,反映支付订单状态被修改由原先未支付修改为已支付,导致商户那边直接发货给此订单会员了,商户和平台的损失较大,很多码...

网站安全
昨天
63
0
MySQL-基于SELECT查询的UPDATE查询

我需要检查(从同一张表)基于日期时间的两个事件之间是否存在关联。 一组数据将包含某些事件的结束日期时间,另一组数据将包含其他事件的开始日期时间。 如果第一个事件在第二个事件之前完成...

javail
昨天
70
0
将PostgreSQL数据库复制到另一台服务器

我正在将生产PostgreSQL数据库复制到开发服务器。 什么是最快,最简单的方法? #1楼 pg_dump the_db_name > the_backup.sql 然后将备份复制到您的开发服务器,并使用以下命令进行还原: ps...

技术盛宴
昨天
130
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部