From Fedora Project Wiki

Warning: You are not logged in. Your IP address will be publicly visible if you make any edits. If you log in or create an account, your edits will be attributed to your username, along with other benefits.

The edit can be undone. Please check the comparison below to verify that this is what you want to do, and then publish the changes below to finish undoing the edit.

Latest revision Your text
Line 9: Line 9:
| fedora_mailing_list = test
| fedora_mailing_list = test
}}
}}
{{admon/warning | In construction | The Test Day page is yet in construction. It will be ready for the Test Day - when this message is removed :) .}}


{{admon/note | Can't make the date? | If you come to this page before or after the test day is completed, your testing is still valuable, and you can use the information on this page to test, file any bugs you find at [http://bugzilla.redhat.com Bugzilla], and add your results to the results section. If this page is more than a month old when you arrive here, please check the [[QA/Test_Days|current schedule]] and see if a similar but more recent Test Day is planned or has already happened.}}
{{admon/note | Can't make the date? | If you come to this page before or after the test day is completed, your testing is still valuable, and you can use the information on this page to test, file any bugs you find at [http://bugzilla.redhat.com Bugzilla], and add your results to the results section. If this page is more than a month old when you arrive here, please check the [[QA/Test_Days|current schedule]] and see if a similar but more recent Test Day is planned or has already happened.}}
Line 14: Line 16:
== What to test? ==
== What to test? ==


Today's instalment of Fedora Test Day will focus on SSD Caching in Fedora 20, specifically bcache. SSD Caching allows you to speedup your disk access by combining your slow HDD with a fast SSD. The SSD will be used to store copies of frequently accessed blocks on your HDD, so you'll experience a good performance while also having the large storage capacity of your HDD.
Today's instalment of Fedora Test Day will focus on bcache based SSD Caching in Fedora 20. Although dm-cache is another SSD caching implementation, today we'll only focus on the bcache implementation.
 
Although dm-cache is another SSD caching implementation, today we'll only focus on the bcache implementation.


=== General test objective ===
=== General test objective ===
Line 28: Line 28:
The bcache implementation of SSD caching is a new feature (since kernel 3.9) and should be considered experimental. The focus of this Test day is to evaluate the alignment of bcache-tools with other relevant Fedora packages to support a good basis for experimenting with SSD caching:
The bcache implementation of SSD caching is a new feature (since kernel 3.9) and should be considered experimental. The focus of this Test day is to evaluate the alignment of bcache-tools with other relevant Fedora packages to support a good basis for experimenting with SSD caching:


* bcache-tools (version 0-0.14.20130909git or later)
* bcache-tools (version 0-0.12.20130909git or later)
* util-linux (version 2.24-0.1 or later)
* util-linux (version 2.24-0.1 or later)
* dracut (version 034 or later)
* dracut (version 033-1 or later)
* lvm2 (version 2.02.102-1 or later)
* lvm2 (version 2.02.102-1 or later)
* kernel (version 3.9 or later)
* kernel (version 3.9 or later)
Line 41: Line 41:


The following cast of characters will be available testing, workarounds, bug fixes, and general discussion ...
The following cast of characters will be available testing, workarounds, bug fixes, and general discussion ...
* Development - Kent Overstreet (py1hon)
* Development - TBD
* Quality Assurance - [[User:ignatenkobrain|Igor Gnatenko]] (ignatenkobrain), [[User:rolffokkens|Rolf Fokkens]] (rolffokkens)
* Quality Assurance - [[User:ignatenkobrain|Igor Gnatenko]] (ignatenkobrain), [[User:rolffokkens|Rolf Fokkens]] (rolffokkens)


== External documentation ==
== Prerequisite for Test Day ==  
You can find some relevant documentation at bcache.evilpiepirate.org[[http://bcache.evilpiepirate.org/]].
 
== Prerequisites for the Test Day ==  
 
=== Limitations ===
There's no "easy way" yet to convert an existing filesystem to a bcache based filesystem: bcache is an additional block layer that writes its own superblock on the underlying block devices. There is a blocks [[https://github.com/g2p/blocks]] tool under development, but for now the only solution is to backup your data some where, recreate your filesystem on a bcache device, and then restore the data.
 
Another limitation is the fact that bcache is EXPERIMENTAL. Although it works really well in general, you should be careful to store important data on it.


=== Physical or Virtual ===
=== Physical or Virtual ===
Line 67: Line 59:
   * internet connection
   * internet connection


* bootable media containg (one of):
* bootable media containg Rawhide/F20 (?) netinst (?) image.
[http://dl.fedoraproject.org/pub/alt/stage/20-Beta-TC2/Fedora/x86_64/iso/Fedora-20-Beta-TC2-x86_64-DVD.iso Fedora 20 Beta TC2 x86_64 DVD]
 
=== Other requirements ===
* Knowledge on how to build physical or virtual machines
* Knowledge how to use the Linux command line (There's no graphical installer yet)
* A desire to break software
 
=== Further reading ===
 
Here's a chunk which is commonly used for most Test Days. Replace XX with whatever Fedora release is pending:
 
* An updated [http://fedoraproject.org/get-prerelease Fedora 20 pre-release], [[Releases/Rawhide|Rawhide]] (tips on installing Rawhide below), or a [http://alt.fedoraproject.org/pub/alt/nightly-composes/desktop/ nightly live image]
 
== How to test? ==
Because Anaconda does not support bcache yet, the test may be executed following certain steps: preparation and test case 1 to test case 3. The end result will be a F20 system running its root filesystem on bcache. These steps are merely suggestions, to allow testing in limited time. Of course testers are free to choose other ways of testing. As a suggestion, testers can focus on the following criteria:
 
* Are your 'bcached' filesystems automatically operational after a reboot?
* Are your 'bcached' filesystems automatically operational after a kernel update?
 
Each demonstrates the proper allignment of dracut, util-linux, lvm2 (when used), bcache-tools and the kernel.


[http://dl.fedoraproject.org/pub/alt/stage/20-Beta-TC2/Fedora/x86_64/iso/Fedora-20-Beta-TC2-i386-DVD.iso Fedora 20 Beta TC2 i386 DVD]
=== Preparation: install F20 ===


Because doing updates (particularly the kernel) is part of the test, it's best not to install latest and greatest.
The first step is to do a minimal install:
 
* this is the fastest install
* it also saves time when copying the root filesystem during later test cases
* it allows to install other packages later (yum groupinstall) as part of the test activities.


=== Disk partitioning ===
To prepare for the test cases, it is important to use the following partitioning:
To prepare for the test cases, it is important to use the following partitioning:


Line 81: Line 94:
   sda2 2GB    /home
   sda2 2GB    /home
   sda3 2GB    /
   sda3 2GB    /
   sda4 (>4G)  free space (only used when testing in combination with LVM)
   sda4 (>4G)  free space
    
    
   sdb:
   sdb:
   sdb1 >2GB  (caching device)
   sdb1 >2GB  (caching device)


sda is (or models) the rotational disk device, sdb is (or models) the solid state disk device. It would be best to have sdb (on) a true SSD, but if you don't have an SSD then an ordinary disk will do as well for the testing (except for performance testing)
When using a VM sda may be vda and sdb may be vdb.


When using a VM sda may and sdb may be read as vda and vdb.
Both the partitioning and the installation of Fedora can be done by any of the iso's in https://dl.fedoraproject.org/pub/alt/stage/, e.g. Fedora-20-Alpha-x86_64-netinst.iso.


=== SElinux ===
== Test Cases ==
Please disable SElinux. There's some copying involved in the testcases, and SElinux may break the testcases when the copied data is not accessible.


To disable SElinux you should edit your /etc/selinux/config and set SELINUX=permissive instead of SELINUX=enforcing.
=== Test case 1.A: /home on bcache (no LVM)===


=== Other requirements ===
Once your fresh Fedora 20 system is running, we will "move" /home to a bcache device. To do this it's convenient to have a minimum amount of data on /home. Do the following steps:
* Knowledge on how to build physical or virtual machines
* Knowledge on how to use the Linux command line (There's no graphical installer yet)
* A desire to break software


== How to test? ==
* yum install bcache-tools
Because Anaconda does not support bcache yet, the test may be executed following certain steps: preparation and test case 1 to test case 3. The end result will be a F20 system running its root filesystem on bcache. These steps are merely suggestions, to allow testing in limited time. Of course testers are free to choose other ways of testing. As a suggestion, testers can focus on the following criteria:
* If needed "backup" all data in /home to another place on your root filesystem
* comment /home out in your /etc/fstab
* unmount /home (which is on /dev/sda2)
* Make /dev/sda2 a bcache backing device: make-bcache -B /dev/sda2
* Make /dev/sdb1 a bcache caching device: make-bcache -C /dev/sdb1
* Note the set uuid and attach /dev/sdb1 to /dev/sda2: echo <set uuid> > /sys/block/bcache0/bcache/attach


* Do the tools to create / manage bcache operate as expected?
Now you have a bcache device: /dev/bcache0
* Are your 'bcached' filesystems automatically operational after a reboot?
* use "bcache-status -s" to see details about your bcache device.
* Are your 'bcached' filesystems automatically operational after a kernel update?
* create a filesystem: mkfs -t ext4 -L HOME /dev/bcache0
* create a /home entry in your /etc/fstab: LABEL=HOME /home ext4 defaults 1 2
* mount /home: mount -a
* If needed restore the /home backup you made earlier.


Each demonstrates the proper allignment of dracut, util-linux, lvm2 (when used), bcache-tools and the kernel.
Now you have a system with /home on bcache.
* reboot your system to see if it boots OK.
* do some other testing if you like. Limit the amount of data on /home or accept that it gets lost in the following steps.


=== Preparation: install F20 ===
=== Test case 1.B: / on bcache (no LVM) ===


The first step is to do a minimal install:
==== step 1: / on bcache with fallback  ====
Now we have a stable system with /home on bcache, we can go forward and have / on bcache. Consider thought that bcache is EXPERIMENTAL!


* this is the fastest install
To get / on bcache we'll stop using /home on bcache first:
* it also saves time when copying the root filesystem during later test cases
* if needed make a bachup of /home on your root filesystem.
* it allows to install other packages later (yum groupinstall) as part of the test activities.
* comment /home out in your /etc/fstab
* umount /home
* if needed restore your bachup to the /home directory


Use bootable media containg
Now your /home is in your root filesystem. Next:
[http://dl.fedoraproject.org/pub/alt/stage/20-Beta-TC2/Fedora/x86_64/iso/Fedora-20-Beta-TC2-x86_64-DVD.iso Fedora 20 Beta TC2 x86_64 DVD]
* create a new filesystem on /dev/bcache0: mkfs -t ext4 -L ROOTFS /dev/bcache0
[http://dl.fedoraproject.org/pub/alt/stage/20-Beta-TC2/Fedora/x86_64/iso/Fedora-20-Beta-TC2-i386-DVD.iso Fedora 20 Beta TC2 i386 DVD]
* mount it: mount /dev/bcache0 /mnt
[http://dl.fedoraproject.org/pub/alt/stage/20-Beta-TC2/Fedora/x86_64/iso/Fedora-20-Beta-TC2-x86_64-netinst.iso Fedora 20 Beta TC2 x86_64 netinstall]
* copy your current root filesystem to /mnt: cp -ax / /mnt
[http://dl.fedoraproject.org/pub/alt/stage/20-Beta-TC2/Fedora/x86_64/iso/Fedora-20-Beta-TC2-x86_64-netinst.iso Fedora 20 Beta TC2 i386 netinstall] to install Fedora 20. This does not contain the most recent packages, so lateron <code>yum update</code> can be used as a test.
* edit /mnt/fstab so your root fs is mounted like: LABEL=ROOTFS / ext4 defaults 1 1


== Test Cases ==
Now we have a duplicate root filesystem on /dev/bcache0. To use it we need to build a new initramfs:
* rename your current initramfs: mv /boot/initramfs...img /boot/initramfs...img.sav
* create a new initramfs: dracut -N


=== Test case 1.A: /home on bcache (no LVM)===
Now reboot your system. Edit your default grub entry:
* replace the root=UUID=... parameter in the "linux" line by: root=LABEL=ROOTFS
* boot it.


Once your fresh Fedora 20 system is running, we will "move" /home to a bcache device without using LVM.
If all goes well, your system now boots fine and it's running on bcache!
* Edit your /etc/grub2.cfg file..
* .. duplicate the first "menuentry ... { ...}" (about 15 lines).
* Now change the first one and replace the root=UUID=... parameter in the "linux" line by root=LABEL=ROOTFS
* reboot again


Step by step instructions are available on [[QA:Testcase_bcache-tools_home_on_bcache_(no_LVM)|this page]]
Now your system should boot fine.


=== Test case 1.B: / on bcache (no LVM) ===
==== step 2: / on bcache no fallback ====
Now we have a stable system with /home on bcache, we can go forward and have / on bcache without using LVM.


Step by step instructions are available on [[QA:Testcase_bcache-tools_root_on_bcache_(no_LVM)|this page]].
Now your system boots fine you can drop the fallback root filesystem. Consider though that bcache is EXPERIMENTAL and a fallback may be important.


=== Test case 2.A: /home on bcache (LVM)===
=== Test case 2.A: /home on bcache (LVM)===


Once your fresh Fedora 20 system is running, we will "move" /home to a Logical Volume (LVM) on a bcache device. Because of the flexibility that LVM provides the approach is quite different from page 1.A, for example we'll start by using sda4!
Once your fresh Fedora 20 system is running, we will "move" /home to a Logical Volume (LVM) on a bcache device. Because of the flexibility that LVM provides the approach is quite different from page 1.A, for example we'll start by using sda4! Do the following steps:


Step by step instructions are available on [[QA:Testcase_bcache-tools_home_on_bcache_(LVM)|this page]]
* yum install bcache-tools lvm2
* Make /dev/sda4 a bcache backing device: make-bcache -B /dev/sda4
* Make /dev/sdb1 a bcache caching device: make-bcache -C /dev/sdb1
* Note the set uuid and attach /dev/sdb1 to /dev/sda2: echo <set uuid> > /sys/block/bcache0/bcache/attach


=== Test case 2.B: / on bcache (LVM) ===
Now you have a bcache device: /dev/bcache0
* use "bcache-status -s" to see details about your bcache device.
* create a Physical Volume: pvcreate /dev/bcache0
* create a Volume Group: vgcreate BCACHE /dev/bcache0
* create a Logical Volume: lvcreate -L 2G -n HOME BCACHE
* create a filesystem: mkfs -t ext4 -L HOME /dev/BCACHE/HOME
This will be our new /home device. To use it first move the current /home to another mount point:
* replace /home entry in your /etc/fstab: LABEL=HOME /home ext4 defaults 1 2
* mkdir /home.old
* umount /home
* mount /dev/sda2 /home.old
* mount /home
* cp -ax /home.old/* /home
* umount /home.old


Now we have a stable system with /home on LVM on bcache, we can go forward and have / on bcache.
* build a new initramfs with dracut???
 
Now you have a system with /home on LVM2 on bcache.
* reboot your system to see if it boots OK.
* do some other testing if you like.
 
=== Test case 2.B: / on bcache (no LVM) ===
 
==== step 1: / on bcache with fallback  ====
Now we have a stable system with /home on LVM on bcache, we can go forward and have / on bcache. Consider thought that bcache is EXPERIMENTAL!
 
To get / on bcache:
* create a Logical Volume: lvcreate -L 2G -n ROOTFS BCACHE
* create a filesystem: mkfs -t ext4 -L ROOTFS /dev/BCACHE/ROOTFS
* mount it: mount /dev/BCACHE/ROOTFS /mnt
* copy your current root filesystem to /mnt: cp -ax / /mnt
* edit /mnt/fstab so your root fs is mounted like: LABEL=ROOTFS / ext4 defaults 1 1
 
Now we have a duplicate root filesystem on /dev/BCACHE/ROOTFS. To use it we need to build a new initramfs:
* rename your current initramfs: mv /boot/initramfs...img /boot/initramfs...img.sav
* create a new initramfs: dracut -N
 
Now reboot your system. Edit your default grub entry:
* replace the root=UUID=... parameter in the "linux" line by: root=LABEL=ROOTFS
* remove any rd.lvm=0 occurrence
* boot it.
 
If all goes well, your system now boots fine and it's running on bcache!
* Edit your /etc/grub2.cfg file..
* .. duplicate the first "menuentry ... { ...}" (about 15 lines).
* Now change the first one and replace the root=UUID=... parameter in the "linux" line by root=LABEL=ROOTFS
* reboot again
 
Now your system should boot fine.


Step by step instructions are available on [[QA:Testcase_bcache-tools_root_on_bcache_(LVM)|this page]]


== Participants ==
== Participants ==
Line 154: Line 231:
! IRC nickname
! IRC nickname
|-
|-
| Kent Overstreet
| [[User:rolffokkens|Rolf Fokkens]]
| py1hon
| rolffokkens
|-
|-
| [[User:ignatenkobrain|Igor Gnatenko]]
| [[User:ignatenkobrain|Igor Gnatenko]]
| ignatenkobrain
| ignatenkobrain
|-
| [[User:rolffokkens|Rolf Fokkens]]
| rolffokkens
|-
|-
|}
|}
Line 167: Line 241:
== Test Results ==
== Test Results ==


<!-- metadata: https://fedoraproject.org/wiki/User:Jskladan/Sandbox:F20SSDCacheTestday
Construct a table or list to allow testers to post results. Each column should be a test case or configuration, and each row should consist of test results. Include some instructions on how to report bugs, and any special instructions. Here's an example, from a Palimpsest test day:
    To update the results tool, put the metadata url in the following form and submit: http://testdays.qa.fedoraproject.org/testdays/admin/update_testday
 
'''We are tracking test results in a web application [http://testdays.qa.fedoraproject.org/testdays/show_event?event_id=8 over here]'''
 
Results from this web application will be automatically transferred to the Wiki a week after the test day, and the reporting system will be shutdown. Feel free to continue testing and filling the wiki even after this date.
 
Should you encounter any problem while using the web application, please contact jskladan on #fedora-qa channel at freenode, or send an email to jskladan@fedoraproject.org
-->
 


If you have problems with any of the tests, report a bug to [https://bugzilla.redhat.com Bugzilla] usually for the component [https://bugzilla.redhat.com/enter_bug.cgi?product=Fedora&version=13&component=bcache-tools bcache-tools]. If you are unsure about exactly how to file the report or what other information to include, just ask on IRC and we will help you. Once you have completed the tests, add your results to the Results table below, following the example results from the first line as a template. The first column should be your name with a link to your User page in the Wiki if you have one. For each test case, use the [[Template:result|result template]] to enter your result, as shown in the example result line.
If you have problems with any of the tests, report a bug to [https://bugzilla.redhat.com Bugzilla] usually for the component [https://bugzilla.redhat.com/enter_bug.cgi?product=Fedora&version=13&component=bcache-tools bcache-tools]. If you are unsure about exactly how to file the report or what other information to include, just ask on IRC and we will help you. Once you have completed the tests, add your results to the Results table below, following the example results from the first line as a template. The first column should be your name with a link to your User page in the Wiki if you have one. For each test case, use the [[Template:result|result template]] to enter your result, as shown in the example result line.
Line 183: Line 248:
! User
! User
! [[QA:Testcase_bcache-tools_home_on_bcache_(no_LVM)|/home on bcache (no LVM)]]
! [[QA:Testcase_bcache-tools_home_on_bcache_(no_LVM)|/home on bcache (no LVM)]]
! [[QA:Testcase_bcache-tools_root_on_bcache_(no_LVM)|/ on bcache (no LVM)]]
! [[QA:Testcase_sample_2|Sample test 2]]
! [[QA:Testcase_bcache-tools_home_on_bcache_(LVM)|/home on bcache (LVM)]]
! [[QA:Testcase_bcache-tools_home_on_bcache_(no_LVM)|/home on bcache (LVM)]]
! [[QA:Testcase_bcache-tools_root_on_bcache_(LVM)|/ on bcache (LVM)]]
! [[QA:Testcase_sample_4|Sample test 4]]
! References
! References
|-
|-
| [[User:werkman|werkman]]
| [[User:SampleUser|Sample User]]
| {{result|pass}}
| {{result|none}}  
| {{result|none}}
| {{result|pass}}
| {{result|none}}
| {{result|warn}} <ref>Test pass, but also encountered {{bz|54321}}</ref>
| {{result|none}}
| {{result|fail}} <ref>{{bz|12345}}</ref>
| <references/>
|-
| [[User:ambush|PAVLEG]]
| {{result|warn}}<ref>Test pass, but nothing works. {{bz|1018615}}</ref>
| {{result|none}}
| {{result|none}}
| {{result|none}}
| <references/>
|-
| [[User:roshi|roshi]]
| {{result|warn||1018615}}
| {{result|warn}} <ref>Hit this bug with wget {{bz|1018615}}</ref>
| {{result|none}}
| {{result|none}}
| <references/>
| <references/>
|-
|-
|}
|}


=== Mock tests (optional) ===
[[Category:Test Days]] [[Category:Fedora 20 Test Days]]
 
{|
! User
! [[QA:Testcase_bcache-tools_mock_on_bcache_(no_LVM)|mock on bcache (no LVM)]]
! References
|-
| [[User:Sampleuser|Sample User]]
| {{result|inprogress}}
| <references/>
|-
|}
 
 
[[Category:Fedora 20 Test Days]]
Please note that all contributions to Fedora Project Wiki are considered to be released under the Attribution-Share Alike 4.0 International (see Fedora Project Wiki:Copyrights for details). If you do not want your writing to be edited mercilessly and redistributed at will, then do not submit it here.
You are also promising us that you wrote this yourself, or copied it from a public domain or similar free resource. Do not submit copyrighted work without permission!

To edit this page, please solve the following task below and enter the answer in the box (more info):

Cancel Editing help (opens in new window)