Chapter 9 :
Maintenance
Learning Objectives
✔ Explain and contrast four types of system
maintenance.
✔ Describe factors affecting maintenance costs.
✔ Describe maintenance management issues,
including organizational structure, quality
measurement, change management, and
configuration management.
✔ Explain the role of CASE tools for system
maintenance.
The Process of Maintaining
Information Systems
● Process of returning to the beginning of the
SDLC and repeating development steps focusing
on system change until the change is
implemented
● Maintenance is the longest phase in the SDLC
● Four major activities:
● Obtaining maintenance requests
● Transforming requests into changes
● Designing changes
● Implementing changes
Maintenance is like a mini-SDLC
Types of System Maintenance
● Corrective maintenance
Changes made to a system to repair flaws in its design,
coding, or implementation
● Adaptive maintenance
Changes made to a system to evolve its functionality to
changing business needs or technologies
● Perfective maintenance
Changes made to a system to add new features or to improve
performance
● Preventive maintenance
Changes made to a system to avoid
possible future problems
By far, most maintenance is corrective, and therefore urgent
and non-value adding.
The Cost of Maintenance
● Many organizations allocate eighty percent of
information systems budget to maintenance
● Factors that influence system maintainability:
▪ Latent defects
▪ Number of customers for a given system
▪ Quality of system documentation
▪ Maintenance personnel
▪ Tools
▪ Well-structured programs
A well-documented system is easier to understand, and
therefore easier to maintain.
Conducting System Maintenance
Managing Maintenance
● Number of people working in maintenance has
surpassed number working in development.
● Three possible organizational structures:
● Separate
- Maintenance group consists of different personnel than
development group.
● Combined
- Developers also maintain systems.
● Functional
- Maintenance personnel work within the functional
business unit.
Advantages and Disadvantages
Maintenance
Organization Advantages Disadvantages
Type
Separate Improved system Ignorance of critical
and documentation undocumented
quality information
Combined Maintenance group Less emphasis on
knows all about good documentation
system
Functional Personnel have Limited job mobility
vested interest and human or
technical resources
Assignment of Maintenance
Personnel
● Maintenance work is often viewed negatively by
IS personnel.
● Organizations have historically have rewarded
people involved in new development better than
maintenance personnel.
● Organizations often rotate personnel in and out of
maintenance roles in order to lessen negative
feelings about maintenance.
Conducting System Maintenance
Measures of Effectiveness
● Important factors to consider
- Number of failures
- Time between each failure
- Type of failure
● Mean time between failures (MTBF)
- A measurement of error occurrences that can
be tracked over time to indicate the quality of a
system
Expect lots of failures early, but as corrective
maintenance takes place, error rate should decrease
rapidly
Controlling Maintenance
Requests
Maintenance requests
can be frequent
Prioritize based on type
and urgency of request
The Flow of a Maintenance
Request
Evaluations are based on
feasibility analysis
Configuration Management
● The process of assuring that only authorized changes are
made to the system
● Baseline modules
- Software modules that have been tested, documented, and
approved to be included in the most recently created
version of a system
● System librarian
- A person responsible for controlling the checking out and
checking in of baseline modules when a system is being
developed or maintained
● Build routines
- Guidelines that list the instructions to construct an executable
system from the baseline source code
Configuration Management
Tools
● Special software systems for managing system
configuration
● Controls access to modules in the system library
● Two types
● Revision control: modules labeled as frozen
(unchangeable) or floating (checked out by programmer
for modification)
● Source code control: extend revision control to all
interrelated modules
● Historical changes can be traced and previous
versions can be reconstructed
Role of CASE and Automated Development
Tools in Maintenance
● Traditional systems ● Development with CASE
development ● Emphasis is on design
● Emphasis on coding and documents.
testing.
● Changes are implemented
● Changes are implemented in design documents.
by coding and testing first.
● Code is regenerated using
● Documentation is done
after maintenance is code generators.
performed. ● Documentation is updated
● Keeping documentation during maintenance.
current is often neglected
due to time-consuming
nature of task.
Example Website Maintenance
● Special considerations
● 24 X 7 X 365
- Nature of continuous availability makes maintenance
challenging.
- Pages under maintenance can be locked.
- Date and time stamps
● Check for broken links
● HTML Validation
- Pages should be processed by a code validation routine
before publication.
Website Maintenance
● Special considerations (continued)
● Reregistration
- When content significantly changes, site may need to
be reregistered with search engines
● Future Editions
- Consistency is important to users
- Post indications of future changes to the site
- Batch changes
Summary
● In this chapter you learned how to:
✔ Explain and contrast four types of system
maintenance.
✔ Describe factors affecting maintenance costs.
✔ Describe maintenance management issues,
including organizational structure, quality
measurement, change management, and
configuration management.
✔ Explain the role of CASE tools for system
maintenance.