From Fedora Project Wiki

 
(31 intermediate revisions by 3 users not shown)
Line 23: Line 23:


     1.1. Who should read this guide?
     1.1. Who should read this guide?
     1.2. Virtualization in Fedora Linux
     1.2. Virtualization in Fedora Linux <span style='color:red'>--> grundblom: This should be a more general statement, no technical products mentioned here, but directed to chapter 3 for more information.</span>
     1.3. Virtualization resources
     1.3. Virtualization resources


2. What is virtualization and migration?
2. General Overview of Virtualization


     2.1. What is virtualization?<span style='color:blue'> --> Lnovich ADD Here we need to add a section on "How a computer/server is virtualized - ie how it works? with a diagram. </span>
     2.1. What is Virtualization?
<span style='color:blue'>Add what a hypervisor is, what a host and guest are as this may be misunderstood.</span>
    2.2. What are the costs of Virtualization
    2.3. Performance factors of Virtualization
    2.4. Flexibility options of Virtualization
    2.5. Disaster Recovery options and scenarios of Virtualization<span style='color:red'>
    2.6. Security options and benefits of Virtualization
    2.7. Differences and commonalities of Virtualization for servers and individuals. grundblom: 2.6, and 2.7 need to be added</span>


    2.2. What is migration? <span style='color:blue'> --> Lnovich - consider moving this elsewhere </span> <span style='color:orange'>--> kirsti when moving this elsewhere, consider changing title 2. as well </span>
3. Introduction to Fedora virtualization products


        2.2.1. Benefits of migrating virtual machines
    3.1. KVM <span style='color:red'>--> grundblom:Lets just call this KVM </span>
    3.2. libvirt and tools <span style='color:red'>--> grundblom: Removed the "libvert tools" and shortened it </span>
    3.3. Boxes
    3.4  Containers <span style='color:red'>--> grundblom: I would like to mention something on how to use docker containers, or containers in general, but not a lot of detail here since there should be other guides, or more detailed resources eslewhere</span>


3. Advantages and misconceptions of virtualization


<span style='color:green'>--> smccann consider rewriting as Why use virtualization </span>
4. Introduction to Boxes <span style='color:orange'>--> kirsti only a separate chapter for boxes, not for the other products? </span> <span style='color:red'>--> grundblom: I agree we should have sections for each product we mentioned in 4 I volunteer to write a section on how to make a vm in kvm.</span>
<span style='color:orange'>--> kirsti or just Andvantages (misconceptions seems negative)</span>


     3.1. Virtualization costs
     4.1. Features of Boxes
     3.2. Virtualization learning curve <span style='color:orange'>--> kirsti suggestion to skip this </span>
     4.2. How do I create a virtual machine in Boxes?
     3.3. Performance
     4.3. How do I connect to other computers in Boxes?
     3.4. Flexibility
     4.4. How do I change the settings of a machine in boxes?
     3.5. Disaster recovery
     4.5. How do I delete a box?
     3.6. Security
     4.6. Boxes Tips and Tricks
    4.7. Advanced Commands in Boxes


        3.6.1. Virtualization security features<span style='color:orange'>--> kirsti suggestion to make this 3.6 </span>
5. Creating and Managing Guests with Virt-Manager
 
    3.7. Virtualization for servers and individuals
 
