一、前提:内核中需要配置bcache模块

1.1 检查

  - 是否存在于内核中:检查/sys/fs/bcache目录是否存在,没有说明内核中没有bcache

  - 是否以内核模块方式存在:检查/lib/modules/<$version>/kernel/drivers/md/bcache目录是否存,不存在则说明没有bcache内核模块

  - 以上两步检查完如果都没有,则说明内核中没有配置编译bcache,需要自己配置编译新的内核(下载内核时需要注意版本,bcache功能是在3.10及以上版本中才有)

1.2 编译新内核

$ wget "http://vault.centos.org/7.3.1611/os/Source/SPackages/kernel-3.10.0-514.el7.src.rpm"
$ rpm2cpio ./kernel-3.10.-.el7.src.rpm | cpio -idmv //提取rpm包内容,获取内核:linux-3.10.0-514.el7.tar.xz
$ make menuconfig     //内核配置
Device Drivers
->Multiple devices driver support (RAID and LVM)
-><*> Block device as cache
$ make bzImage (V=)     //编译内核
$ make modules        //编译内核模块
$ make modules_install //拷贝内核模块的.ko文件到/lib/modules下
$ make install //拷贝initrd和bzImage到boot目录下,并修改开机启动配置文件
$ reboot //重启,根据菜单选择对应内核版本进入

二、编译安装

//获取bcache-tools工具(以下两个网址任选其一)
$ git clone http://evilpiepirate.org/git/bcache-tools.git
$ git clone https://github.com/g2p/bcache-tools.git
//安装前需要两个依赖包pkg-config和libblkid-dev
$ yum -y install pkg-config libblkid-dev
//编译安装bcache-tools
$ make
$ make install

三、部署方式

3.1 创建bcache设备

$ make-bcache -C <cache-device> -B <backing device>
解释:make-bcache提供了同时初始化多个设备的功能,并自动绑定缓存设备和后端设备
参数: -B // 格式化backing device
-C // 格式化caching device
-w // block size(hard sector size of SSD),默认2K,也可使用 --block=4K设置。注意一般需要block size = (backing device的)扇区大小。
-b // bucket size,也可使用--bucket=1M设置。注意一般需要bucket size =(caching device的)erase block size大小。
结果:有几个backing device就会对应生成几个/dev/bcache设备
查看:用lsblk命令查看设备的对应关系
  
 

example: the default block and bucket sizes of 512B and 128kB are used. The block size should match the backing devices sector size which will usually be either 512 or 4k. The bucket size should match the erase block size of the caching device with the intent of reducing write amplification. For example, using a HDD with 4k sectors and an SSD with an erase block size of 2MB this command would look like

# make-bcache --block 4k --bucket 2m -C /dev/sdy

3.2 添加后端设备(backing device)

  - 1、创建后端设备

  $ make-bcache -B <backing-device>
  结果:生成对应的设备/dev/bcache<n>

  - 2、attach绑定后端设备

  $ ls -la /sys/fs/bcache        //查看cache set uuid
  $ echo <CSET-UUID> > /sys/block/bcache<n>/bcache/attach
  结果:attach之后,缓存设备就能够对新加的后端设备缓存数据了
  查看:用lsblk命令查看对应关系
  
 

3.3 删除后端设备

  - 1、detach解绑backing device设备

  $ ls -la /sys/fs/bcache/        //查看cache set uuid
  $ echo <CSET-UUID> > /sys/block/bcache<n>/bcache/detach
  结果:detach后端设备后,对应的bcache设备还是存在的,只不过这个bcache设备是无缓存的,查看其状态可以看到是no cache
  查看:用lsblk查看对应关系
  

  - 2、删除后端设备

  $ echo  > /sys/block/bcache<N>/bcache/stop
  解释:detach后端设备后,对应的bcache设备还存在,如果要删除,还需要stop该设备
  查看:用lsblk查看设备对应关系
  

