Web-Based Enterprise Management
|Organization||Distributed Management Task Force|
|Base standards||CIM and WS-Management|
In computing, Web-Based Enterprise Management (WBEM) comprises a set of systems-management technologies developed to unify the management of distributed computing environments. The WBEM initiative, initially sponsored in 1996 by BMC Software, Cisco Systems, Compaq Computer, Intel, and Microsoft, is now widely adopted. WBEM is based on Internet standards and Distributed Management Task Force (DMTF) open standards:
- Common Information Model (CIM) infrastructure and schema
- WS-Management for web services
Although the name labels WBEM as "web-based", it is not necessarily dependent on any particular user interface (see below). Other systems-management approaches include remote shells, proprietary solutions and IETF standardized network-management architectures like the SNMP and netconf.
WBEM allows the management of any element in a standard and inter-operable manner.
WBEM provides the technology underlying different management initiatives in information technology:
- desktop management (DASH)
- network management (NetMan)
- storage management (SMI)
- systems management (SMASH)
- virtualization management (VMAN)
To understand the WBEM architecture, consider the components which lie between the operator trying to manage a device (configure it, turn it off and on, collect alarms, etc.) and the actual hardware and software of the device:
- the operator will invoke some form of graphical user interface (GUI), Browser User Interface (BUI), or command-line interface (CLI). The WBEM standard has nothing to say about this interface (although the definition of a CLI for specific applications has started): WBEM operates independently of the human interface, since human interfaces can change without the rest of the system needing to note such changes.
- the GUI, BUI or CLI will interface with a WBEM client through a small set of application programming interfaces (APIs). This client will find the WBEM server for the managed device (typically on the device itself) and construct an XML message containing the request.
- the client will use the HTTP (or HTTPS) protocol to pass the request, encoding it in CIM-XML, to the WBEM server
- the WBEM server will decode the incoming request, perform the necessary authentication and authorization checks and then consult the previously defined model of the managed device to see how to handle the request. This model provides the power of the architecture: it represents the pivot point of the transaction, with the client simply interacting with the model and the model interacting with the real hardware or software. The model uses the Common Information Model standard; the DMTF has published many models for commonly managed devices and services: IP routers, storage servers, desktop computers, etc.
- for most operations, the WBEM server determines from the model that it needs to communicate with the actual hardware or software. So-called "providers" handle the interaction: small pieces of code interface between the WBEM server (using a standardised interface known as CMPI) and the real hardware or software. Because the interface is well-defined and the number of types of call is small, it is normally easy to write providers. In particular, the writer of the provider knows nothing of the GUI, BUI, or CLI used by the operator.
- SLP (WBEM Discovery using SLP; SLP Template)
- Query Language
So, which pieces of this does a device manufacturer or service provider have to write?
- Firstly the model.
- This is normally done by extending as necessary one of the standard models published by the DMTF.
- Then the BUI, GUI, or CLI.
- The client and server usually do not need to be written because there are many open-source and commercial implementations available (see External links below)
- Then the providers
- In summary, the WBEM architecture allows the manufacturer of a device or developer of a service to provide a standards-compliant management interface to that device simply and cheaply.
WBEM in operating systems
- Apple Inc. uses an implementation of WBEM in its Apple Remote Desktop management tool, and Mac OS X clients ship with support for Remote Management.
- Hewlett Packard has included WBEM Services CORE Product in the HP-UX operating system (with all operating environments) since version 11iv1 and OpenVMS V8.3-1H1 and V8.4
- IBM ships support in z/OS and AIX.
- Microsoft has developed the WMI technology and has included it in Microsoft Windows
- Novell has adopted the OpenWBEM open source implementation of WBEM and includes it in SUSE Linux Enterprise Server
- Red Hat ships OpenPegasus as part of Red Hat Enterprise Linux
- Oracle has WBEM-Services for the Solaris operating environment
- Ubuntu ships with an updated CIM instrumentation stack, powered by the latest version of the lightweight CIMOM, SBLIM SFCB.
- OpenPegasus, open-source client and server written in C++
- Open Management Infrastructure, open-source client and server written in C
- OpenWBEM, open-source client and server written in C++ (unchanged since 2006?)
- WBEM Services, Java (unchanged since 2003?)
- SBLIM (pronounced "sublime") Standards Based Linux Instrumentation for Manageability, C, C++, Java
- PyWBEM, open-source WBEM library written in Python
- Purgos, open-source management client for Windows written in C++ (Product now discontinued and has reached End Of Life)
- SMI-S, Storage Management Initiative - Specification. Based on WBEM, used for SAN devices
- JSR-48, Java API for developing WBEM Clients and WBEM Providers
- CMPI, C provider API for developing WBEM Providers
- Todd, Greg (June 30, 1998). "What is WBEM?". Windows IT Pro. Archived from the original on 13 November 2015. Retrieved 13 November 2015.
In 1996, BMC Software, Cisco Systems, Compaq Computer, Intel, and Microsoft sponsored the Web-Based Enterprise Management (WBEM) initiative, an effort to provide a unifying mechanism for describing and sharing management information.
- The Common Manageability Programming Interface
-  Solaris WBEM Developer's Guide