4. Introduction to Fedora virtualization products
 
    4.1. KVM and virtualization in Fedora <span style='color:orange'>--> kirsti suggestion to just call it KVM? (since the fedora is mentioned in the main title </span>
    4.2. libvirt and libvirt tools
    4.3. Boxes
    4.4. Storage
 
        4.4.1. Storage pools
        4.4.2. Storage volumes
 
5. Introduction to Boxes <span style='color:orange'>--> kirsti only a separate chapter for boxes, not for the other products? </span>
 
    5.1. Features of Boxes
    5.2. How do I create a virtual machine in Boxes?
    5.3. How do I connect to other computers in Boxes?
    5.4. How do I change the settings of a machine in boxes?
    5.5. How do I move a Virtual Machine between computers?
    5.6. How do I delete a box?
    5.7. Boxes Tips and Tricks
    5.8. Advanced Commands in Boxes
 
6. Creating and Managing Guests with Virt-Manager
<span style='color:green'>--> smccann work toward common topic titles w/ Boxer chapter - should be covering same information </span>
<span style='color:green'>--> smccann work toward common topic titles w/ Boxer chapter - should be covering same information </span>


     6.1. System Requirements
     5.1. System Requirements
     6.2. Installing Virtualization package groups
     5.2. Installing Virtualization package groups
     6.3. Network Support
     5.3. Network Support
     6.4. Creating guests with virt-manager
     5.4. Creating guests with virt-manager


A. Advanced Virtualization Concepts
A. Advanced Virtualization Concepts
Line 88: Line 70:
         A.1.3. Physical host devices
         A.1.3. Physical host devices
         A.1.4. CPU models
         A.1.4. CPU models
        A 1.5. Storage <span style='color:red'>--> grundblom: Took storage pools and added them here since its more of a definition/concept then in the detailed part of libvir</spam>
        A    1.5.1. Storage pools
          A  1.5.2. Storage volumes


     A.2. guestfish
     A.2. guestfish
     A.3. Other useful tools
     A.3. Other useful tools
<span style='color:orange'>--> kirsti is it an idea to add a few dos and do nots, as in what would make good use cases for virtualization, and what not?  </span>


B. Revision History
B. Revision History


=Changes to Content=
=Changes to Content=
Line 102: Line 87:
! Chapter/Section !! Link/URL !! Change Needed !! Who is requesting the Change !! Approved !! BZ Link
! Chapter/Section !! Link/URL !! Change Needed !! Who is requesting the Change !! Approved !! BZ Link
|-
|-
| preface, 2 || http://docs.fedoraproject.org/en-US/Fedora/19/html/Virtualization_Getting_Started_Guide/pr01s02.html || now referring to fedora 19, in the new version, which fedora will we be writing for? ||Kirsti ||  ||  
 
|Ch 1 || http://docs.fedoraproject.org/en-US/Fedora/22/html/Virtualization_Getting_Started_Guide/chap-Virtualization_Getting_Started-Introduction.html || "The Fedora Virtualization Getting Started Guide introduces the basics of virtualization and assists with the navigation of other virtualization documentation and products that Fedora provides. This guide also explains the advantages of virtualization and dispels some common myths that exist regarding virtualization." leave out the second part (going with leaving out the misconceptions). First sentence could read "The Fedora Virtualization Getting Started Guide introduces the basics, and advantages of virtualization; and assists with the navigation of other virtualization documentation, and products that Fedora provides." (adding Oxford comma). || Kirsti ||  ||
|-
|ch2.1 ||http://docs.fedoraproject.org/en-US/Fedora/22/html/Virtualization_Getting_Started_Guide/chap-Virtualization_Getting_Started-What_Is_It.html||Missing link in the note to Fedora Virtualization Deployment and Administration Guide||Kirsti||  ||
|-
|ch2.2||http://docs.fedoraproject.org/en-US/Fedora/22/html/Virtualization_Getting_Started_Guide/sec-migration.html|| under live migration is a reference to fedora 19."In Fedora 19, shared storage is not necessary for storing guest images to be migrated." Does this still apply to fed 22?||Kirsti||  ||
|-
|-
|Ch 1 || http://docs.fedoraproject.org/en-US/Fedora/19/html/Virtualization_Getting_Started_Guide/chap-Virtualization_Getting_Started-Introduction.html ||  "The Fedora Virtualization Getting Started Guide introduces the basics of virtualization and assists with the navigation of other virtualization documentation and products that Fedora provides.
|ch 3 || http://docs.fedoraproject.org/en-US/Fedora/22/html/Virtualization_Getting_Started_Guide/chap-Virtualization_Getting_Started-Advantages.html||when we decide to go without the misconceptions, we need to rephrase the first two paragraphs, willing to make the attempt. The chapter as a whole, with all the explanations would make a poor business case, I would not be able to use it to convince a manager to go Virtual||Kirsti||  ||
This guide also explains the advantages of virtualization and dispels some common myths that exist regarding virtualization." leave out the second part (going with leaving out the misconceptions). Firts sentence couls read "The Fedora Virtualization Getting Started Guide introduces the basics, and advantages of virtualization, and assists with the navigation of other virtualization documentation, and products that Fedora provides." (adding oxford comma) || Kirsti ||  ||
|-
|ch3.3||http://docs.fedoraproject.org/en-US/Fedora/22/html/Virtualization_Getting_Started_Guide/ch03s03.html||This chapter takes it from a misconception point of view. Searching the web I cannot come up easily with a good description, but is there a place in the admin manual where this subject is better explained? Could we work with something like: "While virtualization can speed processing up, it doesn't just magically make things better. Without the right architecture and tuning, virtualization will not deliver performance benefits." and then add a link to how to implement virtualization?||Kirsti||  ||
|-
|ch3.4||http://docs.fedoraproject.org/en-US/Fedora/22/html/Virtualization_Getting_Started_Guide/ch03s04.html||Is this all we can say about flexibility? nothing about expanding or decreasing the number of machines in your network, easy test environment set-up without using up massive amounts of resources, easy to install when using images...||Kirsti||  ||
|-
|-
|}
|}
Random thoughts and things I have been looking into. Is this going anywhere usefull?
Still reading up on a lot of things...
---------------------------------------------------
==Proposal CH2 what I have now (WIP):==
2. General Overview of Virtualization
'''What is Virtualization?'''
Virtualization is a broad computing term used for running software, usually multiple operating systems, concurrently and isolated.
'''How Does Virtualization work?'''
* Most existing implementations of virtualization use a hypervisor. The hypervisor allows multiple operating systems, called guests, to run on the same physical system by offering virtualized hardware to the guest operating system.
'''2.1 Virtualization methods'''
''Full virtualization''
* Full virtualization uses the hardware features of the processor to provide guests with total abstraction of the underlying physical system. This creates a new virtual system, called a virtual machine, that allows guest operating systems to run without modifications. The guest operating system and any applications on the guest virtual machine are unaware of their virtualized environment and run normally. Hardware-assisted virtualization is the technique used for full virtualization with KVM (Kernel-based Virtual Machine) in Fedora.
''Para-virtualization''
* Para-virtualization employs a collection of software and data structures that are presented to the virtualized guest, requiring software modifications in the guest to use the para-virtualized environment. Para-virtualization can encompass the entire kernel, as is the case for Xen para-virtualized guests, or drivers that virtualize I/O devices.
''Software virtualization (or emulation)''
* Software virtualization uses slower binary translation and other emulation techniques to run unmodified operating systems.
''Note''
For more information and detailed instructions on guest installation, refer to the Fedora Virtualization Deployment and Administration Guide. /*add link when possible
'''2.2. Virtualization Considerations'''
Before you consider to virtualize your environment it is important to perform a Return on Investment (ROI) analysis to determine the best use of virtualization in your environment.
Consider the following benefits:
''* Smaller footprint''
Using virtualization negates much of the need for multiple physical platforms. Consolidating servers onto fewer machines means less physical space is required. This equates to less power being drawn for machine operation and cooling, resulting in reduced energy costs. This means more efficient energy resource management for your data centre.
 
''* Less maintenance''
Provided adequate planning is performed before migrating physical systems to virtualized ones, less time is spent maintaining them. This means less money being spent on various resources.
''* Extended life for installed software''
Older versions of software may not run on newer, bare metal machines directly. However, by running the older software virtually on a larger, faster system, the life of the software may be extended while taking advantage of the  performance from the newer system.
'''2.3. Performance'''
Modern servers are delivered with multiple CPU as a standard. This has significantly changed the possibilities with VMs.
Depending on what you would like to use your VM for, and how many CPUs are available, you can now set up a VM with multiple CPUs.
As discussed in the chapter about use cases for setting up a VM, all of these uses will have their own system requirements.
'''2.4. Flexibility'''
* Virtualization provides greater flexibility for managing systems.
Virtual machines can be copied or moved to test software updates and validate configuration changes, without impacting other systems. Because each of the virtualized systems are completely separate to each other, one system's downtime will not affect any others.
With separate virtualized systems you can use any hardware available, and install the OS needed for the function. There is no verndor lock-in.
Since less space is needed in a data centre to put up the production environment, it is easier to create extra space for development and testing environments. Both are easily set up and discarded.
Having a more felixible environment, makes it easier to provide secure redundancy planning; and with easy access to a test machine, more stable systems can be built up.
With the fast changing market, a virtual configuration will provide a flexible, stable environment, with which a business can quickly adapt, to stay on top of the competition.
'''2.5. Disaster Recovery'''
* Disaster Recovery is generally easier:
Disaster recovery has become part of the business plan. In case of IT, besides having a stable an efficient production environment, a place where this environment can be moved to is desired.
To make sure the business loses as little time as possible to set up this shadow environment, virtualization might prove to be the best choice.
Even when the production environment is still on hardware, disaster recovery is quicker and easier when the systems are virtualized.
On a physical system, if something serious goes wrong, a complete re-install of the operating system is usually required, resulting in hours of recovery time.
However, when a clone or snapshot of the system is stored as a backup, this can be used a fast and reliable set-up of a virtual machine.
A virtual machine is not depended on specific hardware, this makes any server suitable to recover your machines on.
In the case of using a clone, you will only have the set up of the machine available. The longest delay would then be in restoring guest data.
When using a snapshot, the data as was when last made will be available immediately.
==Kristi Other Thoughts on Virt getting started==
------------------------------------------------------------------
General thoughts on how users could read documentation. Realizing this might come close to the personas that are being defined.
* As an advisor or manager with no technical background, I would probably only read the chapter Virtualization 101. Because here I can find the basis for a business case, to which company specific calculations and graphs can be added.
(decision makers love graphs!)
* As a technical project manager I will go over all of the documentation, and might ask some specialists (about the security aspect for example)for further details. This is a good starting point to base a project plan on, in which a business case is included, but also the planning; what do we use it for? what is needed in hardware & software resources? what are the risks (and how do we solve this)?  what does the architecture look like? how much time do I need? and how many people, with which skills? Looking at the guide as it is, I think all of that is covered.
* As a sysadmin I might start with the Chapter on How to install a Virtual machine. Now here we have some of the personas already defined.
Each would look for their own use-case; server, network, application, desktop. By adding a short list of these cases, with normal hardware spec, and possible links to where these cases are explained; and a short explanation of why only a simple set-up is explained in this chapter (I read this as a desktop setup, going with the choices for the use of one core and the amount of memory), this is a good stand alone chapter, very hands on.

Latest revision as of 00:44, 11 April 2016

Outline for Getting Started

Current TOC

This TOC should be changed -please indicate what needs changing in a different color or with an arrow. Please put your name in the line that has the change so we can track it. Thanks!



Preface

   1. Document Conventions
       1.1. Typographic Conventions
       1.2. Pull-quote Conventions
       1.3. Notes and Warnings
   2. We Need Feedback!

1. Introduction

   1.1. Who should read this guide?
   1.2. Virtualization in Fedora Linux --> grundblom: This should be a more general statement, no technical products mentioned here, but directed to chapter 3 for more information.
   1.3. Virtualization resources

2. General Overview of Virtualization

   2.1. What is Virtualization?
   2.2. What are the costs of Virtualization
   2.3. Performance factors of Virtualization
   2.4. Flexibility options of Virtualization
   2.5. Disaster Recovery options and scenarios of Virtualization
   2.6. Security options and benefits of Virtualization
   2.7. Differences and commonalities of Virtualization for servers and individuals. grundblom: 2.6, and 2.7 need to be added

3. Introduction to Fedora virtualization products

   3.1. KVM --> grundblom:Lets just call this KVM 
   3.2. libvirt and tools --> grundblom: Removed the "libvert tools" and shortened it 
   3.3. Boxes
   3.4  Containers --> grundblom: I would like to mention something on how to use docker containers, or containers in general, but not a lot of detail here since there should be other guides, or more detailed resources eslewhere


4. Introduction to Boxes --> kirsti only a separate chapter for boxes, not for the other products? --> grundblom: I agree we should have sections for each product we mentioned in 4 I volunteer to write a section on how to make a vm in kvm.

   4.1. Features of Boxes
   4.2. How do I create a virtual machine in Boxes?
   4.3. How do I connect to other computers in Boxes?
   4.4. How do I change the settings of a machine in boxes?
   4.5. How do I delete a box?
   4.6. Boxes Tips and Tricks
   4.7. Advanced Commands in Boxes

5. Creating and Managing Guests with Virt-Manager --> smccann work toward common topic titles w/ Boxer chapter - should be covering same information

   5.1. System Requirements
   5.2. Installing Virtualization package groups
   5.3. Network Support
   5.4. Creating guests with virt-manager

A. Advanced Virtualization Concepts --> kirsti would this be a place to make a pointer to containers?

   A.1. Virtualized hardware devices
       A.1.1. Virtualized and emulated devices
       A.1.2. Para-virtualized devices
       A.1.3. Physical host devices
       A.1.4. CPU models
       A 1.5. Storage --> grundblom: Took storage pools and added them here since its more of a definition/concept then in the detailed part of libvir</spam>
        A    1.5.1. Storage pools
         A   1.5.2. Storage volumes
   A.2. guestfish
   A.3. Other useful tools
--> kirsti is it an idea to add a few dos and do nots, as in what would make good use cases for virtualization, and what not?  

B. Revision History

Changes to Content

Here you can list specific changes you would like to see made. In each instance please include some information that will help us find the location of the issue

Changes that are needed in the Getting Started Guide
Chapter/Section Link/URL Change Needed Who is requesting the Change Approved BZ Link
Ch 1 http://docs.fedoraproject.org/en-US/Fedora/22/html/Virtualization_Getting_Started_Guide/chap-Virtualization_Getting_Started-Introduction.html "The Fedora Virtualization Getting Started Guide introduces the basics of virtualization and assists with the navigation of other virtualization documentation and products that Fedora provides. This guide also explains the advantages of virtualization and dispels some common myths that exist regarding virtualization." leave out the second part (going with leaving out the misconceptions). First sentence could read "The Fedora Virtualization Getting Started Guide introduces the basics, and advantages of virtualization; and assists with the navigation of other virtualization documentation, and products that Fedora provides." (adding Oxford comma). Kirsti
ch2.1 http://docs.fedoraproject.org/en-US/Fedora/22/html/Virtualization_Getting_Started_Guide/chap-Virtualization_Getting_Started-What_Is_It.html Missing link in the note to Fedora Virtualization Deployment and Administration Guide Kirsti
ch2.2 http://docs.fedoraproject.org/en-US/Fedora/22/html/Virtualization_Getting_Started_Guide/sec-migration.html under live migration is a reference to fedora 19."In Fedora 19, shared storage is not necessary for storing guest images to be migrated." Does this still apply to fed 22? Kirsti
ch 3 http://docs.fedoraproject.org/en-US/Fedora/22/html/Virtualization_Getting_Started_Guide/chap-Virtualization_Getting_Started-Advantages.html when we decide to go without the misconceptions, we need to rephrase the first two paragraphs, willing to make the attempt. The chapter as a whole, with all the explanations would make a poor business case, I would not be able to use it to convince a manager to go Virtual Kirsti
ch3.3 http://docs.fedoraproject.org/en-US/Fedora/22/html/Virtualization_Getting_Started_Guide/ch03s03.html This chapter takes it from a misconception point of view. Searching the web I cannot come up easily with a good description, but is there a place in the admin manual where this subject is better explained? Could we work with something like: "While virtualization can speed processing up, it doesn't just magically make things better. Without the right architecture and tuning, virtualization will not deliver performance benefits." and then add a link to how to implement virtualization? Kirsti
ch3.4 http://docs.fedoraproject.org/en-US/Fedora/22/html/Virtualization_Getting_Started_Guide/ch03s04.html Is this all we can say about flexibility? nothing about expanding or decreasing the number of machines in your network, easy test environment set-up without using up massive amounts of resources, easy to install when using images... Kirsti

Random thoughts and things I have been looking into. Is this going anywhere usefull? Still reading up on a lot of things...


Proposal CH2 what I have now (WIP):

2. General Overview of Virtualization What is Virtualization?

Virtualization is a broad computing term used for running software, usually multiple operating systems, concurrently and isolated.

How Does Virtualization work?

  • Most existing implementations of virtualization use a hypervisor. The hypervisor allows multiple operating systems, called guests, to run on the same physical system by offering virtualized hardware to the guest operating system.


2.1 Virtualization methods

Full virtualization

  • Full virtualization uses the hardware features of the processor to provide guests with total abstraction of the underlying physical system. This creates a new virtual system, called a virtual machine, that allows guest operating systems to run without modifications. The guest operating system and any applications on the guest virtual machine are unaware of their virtualized environment and run normally. Hardware-assisted virtualization is the technique used for full virtualization with KVM (Kernel-based Virtual Machine) in Fedora.

Para-virtualization

  • Para-virtualization employs a collection of software and data structures that are presented to the virtualized guest, requiring software modifications in the guest to use the para-virtualized environment. Para-virtualization can encompass the entire kernel, as is the case for Xen para-virtualized guests, or drivers that virtualize I/O devices.

Software virtualization (or emulation)

  • Software virtualization uses slower binary translation and other emulation techniques to run unmodified operating systems.

Note For more information and detailed instructions on guest installation, refer to the Fedora Virtualization Deployment and Administration Guide. /*add link when possible

2.2. Virtualization Considerations Before you consider to virtualize your environment it is important to perform a Return on Investment (ROI) analysis to determine the best use of virtualization in your environment. Consider the following benefits:

* Smaller footprint Using virtualization negates much of the need for multiple physical platforms. Consolidating servers onto fewer machines means less physical space is required. This equates to less power being drawn for machine operation and cooling, resulting in reduced energy costs. This means more efficient energy resource management for your data centre.

* Less maintenance Provided adequate planning is performed before migrating physical systems to virtualized ones, less time is spent maintaining them. This means less money being spent on various resources.

* Extended life for installed software Older versions of software may not run on newer, bare metal machines directly. However, by running the older software virtually on a larger, faster system, the life of the software may be extended while taking advantage of the performance from the newer system.

2.3. Performance Modern servers are delivered with multiple CPU as a standard. This has significantly changed the possibilities with VMs. Depending on what you would like to use your VM for, and how many CPUs are available, you can now set up a VM with multiple CPUs. As discussed in the chapter about use cases for setting up a VM, all of these uses will have their own system requirements.

2.4. Flexibility

  • Virtualization provides greater flexibility for managing systems.

Virtual machines can be copied or moved to test software updates and validate configuration changes, without impacting other systems. Because each of the virtualized systems are completely separate to each other, one system's downtime will not affect any others. With separate virtualized systems you can use any hardware available, and install the OS needed for the function. There is no verndor lock-in.

Since less space is needed in a data centre to put up the production environment, it is easier to create extra space for development and testing environments. Both are easily set up and discarded. Having a more felixible environment, makes it easier to provide secure redundancy planning; and with easy access to a test machine, more stable systems can be built up.

With the fast changing market, a virtual configuration will provide a flexible, stable environment, with which a business can quickly adapt, to stay on top of the competition.


2.5. Disaster Recovery

  • Disaster Recovery is generally easier:

Disaster recovery has become part of the business plan. In case of IT, besides having a stable an efficient production environment, a place where this environment can be moved to is desired. To make sure the business loses as little time as possible to set up this shadow environment, virtualization might prove to be the best choice.

Even when the production environment is still on hardware, disaster recovery is quicker and easier when the systems are virtualized. On a physical system, if something serious goes wrong, a complete re-install of the operating system is usually required, resulting in hours of recovery time. However, when a clone or snapshot of the system is stored as a backup, this can be used a fast and reliable set-up of a virtual machine. A virtual machine is not depended on specific hardware, this makes any server suitable to recover your machines on.

In the case of using a clone, you will only have the set up of the machine available. The longest delay would then be in restoring guest data. When using a snapshot, the data as was when last made will be available immediately.

Kristi Other Thoughts on Virt getting started


General thoughts on how users could read documentation. Realizing this might come close to the personas that are being defined.

  • As an advisor or manager with no technical background, I would probably only read the chapter Virtualization 101. Because here I can find the basis for a business case, to which company specific calculations and graphs can be added.

(decision makers love graphs!)

  • As a technical project manager I will go over all of the documentation, and might ask some specialists (about the security aspect for example)for further details. This is a good starting point to base a project plan on, in which a business case is included, but also the planning; what do we use it for? what is needed in hardware & software resources? what are the risks (and how do we solve this)? what does the architecture look like? how much time do I need? and how many people, with which skills? Looking at the guide as it is, I think all of that is covered.
  • As a sysadmin I might start with the Chapter on How to install a Virtual machine. Now here we have some of the personas already defined.

Each would look for their own use-case; server, network, application, desktop. By adding a short list of these cases, with normal hardware spec, and possible links to where these cases are explained; and a short explanation of why only a simple set-up is explained in this chapter (I read this as a desktop setup, going with the choices for the use of one core and the amount of memory), this is a good stand alone chapter, very hands on.