3.4 添加缓存设备(caching device)

  -1、 创建缓存设备

  $ make-bcache -C <cache device>
  结果:在/sys/fs/bcache目录下生成对应的CACHE SET UUID
  注意:有可能设备本身有残余数据,需要使用wipefs清理掉
  $ wipefs -a /dev/sda

        

   -2、attach,与bcache设备关联

  $ echo <CSET-UUID> > /sys/block/bcache<n>/bcache/attach
  解释:通过后端设备attach缓存设备,cache device才能开始缓存,backing device才能被缓存

3.5 删除缓存设备

前提:确保没有backing device在使用它(可以通过lsblk查看)
解释: - cache设备的存在,可以通过/sys/fs/bcache目录对应的cache set uuid了解
    - unregister该uuid后这个cache设备就被视为删除了

$ echo  > /sys/fs/bcache/<cache set uuid>/unregister
结果:再看/sys/fs/bcache目录下就没有这个cache设备的uuid了

3.6 格式化bcache并挂载使用

$ mkfs.xfs /dev/bcache<n>            //格式化设备为xfs文件系统
$ mount /dev/bcache<n> /mnt   //挂载设备到/mnt目录进行访问

 四、使用操作

4.1 查看运行状态

$ cat /sys/block/bcache<n>/bcache/state
  • no cache:该backing device没有attach任何caching device(这意味着所有I / O都直接传递到backing device[pass-through mode])。
  • clean:everything is ok,缓存是干净的。
  • dirty:这意味着一切都设置正常,并且您已启用回写,缓存是脏的。
  • inconsistent:您遇到问题,因为后台设备与缓存设备不同步。

4.2 查看缓存的数据量

$ cat /sys/block/bcache<n>/bcache/dirty_data

4.3 查看/设置缓存模式

// 设置缓存模式(默认writethrough)
$ echo <cache mode> > /sys/block/bcache<N>/bcache/cache_mode
// 查看缓存模式
$ cat /sys/block/bcache<N>/bcache/cache_mode
[writethrough] writeback writearound none

4.4 打印device信息

$ bcache-super-show /dev/sd<n>

4.5 配置信息

  • backing device 在 /sys/block/bcache<n>/bcache/ 目录下
  • cache device 在 /sys/fs/bcache/<CSET-UUID>/ 目录下

  对/sys中配置信息的改变是暂时的,重启会失效。如果想要在启动时设置当前的配置,需要创建一个conf配置文件在/etc/tmpfile.d/中,例如 /etc/tmpfile.d/my-bcache.conf:

w /sys/block/bcache0/bcache/sequential_cutoff - - - - 1
w /sys/block/bcache0/bcache/cache_mode - - - - writeback
(To set, in a persistent fashion, the sequential cutoff for bcache0 to 1 MB and write back)


 五、参考资料

  •   http://bcache.evilpiepirate.org/
  •   http://lwn.net/Articles/550207/
  •   https://yq.aliyun.com/articles/60734
  •   http://blog.csdn.net/liumangxiong/article/details/18090043
  •   http://unix.stackexchange.com/questions/115764/how-to-remove-cache-device-from-bcache
  •   http://pommi.nethuis.nl/ssd-caching-using-linux-and-bcache/
  •   https://www.kernel.org/doc/Documentation/bcache.txt
  •   https://evilpiepirate.org/git/linux-bcache.git/tree/Documentation/bcache.txt#n126

  

