RETIRED, Fuel plugin for ScaleIO storage backend integration
Go to file
OpenDev Sysadmins 9cb2bc17ac OpenDev Migration Patch
This commit was bulk generated and pushed by the OpenDev sysadmins
as a part of the Git hosting and code review systems migration
detailed in these mailing list posts:

http://lists.openstack.org/pipermail/openstack-discuss/2019-March/003603.html
http://lists.openstack.org/pipermail/openstack-discuss/2019-April/004920.html

Attempts have been made to correct repository namespaces and
hostnames based on simple pattern matching, but it's possible some
were updated incorrectly or missed entirely. Please reach out to us
via the contact information listed at https://opendev.org/ with any
questions you may have.
2019-04-19 19:52:00 +00:00
deployment_scripts/puppet Glance configuration is moved to scaleio openstack puppet module 2016-11-17 13:25:51 +03:00
doc Update version to v2.1.3. 2016-12-02 18:59:58 +03:00
repositories update version from https://github.com/cloudscaling/fuel-plugin-scaleio 2016-06-23 17:40:46 +03:00
spec Fixed plugin specs styling 2015-11-26 16:47:22 +01:00
.gitignore update version from https://github.com/cloudscaling/fuel-plugin-scaleio 2016-06-23 17:40:46 +03:00
.gitmodules update version from https://github.com/cloudscaling/fuel-plugin-scaleio 2016-06-23 17:40:46 +03:00
.gitreview OpenDev Migration Patch 2019-04-19 19:52:00 +00:00
CONTRIBUTING.md Updated README 2015-11-19 11:26:40 -08:00
deployment_tasks.yaml fixed dependencies for scaleio role 2016-10-18 17:15:54 +03:00
environment_config.yaml Use FTP server as a source with ScaleIO packages 2016-11-14 12:35:46 +03:00
LICENSE Updated README file to inform about the Launchpad site 2015-11-18 17:25:02 -08:00
metadata.yaml enable plugin for fuel10 2017-02-07 15:40:22 +00:00
node_roles.yaml v2.1.2 fixes for documentations 2016-10-26 16:22:51 +03:00
pre_build_hook Update version to v2.1.3. 2016-12-02 18:59:58 +03:00
README.md Update version to v2.1.3. 2016-12-02 18:59:58 +03:00
Vagrantfile updated Vagrantfile and ScaleIO drivers for Cinder 2015-11-06 10:06:25 +01:00
volumes.yaml Non-hyper-converged deployment support 2016-09-06 17:05:14 +03:00

ScaleIO Plugin for Fuel

Overview

The ScaleIO plugin allows to:

  • Deploy an EMC ScaleIO v.2.0 cluster together with OpenStack and configure OpenStack to use ScaleIO as the storage for persistent and ephemeral volumes
  • Configure OpenStack to use an existing ScaleIO cluster as a volume backend
  • Support the following ScaleIO custer modes: 1_node, 3_node and 5_node the mode is chosen automatically depending on the number of controller nodes

## Requirements

Requirement Version/Comment
Mirantis OpenStack 8.0
Mirantis OpenStack 9.0

## Recommendations

  1. Use configuration with 3 controllers or 5 controllers. Although 1 controller mode is supported is suitable for testing purposees only.
  2. Assign Cinder role for all controllers with allocating minimal diskspace for this role. Some space is needed because of FUEL framework limitation (this space will not used). Rest of the space keep for images.
  3. Use nodes with similar HW configuration within one group of roles.
  4. Deploy SDS coponents only on compute nodes. Deploymen SDS-es on controllers is supported but it is more suitable for testing than for production environment.
  5. On compute nodes keep minimal space for virtual storage on the first disk, rest disks use for ScaleIO. Some space is needed because of FUEL framework limitations. Other disks should be unallocated and can be used for ScaleIO.
  6. In case of extending cluster with new compute nodes not to forget to run update_hosts tasks on controller nodes via FUEL cli.

Limitations

  1. Plugin supports Ubuntu environment only.
  2. Multi storage backend is not supported.
  3. It is not possible to use different backends for persistent and ephemeral volumes.
  4. Disks for SDS-es should be unallocated before deployment via FUEL UI or cli.
  5. MDMs and Gateways are deployed together and only onto controller nodes.
  6. Adding and removing node(s) to/from the OpenStack cluster won't re-configure the ScaleIO.

Installation Guide

ScaleIO Plugin install from source code

To install the ScaleIO Plugin from source code, you first need to prepare an environment to build the RPM file of the plugin. The recommended approach is to build the RPM file directly onto the Fuel Master node so that you won't have to copy that file later.

Prepare an environment for building the plugin on the Fuel Master node.

  1. You might want to make sure that kernel you have on the nodes for ScaleIO SDC installation (compute and cinder nodes) is suitable for the drivers present here: ftp://QNzgdxXix:Aw3wFAwAq3@ftp.emc.com/. Look for something like Ubuntu/2.0.5014.0/4.2.0-30-generic. Local kernel version can be found with uname -a command.

  2. Install the standard Linux development tools:

    $ yum install createrepo rpm rpm-build dpkg-devel dpkg-dev git
    
  3. Install the Fuel Plugin Builder. To do that, you should first get pip:

    $ easy_install pip
    
  4. Then install the Fuel Plugin Builder (the fpb command line) with pip:

    $ pip install fuel-plugin-builder
    

