1. Introduction¶
1.1. Pywbemtools features¶
Pywbemtools is a collection of command line tools that communicate with WBEM servers. The tools are written in pure Python and support Python 2 and Python 3.
At this point, pywbemtools includes a single command line tool named
pywbemcli
that uses the pywbem package on Pypi to issue operations to a
WBEM server using the CIM/WBEM standards defined by the DMTF to perform
system management tasks.
CIM/WBEM standards are used for a wide variety of systems management tasks in the industry including DMTF management standards and the SNIA Storage Management Initiative Specification (SMI-S).
1.1.1. Pywbemcli command line interface WBEM client¶
Pywbemcli provides access to WBEM servers from the command line. It provides functionality to:
- Explore the CIM data of WBEM servers. It can manage/inspect the CIM model components including CIM classes, CIM instances, and CIM qualifiers and execute CIM methods and queries on the WBEM server.
- Execute specific CIM-XML operations on the WBEM server as defined in DMTF standard DSP0200 (CIM Operations over HTTP).
- Inspect and manage WBEM server functionality including:
- CIM namespaces
- Advertised WBEM management profiles
- WBEM server brand and version information
- Capture detailed information on CIM-XML interactions with the WBEM server including time statistics and details of data flow.
- Maintain a file with persisted WBEM connection definitions so that pywbemcli can access multiple WBEM servers by name.
- Provide both a command line mode and an interactive mode where multiple pywbemcli commands can be executed within the context of a WBEM server.
- Use an integrated mock WBEM server to try out commands. The mock server can be loaded with CIM objects defined in MOF files or via Python scripts.
1.2. Supported environments¶
The pywbemtools package is supported in these environments:
- Operating systems: Linux, Windows (native and Unix-like environments (ex. Cygwin), OS-X
- Python versions: 2.7, 3.4, and greater
- WBEM servers: Any WBEM server that conforms to the DMTF specifications listed in Standards conformance. WBEM servers supporting older versions of these standards are also supported, but may have limitations. See the pywbem WBEM servers documentation for more details.
1.3. Installation¶
This section describes the complete installation of pywbemtools with all steps including prerequisite operating system packages.
The easiest way to install the pywbemtools package is using pip. Pip ensures that any dependent Python packages also get installed.
Pip will install the packages into your currently active Python environment (your system Python or your predefined virtual Python environment).
It is beneficial to set up a virtual Python environment for your project,
because that leaves your system Python installation unchanged, it does not
require sudo
rights, and gives you better control about the installed
packages and their versions.
If you want to contribute to the pywbem project, you need to set up a development and test environment for pywbem. That has a larger set of OS-level prerequisites and its setup is described in the Pywbemtools development chapter.
1.3.1. Installation prerequisites¶
The Python environment into which you want to install must have the following Python packages installed:
- setuptools - http://pypi.python.org/pypi/setuptools
- wheel
- pip - generally installed with Python 3.x but may be a separate install with Python 2.7 and with Cygwin Python releases.
Pywbemtools installs the pywbem package which requires a number of OS-level
packages as documented in the pywbem installation documentation.
The pywbem package provides the pywbem_os_setup.sh/.bat
scripts that
install the needed OS-level packages. These scripts are only needed when
using Python 2.
To use these scripts, your system must have the following commands installed when using Python 2:
- On native Windows:
choco
- Chocolatey package manager. The pywbemtools package installation uses Chocolatey to install OS-level software. See https://chocolatey.org/ for the installation instructions for Chocolatey.wget
- Download tool. Can be installed with:choco install wget
.
- On Linux, OS-X, UNIX-like environments on Windows (e.g. Cygwin):
wget
- Download tool. Can be installed using the OS-level package manager for the platform.
1.3.2. Installation with pip¶
When using Python 2, install OS-level packages needed by the pywbem package:
On native Windows:
> wget -q https://raw.githubusercontent.com/pywbem/pywbem/master/pywbem_os_setup.bat > pywbem_os_setup.bat
On Linux, OS-X, UNIX-like environments on Windows (e.g. Cygwin):
$ wget -q https://raw.githubusercontent.com/pywbem/pywbem/master/pywbem_os_setup.sh $ chmod 755 pywbem_os_setup.sh $ ./pywbem_os_setup.sh
The
pywbem_os_setup.sh
script uses sudo internally, so your userid needs to have sudo permission.
If you want to install the needed OS-level packages manually, see pywbem prerequisite OS packages.
The following command downloads and installs the latest released version of the pywbemtools package from PyPI into the currently active Python environment:
$ pip install pywbemtools
As an alternative, if you want to install the latest development level of the
pywbemtools package for some reason, install directly from the master
branch of the Git repository of the package:
$ pip install git+https://github.com/pywbem/pywbemtools.git@master#egg=pywbemtools
1.3.3. Verification of the installation¶
You can verify that the pywbemtools package and its dependent packages are
installed correctly by invoking pywbemcli. Invoking with the --version
option displays the installed version of both pywbem and pywbemtools as
shown in the following example:
$ pywbemcli --version
pywbemcli, version 0.5.0
pywbem, version 0.14.4
1.4. Standards conformance¶
Pywbemtools attempts to comply to the maximum possible with the relevant standards.
Pywbemtools uses pywbem for communication with the WBEM server. Therefore pywbemtools conformance to the relevant standards is defined in the pywbem standards conformance documentation.
Therefore, the level of conformance and limitations for pywbemtools is the same as pywbem except for any specific notations in this document.
1.5. Deprecation policy¶
Pywbemtools attempts to be as backwards compatible as possible.
Occasionally functionality needs to be retired, because it is flawed and a better but incompatible replacement has emerged.
In pywbemtools, such changes are done by deprecating existing functionality, without removing it. The deprecated functionality is still supported throughout new minor releases. Eventually, a new major release will break compatibility and will remove the deprecated functionality.
In order to prepare users of pywbemtools for that, deprecation of functionality
is stated in the CLI documentation, and is made visible at runtime by issuing
Python warnings of type DeprecationWarning
(see the Python
py:warnings
module).
Since Python 2.7, DeprecationWarning
messages are suppressed by default.
They can be shown for example by invoking pywbemcli with the environment
variable: PYTHONWARNINGS=default
It is recommended that users of the pywbemtools package run their test code with
DeprecationWarning
messages being shown, so they become aware of any use of
deprecated functionality.
Here is a summary of the deprecation and compatibility policy used by pywbemtools, by release type:
- New update release (M.N.U -> M.N.U+1): No new deprecations; fully backwards compatible.
- New minor release (M.N.U -> M.N+1.0): New deprecations may be added; as backwards compatible as possible.
- New major release (M.N.U -> M+1.0.0): Deprecated functionality may get removed; backwards compatibility may be broken.
Compatibility is always seen from the perspective of the user of pywbemtools, so a backwards compatible new pywbemtools release means that the user can safely upgrade to that new release without encountering compatibility issues.
1.6. Versioning¶
This documentation applies to version 0.5.2.dev4 of the pywbemtools package. You can also see that version in the top left corner of this page.
The pywbemtools package uses the rules of Semantic Versioning 2.0.0 for its version.
This documentation may have been built from a development level of the package. You can recognize a development version of this package by the presence of a “.devD” suffix in the version string. Development versions are pre-versions of the next assumed version that is not yet released. For example, version 0.5.1.dev2 is development pre-version #2 of the next version to be released after 0.5.0. Version 1.5.1 is an assumed next version, because the actually released next version might be 0.7.0 or even 1.0.0.
1.7. Compatibility¶
In this package, compatibility is always seen from the perspective of the user of the package. Thus, a backwards compatible new version of this package means that the user can safely upgrade to that new version without encountering compatibility issues.
This package uses the rules of Semantic Versioning 2.0.0 for compatibility between package versions, and for deprecations.
The public command line interface of this package that is subject to the semantic versioning rules (and specifically to its compatibility rules) is the CLI syntax described in this documentation.
The output formats are currently not the subject of compatibility assurances.
Violations of these compatibility rules are described in section Change log.
1.8. Reporting issues¶
If you encounter any problem with this package, or if you have questions of any kind related to this package (even when they are not about a problem), please open an issue in the pywbemtools issue tracker.
1.9. License¶
This package is licensed under the Apache 2.0 License.