IBM Information Management System
IBM Information Management System is a joint hierarchical database and information management system with extensive transaction processing capabilities.
History
designed the IMS with Rockwell and Caterpillar starting in 1966 for the Apollo program, where it was used to inventory the very large bill of materials for the Saturn V moon rocket and Apollo space vehicle.The first "IMS READY" message appeared on an IBM 2740 terminal in Downey, California, on August 14, 1968.
In the interim period, IMS has undergone many developments as IBM System/360 technology evolved into the current z/OS and IBM zEnterprise System technologies. For example, IMS now supports the Java programming language, JDBC, XML, and, since late 2005, web services.
Vern Watts was IMS's chief architect for many years. Watts joined IBM in 1956 and worked at IBM's Silicon Valley development labs until his death on April 4, 2009. He had continuously worked on IMS since the 1960s.
Database
The IMS Database component stores data using a hierarchical model, which is quite different from IBM's later released relational database, Db2. In IMS, the hierarchical model is implemented using blocks of data known as segments. Each segment can contain several pieces of data, which are called fields. For example, a customer database may have a root segment with fields such as phone, name, and age. Child segments may be added underneath another segment, for instance, one order segment under each customer segment representing each order a customer has placed with a company. Likewise, each order segment may have many children segments for each item on the order. Unlike other databases, you do not need to define all of the data in a segment to IMS. A segment may be defined with a size of 40 bytes but only define one field that is six bytes long as a key field that you can use to find the segment when performing queries. IMS will retrieve and save all 40 bytes as directed by a program but may not understand what the other bytes represent. In practice, often all data in a segment may map to a COBOL copybook. Besides DL/I query usage, a field may be defined in IMS so that the data can be hidden from certain applications for security reasons. The database component of IMS can be purchased standalone, without the transaction manager component, and used by systems such as CICS.There are three basic forms of IMS hierarchical databases:
"Full Function" databases
- Directly descended from the Data Language Interface databases originally developed for Apollo, full function databases can have primary and secondary indexes, accessed using DL/I calls from an application program, like SQL calls to Db2 or Oracle.
- Full function databases can be accessed by a variety of methods, although Hierarchical Direct and Hierarchical Indexed Direct dominate. The other formats are Simple Hierarchical Indexed Sequential, Hierarchical Sequential, and Hierarchical Indexed Sequential.
- Full function databases store data using VSAM, a native z/OS access method, or Overflow Sequential, an IMS-specific access method that optimizes the I/O channel program for IMS access patterns. In particular, OSAM performance benefits from sequential access of IMS databases.
"Fast Path" databases
- Fast Path databases are optimized for extremely high transaction rates. Data Entry Databases and Main Storage Databases are the two types of Fast Path databases. DEDBs use a direct access technique similar to Full Function HDAM and IMS V12 provided a DEDB Secondary Index function. MSDBs do not support secondary indexing. Virtual Storage Option DEDBs can replace MSDBs in modern IMS releases, so MSDBs are gradually disappearing.
High Availability Large Databases (HALDBs)
- IMS V7 introduced HALDBs, an extension of IMS full function databases to provide better availability, better handling of extremely large data volumes, and, with IMS V9, online reorganization to support continuous availability. A HALDB can store in excess of 40 terabytes of data.
Collectively the database-related IMS capabilities are often called IMS DB. IMS DB has grown and evolved over nearly four decades to support myriad business needs. IMS, with assistance from z/OS hardware the Coupling Facility supports N-way inter-IMS sharing of databases. Many large configurations involve multiple IMS systems managing common databases, a technique providing for scalable growth and system redundancy in the event of hardware or software failures.
Transaction Manager
IMS is also a robust transaction manager one of the "big three" classic transaction managers along with CICS and BEA Tuxedo. A transaction manager interacts with an end user or another application, processes a business function, and maintains state throughout the process, making sure that the system records the business function correctly to a data store. Thus IMS TM is quite like a Web application, operating through a CGI program, to provide an interface to query or update a database. IMS TM typically uses either IMS DB or Db2 as its backend database. When used alone with Db2 the IMS TM component can be purchased without the IMS DB component.IMS TM uses a messaging and queuing paradigm. An IMS control program receives a transaction entered from a terminal and then stores the transaction on a message queue. IMS then invokes its scheduler on the queued transaction to start the business application program in a message processing region. The message processing region retrieves the transaction from the IMS message queue and processes it, reading and updating IMS and/or Db2 databases, assuring proper recording of the transaction. Then, if required, IMS enqueues a response message back onto the IMS message queue. Once the output message is complete and available the IMS control program sends it back to the originating terminal. IMS TM can handle this whole process thousands of times per second. In 2013 IBM completed a benchmark on IMS Version 13 demonstrating the ability to process 100,000 transactions per second on a single IMS system.
Application
Prior to IMS, businesses and governments had to write their own transaction processing environments. IMS TM provides a straightforward, easy-to-use, reliable, standard environment for high performance transaction execution. In fact, much of the world's banking industry relies on IMS, including the U.S. Federal Reserve. For example, chances are that withdrawing money from an automated teller machine will trigger an IMS transaction. Several Chinese banks have recently purchased IMS to support that country's burgeoning financial industry.Today IMS complements Db2, IBM's relational database system, introduced in 1982. In general, IMS performs faster than Db2 for the common tasks but may require more programming effort to design and maintain for non-primary duties. Relational databases have generally proven superior in cases where the requirements, especially reporting requirements, change frequently or require a variety of viewpoint "angles" outside the primary or original function.
A relational "data warehouse" may be used to supplement an IMS database. For example, IMS may provide primary ATM transactions because it performs well for such a specific task. However, nightly copies of the IMS data may be copied to relational systems such that a variety of reports and processing tasks may be performed on the data. This allows each kind of database to focus best on its relative strength.