Software Maintenance and Support
A to Z Guide
Learn about the key steps, necessary skills, and potential sourcing options to set up smooth maintenance and support processes. The page also outlines the costs and benefits of outsourced software maintenance and support services based on ScienceSoft's decades-long experience in ITSM.
Maintenance vs. Support: What's the Difference?
Software maintenance is proactive and includes scheduled activities to address non-urgent issues or perform planned improvements. Software support is reactive and focuses on handling urgent problems that can hamper software operation and cause downtimes.
ScienceSoft brings 16 years of experience in ITSM to provide organizations with comprehensive support and maintenance services to ensure stability, scalability, high performance, and robust security of their software in the long run.
Key Support and Maintenance Classifications
Below we consider two popular classifications of support and maintenance activities. Both classifications offer valuable perspectives on software support and maintenance; they are not mutually exclusive and can be integrated into a comprehensive support and maintenance strategy.
By nature of support and maintenance activities
Type | Essence | Activities | Timing |
---|---|---|---|
Type
Corrective model |
Essence
Responding to identified problems: making changes to the software to correct defects found during the software use (e.g., bugs that cause the software to behave unexpectedly). |
Activities
|
Timing
Reactive |
Type
Adaptive model |
Essence
Modifying software to keep it compliant with a changed or changing environment (e.g., with new regulations while entering a new market). |
Activities
|
Timing
Reactive/proactive |
Type
Perfective model |
Essence
Making the software meet new requirements that were not originally required (improving performance, enhancing features, and making the software more efficient and easier to use) |
Activities
|
Timing
Proactive |
Type
Preventive model |
Essence
Foreseeing and reducing the likelihood of future system failures, making future maintenance tasks easier and less costly. |
Activities
|
Timing
Proactive |
Type
Emergency model |
Essence
Addressing urgent fixes, often in response to critical bugs or security vulnerabilities that could significantly impact the functionality, security, or performance of the software. |
Activities
|
Timing
Reactive |
By approach to evolving and mainaining software over time
Quick-fix |
Shares similarities with emergency maintenance in its focus on immediate response to critical issues. |
This model is the simplest form of support. It is about making immediate and direct fixes to problems as they are discovered. It is often applied under pressure, for example, when a critical bug needs to be fixed immediately to keep the system running. However, while it provides a rapid solution, the quick-fix model can lead to a buildup of technical debt over time if the underlying causes of issues are not addressed. |
Iterative enhancement |
Can incorporate elements of perfective, preventive, and adaptive maintenance as part of its ongoing improvement cycles. |
The model is aimed at continuous software improvement in cycles or iterations. Each iteration typically includes planning, design, coding, testing, and deployment phases. This model acknowledges that software needs to evolve over time and provides a framework for progressively updating and improving the software in response to changing requirements and user feedback. |
Re-use oriented |
Can be seen as a strategy within preventive maintenance, focusing on leveraging existing solutions to avoid future problems. |
Instead of writing new code from scratch, this approach leverages existing software components (either from previous projects, from other parts of software or third-party sources) to build new modules and functionalities or enhance existing ones. This model drastically reduces development time and costs. However, it requires careful management of dependencies and compatibility between components. |
Software Maintenance and Support Setup Plan
The setup plan will differ depending on the specifics of the supported software and its underlying infrastructure, as well as the scope of the required support and maintenance activities.
Below are described the typical steps we at ScienceSoft take to set up maintenance and support activities.
1.
Scope and resources estimation
To determine the scope of the support and maintenance activities, we analyze:
- The software’s related infrastructure.
- Prospective new features and changes.
- The current and planned user pool.
Then, we measure the projected scope against currently available in-house resources, such as dedicated IT specialists and maintenance tools.
One of the crucial steps we take in scope estimation is the assessment of the software maturity. The newer it is, the more maintenance requests we expect, and we allocate resources accordingly. For example, when we started working with a global advertising agency, we learned from the very start that their microservices-based software was still undergoing development. So, we equipped our L2 team with the needed instructions to adeptly configure the customer's system for smooth integration of software updates.
2.
Software maintenance and support process design
Depending on the scope of the required activities, maintenance and support processes will comprise a combination of the following techniques:
Reactive support (on-demand)
- End user support (L1) – solving usage issues and minor problems, escalating more complex issues.
- Application support (L2) – software troubleshooting, fixing its performance, configuration, and security issues.
- Development support (L3/L4) – fixing software issues on the code and database level, customization, adding new features, software integration.
Proactive support (continuous)
- Software availability, performance, security, and compliance monitoring.
- Software reengineering (including code refactoring, architecture redesign, data restructuring, reverse engineering).
- QA activities (including regular code reviews).
- Infrastructure optimization (e.g., cloud resource consumption optimization).
Depending on the support and maintenance activities, we define a set of KPIs to assess and optimize the process, aligning with the software maintenance plan. A sample KPIs set includes: the number of changes/updates delivered, the number of changes/updates waiting in a backlog, the number of urgent changes, the time required to introduce a change to the software, user satisfaction score, software outage time, software availability, the number of tickets by type, first response time, and ticket time to resolution.
We map the support and maintenance process in compliance with international technical standards set by ISO, IEC, and ITIL. For instance, when ScienceSoft refactored a business modelling tool for one of our clients, we adhered to GAMP4 specifications, establishing unit testing for code validation, regular code reviews, and version control on a dedicated SVN server.
3.
Choosing a sourcing model and implementation
Model 1: in-house software maintenance
1. Hiring and training staff for software maintenance and support
Duration: 4-8 weeks
2. Tool selection and customization
Duration: 1-4 weeks
Relevant tools are chosen based on the type of software, the maintenance and support scope, the KPIs set, and other aspects. The toolset may include backup software, software for performance and security monitoring, DevOps, help desk, and more.
Best practice: For application performance monitoring, ScienceSoft chooses tools that provide insights into the software CPU and memory usage, transactions profiling, response time and request rates, an app’s handling poor network connectivity, etc.
Model 2: outsourced software maintenance
Vendor selection
Duration: 3-12 weeks
To choose the right vendor, you need to:
- Examine top listings of software engineering companies as 90% of them offer maintenance services.
- Shortlist 3-5 companies based on their adherence to ITSM and DevOps practices, relevant certifications, for example, ITIL, Microsoft certifications (e.g., MSP, MCSA), certifications issues by cloud providers (e.g., Certified Solution Architect, Certified SysOps Administrator by AWS), Red Hat certifications.
- Prepare and send an RFP with software support and maintenance needs.
- Get tailored offers from potential vendors and compare their approaches to the given software maintenance project, as well as relevant expertise.
4.
Software maintenance and support launch
Pre-launch stage
Before launching the maintenance and support process, the details of the required services should be formalized in a service level agreement (SLA). Depending on the scope of software maintenance and support services rendered, SLA may outline:
- Software maintenance terms: software evolution roadmap, software performance requirements and expectations, planned security activities, KPIs, schedule, etc.
- Software support terms: support hours, e.g., 8/5, 12/5, 24/5, 24/7, required levels of support, size of a support team, communication channels, KPIs, etc.
Also, we work together with the customer to prepare standard operating procedures (SOPs) and instructions to stipulate all maintenance and support activities.
After-launch stage
We schedule regular maintenance windows for the preventive software maintenance activities that can cause downtimes. These time intervals should always be available, even if not used each time.
At this stage, we also provide the customer with clear and detailed reports (e.g., reports on team productivity, service quality KPIs, incident reports, security audit reports) and a revised risk management strategy.
For the production environment in which end users operate, we schedule the maintenance windows on Sundays. And for the non-production environment that is used just for testing, for example, we set maintenance windows daily during the night hours.
Sample Software Maintenance and Support Costs
Software support
Software maintenance and support
Usually, software maintenance and support costs are around 15–20% of the initial development costs (per year), and in total (during the entire software life cycle) they can be as high as 90% of the TCO.
Want to get a clear picture of your maintenance and support budget?
Software Maintenance and Support Cost Factors
The support and maintenance costs vary a lot depending on the sourcing model. The general cost factors for software maintenance and support services are:
- The type of software maintenance (corrective, adaptive, perfective, preventive; on-demand, continuous, both).
- The type of software, its complexity, integrations and customizations, etc.
- The software availability requirements.
- The maintenance team’s composition, competencies, and workload, e.g., 5 FTE (168h*5), 1 FTE (168h), 0.25 FTE (40h).
- Time coverage (e.g., 8/5, 12/5, 24/5, 24/7).
- The number of software users.
- Availability of comprehensive software documentation required for maintenance.
In addition, ScienceSoft recommends considering cost factors specific to the chosen sourcing model:
In-house software maintenance
- Licenses for configuration, help desk, and other tools used by the team.
- Investments in the in-house staff training.
- Regular payment of salaries and fringe benefits, tax payments, etc.
Outsourced software maintenance
- The pricing model (per ticket, bucket of hours).
- The number of help desk tickets (agreed and extra).
Sourcing Models
In-house maintenance and support
- Full control over the team.
- Potential lack of relevant talents.
- The software maintenance process setup and all managerial efforts are on your side.
- High cost of keeping an in-house team.
In-house management and outsourced resources
- Balanced mix of control and cost optimization.
- Establishing smooth cooperation between the in-house team and outsourced talents is challenging.
Fully outsourced maintenance and support
- Access to external expertise.
- Your IT team's reduced workload and focusing on the core tasks.
- Reduced costs.
- Exposing your IT infrastructure to an unreliable vendor might be risky.
Benefits of Software Maintenance and Support with ScienceSoft
Why Choose ScienceSoft for Software Maintenance
- 35 years in IT, 750+ experts on board.
- 17 years in software support services and help desk, 16 years in ITSM.
- Happy customers from 70+ countries globally: the US, Western Europe, Singapore, Australia and New Zealand, etc.
- Established ITIL 4 processes and practices.
- ISO 13485-certified quality management system specific to the medical devices industry and SaMD.
- Experience with complex, large-scale apps.
- 62% of revenue is from long-term contracts.
Typical Roles in Our Software Maintenance Teams
Depending on software maintenance and upgrade scope, the team may include various IT specialists, from developers to UI designers. Below, we describe the backbone talents required for the project involving both on-demand and continuous support activities:
Help desk specialists
- Receiving, registering, and tracking queries from software users.
- Solving simple and repeating issues (e.g., username and password problems, installing newly released patches and service packs).
- Escalating unsolved issues to L2/L3.
Application support engineers
- Continuous software monitoring and health checks.
- Fixing application performance issues.
- Resolving software configuration and account administration issues.
- Log investigation for root cause analysis of issues.
- Database administration.
Software developers
- Fixing issues on the code and database levels.
- Creating new software components or features.
- Implementing software customizations, integrations, and performing migrations.
- Unit testing.
Test engineers
- Functional, regression, integration, and other types of testing to validate the quality and security of software after introducing the required changes.
DevOps engineers
- Automating the update and evolution processes using the CI/CD approach.
- Managing physical and virtual servers and their configurations.
- Configuring and optimizing cloud services.
- Solving infrastructure issues.
Technologies We Use for Software Maintenance and Support
Consider Professional Software Maintenance Services
With over a decade of experience in software support and IT service management (ITSM), ScienceSoft offers the following service options:
About ScienceSoft
ScienceSoft is a global IT consulting and services provider headquartered in McKinney, TX. We offer application maintenance and support services and help our customers set up robust software maintenance and support process. Being ISO 9001- and ISO 27001-certified, we rely on a mature quality management system and guarantee that cooperation with us does not pose any risks to our customers' data security.