bcache的使用的更多相关文章

  1. [archlinux][hardware] ThankPad T450自带SSD做bcache之后的使用寿命分析

    这个分析的起因,是由于我之前干了这两个事: [troubleshoot][archlinux][bcache] 修改linux文件系统 / 分区方案 / 做混合硬盘 / 系统转生大!手!术!(调整底层 ...

  2. [troubleshoot][archlinux][bcache] 修改linux文件系统 / 分区方案 / 做混合硬盘 / 系统转生大!手!术!(调整底层架构,不!重!装!)

    目标: 我要做的事情是:修改文件系统,硬盘分区方案,但是不重装系统,整个操作不被应用层感知. 背景: 我的笔记本 ThinkPad T450.8G内存 + 16GB SSD + 1TB HDD.预装w ...

  3. bcache 状态/配置 文件详细介绍

    什么是bcache bcache是linux内核块层cache.它使用类似SSD来作为HDD硬盘的cache,从而起到加速作用. HDD硬盘便宜并且空间更大,SSD速度快但更贵.如果能两者兼得,岂不快 ...

  4. linux块设备缓存bcache

    1 Bcache介绍Bcache是一种缓存技术,它是根据SSD的特性设计的,由于SSD的随机读写速度要比普通硬盘的随机读写快N多倍,但是一般SSD的容量小且贵,当然土豪除外,所以我们可以综合SSD的读 ...

  5. bcache 状态/配置 文件详细介绍(翻译自官网)

    声明: 文中 斜体带下划线  的段落为翻译不够准确的段落 原文:https://www.kernel.org/doc/Documentation/bcache.txt 官网:https://bcach ...

  6. 【linux】free命令中cached和buffers的区别

    一.命令 [root@localhost ~]# free -m total used free shared buffers cached Mem: 7869 7651 218 1 191 5081 ...

  7. Buffer和Cache的区别

  8. 安装samba服务器

    首先理解以下概念: ftp:在内网和公网使用. 服务器端支持:windows,linux 客户端端支持:windows,linux samba:只能在内网使用,类似于windows的网络邻居(文件共享 ...

  9. 传统高斯模糊与优化算法(附完整C++代码)

    高斯模糊(英语:Gaussian Blur),也叫高斯平滑,是在Adobe Photoshop.GIMP以及Paint.NET等图像处理软件中广泛使用的处理效果,通常用它来减少图像噪声以及降低细节层次 ...

随机推荐

  1. [知了堂学习笔记]_css3特效第一篇--旋转的背景&翻书效果

    一.html遮盖层与css3的旋转动画 >效果图(加载可能会慢一点儿,请稍等...): >实现思路:在一个大的div中装入一个底层img和顶层的div(里面的内容按照以上图片呈现的样式布局 ...

  2. C# 获取ListView中选中行中对应的列数据

    C# 获取ListView中选中行中对应的列数据 ) { ListView.SelectedIndexCollection c = MediaList.SelectedIndices; ]].SubI ...

  3. <script>元素在XHTML中的用法

    编写XHTML代码的规则要比编写HTML严格得多,例如如下代码: <script type="text/javascript"> function compare(a, ...

  4. Tomcat系统架构分析

    Tomcat系统架构分析 关于这边blog呢,实际开发中并不会用到,但是我觉得还是很有必要认真的写一下.毕竟我们每天在本地撸码的时候使用的就是tomcat来做web服务器.一个常识就是说我们本地在to ...

  5. 在Tomcat中实现基本的HTTP方式的验证

    .实现基本验证 (1)在C:\jakarta-tomcat-5.0.19\conf下的tomcat-users.xml文件中添加角色和用户(可以同时添加多个用户) <role rolename= ...

  6. j2e应用概述

    过年也过完了,现在正式开始进入j2e的整理.现在开篇第一篇,整理一下j2e应用和开发环境.j2e应用提供的跨平台性,开放性已经各种远程访问的技术,为异构系统的良好整合提供了保证.注意这个是有一个异构系 ...

  7. finally中关闭资源

    对finally中关闭资源是否还要使用try...catch老是感到迷惑,现在存个例子,省的忘了 public StringBuilder readTxtFile(File file){ String ...

  8. Spring中Quartz的配置及corn表达式

    Quartz可以用来执行任务调度功能,如间隔一定时间调用执行任务.用起来还是蛮方便的.只要将你要调用的类配置到Spring配置文件即可. 在Spring的配置文件中配置Quartz. <!-- ...

  9. Linux开机时停在 Starting sendmail 不动了的解决方案

    目前遇到这个问题,是在修改了/etc/hosts之后,但停止在Starting sendmail后5分钟就进去了.以后再长时间进入不了系统,可以参考下面的方法. 造成这个问题一般是因为用户修改了机器名 ...

  10. 【ASP.NET Core】MVC中自定义视图的查找位置

    .NET Core 的内容处处可见,刷爆全球各大社区,所以,老周相信各位大伙伴已经看得不少了,故而,老周不考虑一个个知识点地去写,那样会成为年度最大的屁话,何况官方文档也很详尽.老周主要扯一下大伙伴们 ...