Analysis of Business-Critical Core Applications
Business-critical: a deep-dive into core application infrastructure.
Join the DZone community and get the full member experience.Join For Free
striking a balance between cutting costs and optimally supporting a business model is a major challenge for many it departments. they also need to calculate how to adapt the amount of it support — based on the needs of the business model — without raising the complexity of their it infrastructure or allowing application landscapes to grow out of control.
from conducting a comprehensive analysis to establishing key decision parameters, this article covers the journey to a successful core application transformation geared to the needs of a business model.
you may also like: ncache: scaling .net core applications for extreme performance .
core applications in a changing it landscape
every large and evolving it application landscape has extensive business-critical applications that have been developed individually during the span of many years. their ability to withstand the future must be put to the test. these customized core applications may implement core processes or manage huge streams of financial data at organizations in the public and private sectors. any failure of these applications would cause colossal financial damage to the company and/or irreparably harm its image.
it is up to it decision-makers to determine the future of these applications — should they be replaced, re-implemented, or modernized? errors or insufficient consideration of certain aspects (e.g., complexity, expertise, transparency, governance) during this decision phase will lead to failed projects (“money pits”) or missed deadlines and budgets without adding value to the business or it.
in order to mitigate risks, maximize potential benefits, and ensure project success, an extensive core application analysis must be incorporated into the decision-making process. the analysis must consider technology and business functionality of the core application as well as the knowledge of all associated stakeholders, such as the business unit, users, programmers, and it operations.
the ultimate goal is a gradual, transparent, and controllable application transformation that addresses the current and future requirements of a growing digital world without jeopardizing the intrinsic value or operation of existing applications.
the need for comprehensive analysis
how can a transformation be successful if the dependencies between systems are not clear, modules and elements aren’t transparent, and interfaces are poorly maintained and only minimally documented? how can a transformation take place if you can’t tell which modules and components are used in a business process and how? what knowledge of applications will be lost when staff members soon retire? how do you realistically calculate the value of factors such as cost, time, and risk given these conditions?
a comprehensive analysis must address these issues in order to establish a solid information base for decisions to be made in order to evolve applications into a future-proof architecture in a controlled way.
the analysis of an application must involve all relevant organizational entities, such as the business unit and research and development. the analysis must encompass the business and it contexts of the core application, for example, industry-specific methods, business processes, software products, it infrastructures and it architectures.
only a complete analysis of business and it contexts will enable you to make a thorough evaluation of your core application to make decisions with calculated risks. in addition to application details, the dependencies of system components and systems in development and runtime environments (e.g., programming languages and environments, database systems, middleware, job control) as well as it infrastructure (e.g., operating systems, hardware, devices) must be transparent.
static aspects (e.g., application structure, source code, interfaces) as well as dynamic criteria (e.g., runtime behavior) must be considered. all relevant business and it factors must be documented consistently and in relation to each other. all stakeholders should have access to the results of the analysis to view and to use for collaborative decisions.
the complexity of core applications
business-critical applications, whether they are dialog or batch, are highly complex. this is not only reflected in the source code but also in the respective business and database transaction logic. there are also multiple interfaces involved that tightly link internal and external it systems, servicing a variety of business processes and user groups.
core applications run primarily on mainframe platforms or highly scalable server platforms and employ technologies such as natural, cobol, adabas, db2® or vsam™. because these systems have been optimized over many years, they achieve a high level of operational quality that is apparent through their fulfillment of rigorous service-level agreements (slas).
total transparency and complete knowledge of these linked applications is at risk due to factors, such as employee retirement and the ensuing generational transition. up-to-date, consistent documentation of it implementation and the related business functionality are often not available.
an integrated analysis platform
in order to document all context-related elements, establish their relationships, and share them with various stakeholders, you need an integrated, collaborative analysis platform. that is where information on business functionality is defined in relation to core applications and overriding elements of the it portfolio and enterprise architecture.
this gives all stakeholders a comprehensive, consistent, and central knowledge base for inquiries and decisions.
core application analysis
core application analysis must consider structural (static) and runtime (dynamic) aspects in order to establish the level of complexity and criticality with regard to use of the application.
static application analysis
business and process logic are implemented by source code and the associated program structures and libraries. however, source code often contains more “spaghetti code” than structure, which makes it difficult to recognize and change the business logic.
an ideal analysis platform offers these capabilities:
- analysis tools for cobol, ibm® cics® tables, jcl and natural source code.
- support for 3gl languages and features, such as various programming types like subprograms and copybooks and different product versions.
- interface recognition and documentation.
- automatic generation of application documentation, structure diagrams (e.g., control flow, decision tables), reports and impact analysis in multiple formats (e.g., microsoft® excel®, microsoft® word, pdf and html)
- recognition of databases, database structures, and access types.
- complexity metrics (e.g., mccabe, halstead).
- identification of obsolete or redundant source code.
- web-based tools for interactive navigation of program structures and dependencies.
dynamic analysis of processes
dynamic analysis evaluates an application’s runtime transaction load, database access, user interaction, and service calls during normal operation and peak load times. it provides information on the application’s number of users during a specific window in time and the efficiency with which it handles peak loads.
entire operations assesses batch job operation and whole batch job networks. the processing statuses of all jobs are examined to detect and report any sla breaches and better understand dependencies.
an ideal analysis platform offers these capabilities for dynamic analysis:
- dialog and batch application support.
- source code diagnostics when executed (profiling and code coverage).
- production status monitoring across distributed and heterogeneous platforms.
- detection of critical situations through regular monitoring of system kpis.
- measurement and visualization of completed batch processes and ascertainment of process differences (target vs. actual).
- graphical dashboards for fast and easy evaluation.
analysis of business functionality
the primary purpose of analyzing the core application’s business functionality is to establish the relationship between business and technical elements in order to determine which parts of the application implements which business rules and/or processes. only these correlations can provide a full picture of the application, allowing a fact-based exchange between employees from business units and the it department.
the interface between the static analysis tool natural engineer and aris for business functionality analysis provides knowledge about applications, programs, and relationships in an easy-to-understand fashion for non-technical staff members. it serves as a basis for documentation of business processes and recommendations for improvements and enhancements.
analysis of the it portfolio
the results of the analyses of the core applications and their business functionality will lay the foundation for the overall inventory and analysis of the it portfolio. the it portfolio analysis should map out and evaluate business functionality, applications, technologies, strategy, requirements, projects, and their complex relationships to each other with the aim of optimizing the application landscape and aligning it with the business objectives.
the ideal landscape uses an it portfolio management platform like software ag’s alfabet and includes plans for implementation and compliance governance. it is particularly important here to have clear roles and responsibilities when it comes to gathering information, assessing the portfolio and making portfolio-related decisions. it portfolio-management stakeholders need reliable information about applications and their context. they must also have access to role-specific content, views, functions and workflows.
planning and simulating a strategic it transformation
the results of an analysis of applications, business functionality and the entire it portfolio are the starting point for making decisions that will facilitate a reliable evolution plan to transform your current core application architecture into a future-proof, target architecture. an effective analysis allows the relevant departments to continuously monitor and manage the transformation process as needed. parallel operation of current and target applications during the implementation period means elements of the architecture that are modified or added can be evaluated early on, reducing risks as well as implementation time significantly.
your path to success
a successful transformation requires comprehensive, relevant analysis results. the analysis should be executed in three steps:
- analyze core applications taking into account static and dynamic methods for online and batch processing
- analyze business functionality taking into account the results of step one
- analyze the it portfolio taking into account the results of steps one and two
if necessary, sub-steps can be carried out simultaneously, which can help you arrive at insightful results quickly.
Published at DZone with permission of Toni Petrov. See the original article here.
Opinions expressed by DZone contributors are their own.
New ORM Framework for Kotlin
Future of Software Development: Generative AI Augmenting Roles and Unlocking Co-Innovation
Hiding Data in Cassandra
Getting Started With the YugabyteDB Managed REST API