Note: You may also have to build the Fuel Plugin Builder if the package version of the plugin is higher than package version supported by the Fuel Plugin Builder you get from pypi. In this case, please refer to the section "Preparing an environment for plugin development" of the Fuel Plugins wiki if you need further instructions about how to build the Fuel Plugin Builder.

  1. Clone the ScaleIO Plugin git repository:

    $ git clone https://github.com/openstack/fuel-plugin-scaleio.git
    $ cd fuel-plugin-scaleio
    $ git checkout "tags/v2.1.3"
    
  2. Check that the plugin is valid:

    $ fpb --check .
    
  3. Build the plugin:

    $ fpb --build .
    
  4. Install plugin:

    $ fuel plugins --install ./scaleio-2.1-2.1.3-1.noarch.rpm
    

ScaleIO Plugin install from Fuel Plugins Catalog

To install the ScaleIOv2.0 Fuel plugin:

  1. Download it from the Fuel Plugins Catalog

  2. Copy the rpm file to the Fuel Master node

    [root@home ~]# scp scaleio-2.1-2.1.3-1.noarch.rpm root@fuel-master:/tmp
    
  3. Log into Fuel Master node and install the plugin using the Fuel CLI

    $ fuel plugins --install ./scaleio-2.1-2.1.3-1.noarch.rpm
    
  4. Verify that the plugin is installed correctly

    [root@fuel-master ~]# fuel plugins
    id | name                  | version | package_version
    ---|-----------------------|---------|----------------
     1 | scaleio               | 2.1.3   | 3.0.0
    

User Guide

Please read the ScaleIO Plugin User Guide for full description.

First of all, ScaleIOv2.0 plugin functionality should be enabled by switching on ScaleIO in the Settings.

ScaleIO section contains the following info to fill in:

  1. Existing ScaleIO Cluster.

Set "Use existing ScaleIO" checkbox. The following parameters should be specified:

  • Gateway IP address - IP address of ScaleIO gateway
  • Gateway port - Port of ScaleIO gateway
  • Gateway user - User to access ScaleIO gateway
  • Admin password - Password to access ScaleIO gateway
  • Protection domain - The protection domain to use
  • Storage pools - Comma-separated list of storage pools
  1. New ScaleIO deployment

The following parameters should be specified:

  • Admin password - Administrator password to set for ScaleIO MDM
  • Protection domain - The protection domain to create for ScaleIO cluster
  • Storage pools - Comma-separated list of storage pools to create for ScaleIO cluster
  • Storage devices - Path to storage devices, comma separated (/dev/sdb,/dev/sdd)

The following parameters are optional and have default values suitable for most cases:

  • Controller as Storage - Use controller nodes for ScaleIO SDS (by default only compute nodes are used for ScaleIO SDS deployment)
  • Provisioning type - Thin/Thick provisioning for ephemeral and persistent volumes
  • Checksum mode - Checksum protection. ScaleIO protects data in-flight by calculating and validating the checksum value for the payload at both ends. Note, the checksum feature may have a minor effect on performance. ScaleIO utilizes hardware capabilities for this feature, where possible.
  • Spare policy - % out of total space to be reserved for rebalance and redundancy recovery cases.
  • Enable Zero Padding for Storage Pools - New volumes will be zeroed if the option enabled.
  • Background device scanner - This options enables the background device scanner on the devices in device only mode.
  • XtremCache devices - List of SDS devices for SSD caching. Cache is disabled if list empty.
  • XtremCache storage pools - List of storage pools which should be cached with XtremCache.
  • Capacity high priority alert - Threshold of the non-spare capacity of the Storage Pool that will trigger a high-priority alert, in percentage format.
  • Capacity critical priority alert - Threshold of the non-spare capacity of the Storage Pool that will trigger a critical-priority alert, in percentage format.
  • Use RAM cache (RMCache) - Enable/Disable use of SDS Servers RAM for caching storage devices in a Storage Pool.
  • Passthrough RMCache storage pools - List of Storage Pools to be cached in SDS Servers RAM in passthrough mode (if the 'Use RAM cache (RMCache)' option is enabled)
  • Cached RMCache storage pools - List od Storage Pools to be cached in SDS Servers RAM in cached mode (if the 'Use RAM cache (RMCache)' option is enabled)
  • Glance images on ScaleIO - Enable/Disable ScaleIO backend for Glance images (It uses cinder backend in Glance to store images on ScaleIO). This option is available since MOS9.0.

Configuration of disks for allocated nodes: The devices listed in the "Storage devices" and "XtremCache devices" should be left unallocated for ScaleIO SDS to work.

Contributions

Please read the CONTRIBUTING.md document for the latest information about contributions.

Bugs, requests, questions

Please use the Launchpad project site to report bugs, request features, ask questions, etc.

License

Please read the LICENSE document for the latest licensing information.