ceph中rbd块的使用技巧有哪些
发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,这篇文章将为大家详细讲解有关ceph中rbd块的使用技巧有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1. rbd块的真实大小由于ceph采用thin pro
千家信息网最后更新 2025年02月03日ceph中rbd块的使用技巧有哪些
这篇文章将为大家详细讲解有关ceph中rbd块的使用技巧有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
1. rbd块的真实大小
由于ceph采用thin provisioning,只有写数据时才会分配相应的块。所以当我们创建一个很大的块时,也是瞬间完成的,因为除了一些元数据外,ceph并没有分配出相应的空间。那么我们创建的rbd块到底有多大呢?以我的环境为例:
[root@osd1 /]# rbd ls myrbdhello.txtrbd1[root@osd1 /]# rbd info myrbd/rbd1rbd image 'rbd1': size 1024 MB in 256 objects order 22 (4096 kB objects) block_name_prefix: rbd_data.13446b8b4567 format: 2 features: layering[root@osd1 /]# rbd diff myrbd/rbd1 | awk '{ SUM += $2 } END { print SUM/1024/1024 " MB" }'14.2812 MB[root@osd1 /]# rbd diff myrbd/rbd1Offset Length Type 0 131072 data 4194304 16384 data 130023424 16384 data 260046848 16384 data 390070272 16384 data 520093696 4194304 data 524288000 4194304 data 528482304 2129920 data 650117120 16384 data 780140544 16384 data 910163968 16384 data 1040187392 16384 data 1069547520 4194304 data
2. rbd format1与rbd fromat2
rbd format1:
[root@osd1 /]# rbd create myrbd/rbd1 -s 8[root@osd1 /]# rbd info myrbd/rbd1rbd image 'rbd1': size 8192 kB in 2 objects order 22 (4096 kB objects) block_name_prefix: rb.0.13fb.6b8b4567 format: 1[root@osd1 /]# rados ls -p myrbdrbd_directoryrbd1.rbd[root@osd1 /]# rbd map myrbd/rbd1[root@osd1 /]# rbd showmappedid pool image snap device 0 myrbd rbd1 - /dev/rbd0 [root@osd1 /]# dd if=/dev/zero of=/dev/rbd0 dd: writing to `/dev/rbd0': No space left on device16385+0 records in16384+0 records out8388608 bytes (8.4 MB) copied, 2.25155 s, 3.7 MB/s[root@osd1 /]# rados ls -p myrbdrbd_directoryrbd1.rbdrb.0.13fb.6b8b4567.000000000001rb.0.13fb.6b8b4567.000000000000
$image_name.rbd : 包含了这个块的id (rb.0.13fb.6b8b4567)
$rbd_id.$fragment : 数据块
rbd_directory :当前pool中rbd块的列表
rbd format2
[root@osd1 /]# rbd create myrbd/rbd1 -s 8 --image-format=2[root@osd1 /]# rbd info myrbd/rbd1rbd image 'rbd1': size 8192 kB in 2 objects order 22 (4096 kB objects) block_name_prefix: rbd_data.13436b8b4567 format: 2 features: layering[root@osd1 /]# rados ls -p myrbdrbd_directoryrbd_header.13436b8b4567rbd_id.rbd1[root@osd1 /]# rbd map myrbd/rbd1[root@osd1 /]# rbd showmappedid pool image snap device 0 myrbd rbd1 - /dev/rbd0 [root@osd1 /]# dd if=/dev/zero of=/dev/rbd0dd: writing to `/dev/rbd0': No space left on device16385+0 records in16384+0 records out8388608 bytes (8.4 MB) copied, 2.14407 s, 3.9 MB/s[root@osd1 /]# rados ls -p myrbdrbd_directoryrbd_data.13436b8b4567.0000000000000000rbd_data.13436b8b4567.0000000000000001rbd_header.13436b8b4567rbd_id.rbd1
rbd_data.$rbd_id.$fragment :数据块
rbd_directory : 当前pool中rbd块的列表
rbd_header.$rbd_id : rbd块的元数据
rbd_id.$image_name : 包含了这个块的id ( 13436b8b4567 )
3. Ceph Primary Affinity
[root@mon0 yum.repos.d]# ceph --admin-daemon /var/run/ceph/ceph-mon.*.asok config show | grep 'primary_affinity' "mon_osd_allow_primary_affinity": "false",#在ceph.conf中加入primary affinitymon osd allow primary affinity = true[root@mon0 yum.repos.d]# ceph pg dump | grep active+clean | egrep "\[0," | wc -ldumped all in format plain109[root@mon0 yum.repos.d]# ceph pg dump | grep active+clean | egrep ",0\]" | wc -ldumped all in format plain123# ceph osd primary-affinity osd.0 0.5set osd.0 primary-affinity to 0.5 (8327682)# ceph pg dump | grep active+clean | egrep "\[0," | wc -l48# ceph pg dump | grep active+clean | egrep ",0\]" | wc -l132# ceph osd primary-affinity osd.0 0set osd.0 primary-affinity to 0 (802)# ceph pg dump | grep active+clean | egrep "\[0," | wc -l0# ceph pg dump | grep active+clean | egrep ",0\]" | wc -l180
4. 升级ceph
29号ceph放出了0.87 giant版本,我们第一时间进行了升级。升级过程非常简单,只需修改一处ceph.repo,然后yum update ceph就可以了。升级完成后重启各种服务。ceph.repo如下:
[root@mon0 software]# cat /etc/yum.repos.d/ceph.repo[Ceph]name=Ceph packages for $basearchgpgkey=https://ceph.com/git/?p=ceph.git;a=blob_plain;f=keys/release.ascenabled=1baseurl=http://ceph.com/rpm-giant/el6/$basearchpriority=1gpgcheck=1type=rpm-md[ceph-source]name=Ceph source packagesgpgkey=https://ceph.com/git/?p=ceph.git;a=blob_plain;f=keys/release.ascenabled=1baseurl=http://ceph.com/rpm-giant/el6/SRPMSpriority=1gpgcheck=1type=rpm-md[Ceph-noarch]name=Ceph noarch packagesgpgkey=https://ceph.com/git/?p=ceph.git;a=blob_plain;f=keys/release.ascenabled=1baseurl=http://ceph.com/rpm-giant/el6/noarchpriority=1gpgcheck=1type=rpm-m
5. ceph admin socket
利用ceph admin socket可以获得ceph的在线参数,对于验证与调试很有帮助。
$ ceph --admin-daemon /path/to/your/ceph/socket[root@osd2 ~]# ceph --admin-daemon /var/run/ceph/ceph-osd.4.asok help{ "config diff": "dump diff of current config and default config", "config get": "config get: get the config value", "config set": "config set [ ...]: set a config variable", "config show": "dump current config settings", "dump_blacklist": "dump blacklisted clients and times", "dump_historic_ops": "show slowest recent ops", "dump_op_pq_state": "dump op priority queue state", "dump_ops_in_flight": "show the ops currently in flight", "dump_reservations": "show recovery reservations", "dump_watchers": "show clients which have active watches, and on which objects", "flush_journal": "flush the journal to permanent store", "get_command_descriptions": "list available commands", "getomap": "output entire object map", "git_version": "get git sha1", "help": "list available commands", "injectdataerr": "inject data error into omap", "injectmdataerr": "inject metadata error", "log dump": "dump recent log entries to log file", "log flush": "flush log entries to log file", "log reopen": "reopen log file", "objecter_requests": "show in-progress osd requests", "perf dump": "dump perfcounters value", "perf schema": "dump perfcounters schema", "rmomapkey": "remove omap key", "setomapheader": "set omap header", "setomapval": "set omap key", "status": "high-level status of OSD", "truncobj": "truncate object to length", "version": "get ceph version"}
获取journal相关的参数设置:
[root@osd2 ~]# ceph --admin-daemon /var/run/ceph/ceph-mon.osd2.asok config show | grep journal "debug_journaler": "0\/5", "debug_journal": "1\/3", "journaler_allow_split_entries": "true", "journaler_write_head_interval": "15", "journaler_prefetch_periods": "10", "journaler_prezero_periods": "5", "journaler_batch_interval": "0.001", "journaler_batch_max": "0", "mds_kill_journal_at": "0", "mds_kill_journal_expire_at": "0", "mds_kill_journal_replay_at": "0", "mds_journal_format": "1", "osd_journal": "\/var\/lib\/ceph\/osd\/ceph-osd2\/journal", "osd_journal_size": "5120", "filestore_fsync_flushes_journal_data": "false", "filestore_journal_parallel": "false", "filestore_journal_writeahead": "false", "filestore_journal_trailing": "false", "journal_dio": "true", "journal_aio": "true", "journal_force_aio": "false", "journal_max_corrupt_search": "10485760", "journal_block_align": "true", "journal_write_header_frequency": "0", "journal_max_write_bytes": "10485760", "journal_max_write_entries": "100", "journal_queue_max_ops": "300", "journal_queue_max_bytes": "33554432", "journal_align_min_size": "65536", "journal_replay_from": "0", "journal_zero_on_create": "false", "journal_ignore_corruption": "false",
关于"ceph中rbd块的使用技巧有哪些"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
数据
升级
篇文章
使用技巧
技巧
参数
更多
分配
帮助
不错
实用
很大
内容
只有
只需
大小
文章
版本
环境
知识
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
嵌入式软件开发区万达
广东无限软件开发
安徽hp服务器阵列卡安装
服务器能修改网络密码吗
如何重启戴尔服务器
计算机监控软件开发
新乡软件开发税务筹划怎么做
网络安全包括的5个基本因素
绵阳软件开发有哪些公司
汽车电子软件开发工资怎么样
虹膜识别数据库
数据库越过第一条记录
牛牛数据库是干嘛的
哈利波特同一兑换码不同服务器
我的世界创建游戏无法连接服务器
php将图片传到数据库
安卓软件开发工具中文版
小游戏软件开发过程
龙门软件开发
停车场服务器软件
扑克约局软件开发
网络安全文章演讲
dell服务器前置面板
衡阳联通服务器
数据库百分比排序问题
天龙八部所有服务器
长治市网络安全支队地址
领星互联网科技怎么样
oracle数据库分区
网络安全工程师免费课程