330 likes | 419 Vues
Learn about implementing change management procedures to enhance the structure and control of software systems during their lifecycle. Understand key concepts, elements, and best practices.
 
                
                E N D
Background • Software systems have grown to be so complex and mission-critical that enterprises cannot afford to develop and maintain software in an unplanned manner. • To add structure and control to the development of large software systems, change management procedures can be implemented.
Change Management • Change management: • Is a standard methodology for performing and recording changes during software development and operation. • Is an essential practice for managing software during its lifecycle, from development through deployment and operation, until it is taken out of service.
Change Management • Change management adds structure and control to the development of software systems as they move from development to operation. • It refers to a standard method for performing and recording changes during software development and operation. • In this presentation, change management is related to managing and controlling software development, maintenance, and operation.
Objectives • Upon completion of this lesson, the learner will be able to: • Explain why change management is an important enterprise management tool. • Describe the key concept of segregation of duties. • Describe the essential elements of change management. • Describe a process for implementing change management. • List the concepts of the Capability Maturity Model.
Why Change Management? • Change management should be used in all phases of software's life: • Development • Testing • Quality assurance (QA) • Production
Segregation of Duties • A key foundation for software change management is the recognition that involving more than one individual in a process may reduce risk. • Good control practices require that duties be assigned to individuals so that one individual does not control all phases of a process or the processing and recording of a transaction.
Segregation of Duties • Some of the best practices for ensuring proper segregation of duties in an IT organization are as follows: • Segregation of duties between development, testing, quality assurance, and production should be documented. • Program developers and program testers should conduct activities on “test” data only. • End users or system operators should not have direct access to program source code. • Functions of creating, installing, and administering software programs should be assigned to different individuals.
Segregation of Duties • Some of the best practices for ensuring proper segregation of duties in an IT organization are as follows (continued): • All accesses and privileges to systems, software, or data should be granted based on the principle of least privilege. • Formal software change management policies and procedures should be enforced throughout the enterprise. • Managers at all levels should review existing and planned processes and systems to ensure proper segregation of duties.
Change Management • Change management practices implement and enforce segregation of duties by adding structure and management oversight to the software development process. • Change management techniques can ensure that only correct and authorized changes, as approved by the management or other authorities, are allowed, following a defined process.
Change Management • Change management has its roots in system engineering, where it is commonly referred to as configuration management.
Elements of Change Management • Elements of change management fit into the four general phases: • Configuration identification • Configuration control • Configuration status accounting • Configuration auditing
Configuration Identification • Configuration identification is the process of identifying which assets need to be managed and controlled. • Depending on the size and complexity of the software project, an appropriate set of data and software (or other assets) must be identified and properly managed. • These identified assets are called configuration items or computer software configuration items.
Configuration Control • Configuration control is the process of controlling changes to items that have been baselined. • Configuration control ensures that only approved changes to a baseline are allowed to be implemented.
Configuration Control • Configuration control provides valuable insight to managers and if a system is being changed, and configuration control is being observed, managers and others concerned will be better informed. • This ensures proper use of assets and avoids unnecessary downtime due to the installation of unapproved changes.
Configuration Status Accounting • Configuration status accounting: • Consists of the procedures for tracking and maintaining data relative to each configuration item in the baseline. • Is closely related to configuration control. • Involves gathering and maintaining information relative to each configuration item.
Configuration Audit • Configuration auditing is the process of verifying that the configuration items are built and maintained according to the requirements, standards, or contractual agreements. • Configuration audits ensure that policies and procedures are being followed, and all configuration items are being properly maintained. • They also ensure that existing documents accurately reflect the status of the systems in operation.
Configuration Audit • The two forms of configuration auditing are functional and physical. • A functional configuration audit verifies that the configuration item performs as defined by the documentation of the software requirements. • A physical configuration audit confirms that all configuration items to be included in a release, change, or upgrade are included and that no additional items are included.
Implementing Change Management • Change management requires some structure and discipline to be effective. • The function of change management is scalable from small to enterprise-level projects.
Implementing Change Management • Change management flow is appropriate for medium to large projects. • It can be adapted to small organizations by: • Having developers work only on their workstations and never on the production system. • Having the system administrator serve in the buildmaster function. The buildmaster is an independent person responsible for compiling and incorporating changed software into an executable image.
Implementing Change Management Change control board process
Software Change Control Software change workflow control
Implementing Change Management • The change management workflow proceeds as follows: • The developer checks out the source code from the code-control tool archive to the development system. • The developer modifies the code and conducts unit testing. • The developer checks the modified code into the code-control tool archive. • The developer notifies the buildmaster that changes are ready for new build and testing/QA. • The buildmaster creates a build with the modified code and compiles the code.
Implementing Change Management • The change management workflow proceeds as follows (continued): • The buildmaster notifies the system administrator that the executable image is ready for testing/QA. • The system administrator moves the executables to the test/QA system. • QA tests the new executables. • If tests are passed, then test/QA notifies the manager, else the process starts again. • Upon manager approval, the system administrator moves the executable to the production system.
Implementing Change Management • The purpose of a change control board (CCB) is to oversee the change management process. • The CCB convenes on a regular basis, usually weekly or monthly. It can, however, also be convened on an emergency or as-needed basis.
Change Control Board (CCB) • The CCB's membership should consist of: • Development project managers • Network administrators • System administrators • Test/QA managers • An information security manager • An operations center manager • A help desk manager
Software Problem Report (SPR) • The SPR documents changes or corrections to a software system. • It reflects: • Who requested the change and why. • What analysis must be done and by whom. • How it was corrected or implemented.
Code Integrity • One key benefit of adequate change management is the assurance of code consistency and integrity. • Whenever a modified program is moved to the production source-code library, the executable version should also be moved to the production system. • Automated change management systems greatly simplify this process and, hence, are better controls for ensuring executable and source-code integrity.
Code Integrity • It is a common hacking technique to replace key system executable code with the modified code that may contain backdoors. This allows unauthorized access or functions to be performed. • Executable code integrity can be verified using a variety of host-based intrusion detection systems.
Code Integrity • The host-based intrusion detection systems create and maintain a database of the size and content of executable modules. • This is accomplished by performing some kind of hashing or sophisticated checksum operation on the executable modules and storing the results in a database.
Capability Maturity Model • The CMM: • Relies on configuration or change management as one of its fundamental concepts. • Provides organizations with the capability to improve their software processes by providing an evolutionary path from ad hoc processes to disciplined software management processes.
The Capability Maturity Model • The five maturity levels are: • Initial – The software process is ad hoc. • Repeatable – The software process is structured enough that success with one project can be repeated for another similar project. • Defined – The software process is standardized and documented.
The Capability Maturity Model • The five maturity levels are (continued): • Managed – Various aspects of the software process and products are measured and evaluated. • Optimizing – Key business processes and their supporting software projects are continuously improved based on measurements and testing new ideas.