SlideShare une entreprise Scribd logo
1  sur  51
Configuration management




©Ian Sommerville 2004   Software Engineering, 7th edition. Chapter 29   Slide 1
Objectives
           To explain the importance of software
           configuration management (CM)
           To describe key CM activities namely CM
           planning, change management, version
           management and system building
           To discuss the use of CASE tools to support
           configuration management processes




©Ian Sommerville 2004   Software Engineering, 7th edition. Chapter 29   Slide 2
Topics covered
           Configuration management planning
           Change management
           Version and release management
           System building
           CASE tools for configuration management




©Ian Sommerville 2004     Software Engineering, 7th edition. Chapter 29   Slide 3
Configuration management
           New versions of software systems are
           created as they change:
             •     For different machines/OS;
             •     Offering different functionality;
             •     Tailored for particular user requirements.
           Configuration management is concerned
           with managing evolving software systems:
             •     System change is a team activity;
             •     CM aims to control the costs and effort involved
                   in making changes to a system.


©Ian Sommerville 2004        Software Engineering, 7th edition. Chapter 29   Slide 4
Configuration management
           Involves the development and application of
           procedures and standards to manage an
           evolving software product.
           CM may be seen as part of a more general
           quality management process.
           When released to CM, software systems are
           sometimes called baselines as they are a
           starting point for further development.



©Ian Sommerville 2004   Software Engineering, 7th edition. Chapter 29   Slide 5
Hind
          Prsio
         vWv
         PCS  D
          e vrsr
              vr
              e
            vrs
            ev
        Initial
        systeme
            Lin
                        System families




            e
          Sun
         vrsio
          e
©Ian Sommerville 2004      Software Engineering, 7th edition. Chapter 29   Slide 6
CM standards
           CM should always be based on a set of standards
           which are applied within an organisation.
           Standards should define how items are identified,
           how changes are controlled and how new versions
           are managed.
           Standards may be based on external CM standards
           (e.g. IEEE standard for CM).
           Some existing standards are based on a waterfall
           process model - new CM standards are needed for
           evolutionary development.


©Ian Sommerville 2004     Software Engineering, 7th edition. Chapter 29   Slide 7
Concurrent development and testing

            A time (say 2pm) for delivery of system
            components is agreed.
            A new version of a system is built from these
            components by compiling and linking them.
            This new version is delivered for testing
            using pre-defined tests.
            Faults that are discovered during testing are
            documented and returned to the system
            developers.


©Ian Sommerville 2004   Software Engineering, 7th edition. Chapter 29   Slide 8
Frequent system building
            It is easier to find problems that stem from
            component interactions early in the process.
            This encourages thorough unit testing -
            developers are under pressure not to ‘break
            the build’.
            A stringent change management process is
            required to keep track of problems that have
            been discovered and repaired.



©Ian Sommerville 2004   Software Engineering, 7th edition. Chapter 29   Slide 9
Configuration management planning
           All products of the software process may
           have to be managed:
             •     Specifications;
             •     Designs;
             •     Programs;
             •     Test data;
             •     User manuals.
           Thousands of separate documents may be
           generated for a large, complex software
           system.

©Ian Sommerville 2004        Software Engineering, 7th edition. Chapter 29   Slide 10
The CM plan
           Defines the types of documents to be
           managed and a document naming scheme.
           Defines who takes responsibility for the CM
           procedures and creation of baselines.
           Defines policies for change control and
           version management.
           Defines the CM records which must be
           maintained.


©Ian Sommerville 2004    Software Engineering, 7th edition. Chapter 29   Slide 11
The CM plan
           Describes the tools which should be used to
           assist the CM process and any limitations on
           their use.
           Defines the process of tool use.
           Defines the CM database used to record
           configuration information.
           May include information such as the CM of
           external software, process auditing, etc.


©Ian Sommerville 2004    Software Engineering, 7th edition. Chapter 29   Slide 12
Configuration item identification
           Large projects typically produce thousands of
           documents which must be uniquely identified.
           Some of these documents must be maintained for
           the lifetime of the software.
           Document naming scheme should be defined
           so that related documents have related names.
           A hierarchical scheme with multi-level names is
           probably the most flexible approach.
             •     PCL-TOOLS/EDIT/FORMS/DISPLAY/AST-INTERFACE/CODE




©Ian Sommerville 2004        Software Engineering, 7th edition. Chapter 29   Slide 13
PCL
              -MGE
              T OL
              O
            CDRS
            O EMA
            PMHL
            IBTE
            LS R
             I ED
             NE
                Configuration hierarchy



             FOR
            DIYUC
            SP RY
             LFOR
             AEQ
               U
          FOR
          M-SP
          ENTER
           CFA
            AS
            TTS
            -CE
           OB
           JCSM-I
             I DE
           ETES
           CO
©Ian Sommerville 2004   Software Engineering, 7th edition. Chapter 29   Slide 14
The configuration database
           All CM information should be maintained in a
           configuration database.
           This should allow queries about configurations to be
           answered:
             •     Who has a particular system version?
             •     What platform is required for a particular version?
             •     What versions are affected by a change to component X?
             •     How many reported faults in version T?
           The CM database should preferably be linked to the
           software being managed.



©Ian Sommerville 2004         Software Engineering, 7th edition. Chapter 29   Slide 15
CM database implementation
           May be part of an integrated environment to
           support software development.
             •     The CM database and the managed documents
                   are all maintained on the same system
           CASE tools may be integrated with this so
           that there is a close relationship between the
           CASE tools and the CM tools.
           More commonly, the CM database is
           maintained separately as this is cheaper and
           more flexible.


©Ian Sommerville 2004      Software Engineering, 7th edition. Chapter 29   Slide 16
Change management
           Software systems are subject to continual
           change requests:
             •     From users;
             •     From developers;
             •     From market forces.
           Change management is concerned with
           keeping track of these changes and ensuring
           that they are implemented in the most cost-
           effective way.


©Ian Sommerville 2004       Software Engineering, 7th edition. Chapter 29   Slide 17
The change management process
          Request change by completing a change request form
          Analyze change request
          if change is valid then
             Assess how change might be implemented
              Assess change cost
             Submit request to change control board
              if change is accepted then
                  repeat
                  make changes to software
                  submit changed software for quality approval
                 until software quality is adequate
             create new system version
           else
             reject change request
          else
              reject change request



©Ian Sommerville 2004           Software Engineering, 7th edition. Chapter 29   Slide 18
Change request form
           The definition of a change request form is part of the

           CM planning process.
           This form records the change proposed, requestor of
           change, the reason why change was suggested and
           the urgency of change(from requestor of the
           change).
           It also records change evaluation, impact analysis,
           change cost and recommendations (System
           maintenance staff).



©Ian Sommerville 2004     Software Engineering, 7th edition. Chapter 29   Slide 19
ChangeaR
           Pr Analys
           oject: a
            Proteus/P
              ools
                 Numb
                 23/02
           Change ro
            equester:
             I. Somm
                 Date:
                 1/12/0
           Requested
             When
           the name
                    Change request form


           Change a
             G. Dean
                 10/12
           Compone
              Display-
           Associate
              FileT p
              able
           Change im
             Relative
           available.
           toLow
               associat
           Change C
           Estimated
             0.5CCB o
                  days
           Date decis
           CCB to im
             15/12/02
           Change  1/2/0
             Accept c
                   deci
                 Date
           Date subm
                 QA
           Comment
©Ian Sommerville 2004    Software Engineering, 7th edition. Chapter 29   Slide 20
Change tracking tools
           A major problem in change management is
           tracking change status.
           Change tracking tools keep track the status
           of each change request and automatically
           ensure that change requests are sent to the
           right people at the right time.
           Integrated with E-mail systems allowing
           electronic change request distribution.



©Ian Sommerville 2004    Software Engineering, 7th edition. Chapter 29   Slide 21
Change control board
           Changes should be reviewed by an external group
           who decide whether or not they are cost-effective
           from a strategic and organizational viewpoint rather
           than a technical viewpoint.
           Should be independent of project responsible
           for system. The group is sometimes called a change
           control board.
           The CCB may include representatives from client
           and contractor staff.




©Ian Sommerville 2004    Software Engineering, 7th edition. Chapter 29   Slide 22
Derivation history
           This is a record of changes applied to a
           document or code component.
           It should record, in outline, the change made,
           the rationale for the change, who made the
           change and when it was implemented.
           It may be included as a comment in code. If
           a standard prologue style is used for the
           derivation history, tools can process this
           automatically.


©Ian Sommerville 2004       Software Engineering, 7th edition. Chapter 29   Slide 23
Component header information




©Ian Sommerville 2004   Software Engineering, 7th edition. Chapter 29   Slide 24
Version and release management

           Invent an identification scheme for system
           versions.
           Plan when a new system version is to be
           produced.
           Ensure that version management procedures
           and tools are properly applied.
           Plan and distribute new system releases.




©Ian Sommerville 2004   Software Engineering, 7th edition. Chapter 29   Slide 25
Versions/variants/releases
           Version An instance of a system which is
           functionally distinct in some way from other
           system instances.
           Variant An instance of a system which is
           functionally identical but non-functionally
           distinct from other instances of a system.
           Release An instance of a system which is
           distributed to users outside of the
           development team.


©Ian Sommerville 2004   Software Engineering, 7th edition. Chapter 29   Slide 26
Version identification
            Procedures for version identification should
            define an unambiguous way of identifying
            component versions.
            There are three basic techniques for
            component identification
             •     Version numbering;
             •     Attribute-based identification;
             •     Change-oriented identification.




©Ian Sommerville 2004        Software Engineering, 7th edition. Chapter 29   Slide 27
Version numbering
           Simple naming scheme uses a linear
           derivation
             •     V1, V1.1, V1.2, V2.1, V2.2 etc.
           The actual derivation structure is a tree or a
           network rather than a sequence.
           Names are not meaningful.
           A hierarchical naming scheme leads to fewer
           errors in version identification.


©Ian Sommerville 2004        Software Engineering, 7th edition. Chapter 29   Slide 28
V1.1b
        V1.1
          Version derivation structure




      V1.0V
       V1.1
        V1.2
         V2.
          V2
       V1.1a
©Ian Sommerville 2004   Software Engineering, 7th edition. Chapter 29   Slide 29
Attribute-based identification
           Attributes can be associated with a version with
           the combination of attributes identifying that
           version
             •     Examples of attributes are Date, Creator,
                   Programming Language, Customer, Status etc.
           This is more flexible than an explicit naming scheme

           for version retrieval; However, it can cause problems
           with uniqueness - the set of attributes have to be
           chosen so that all versions can be uniquely
           identified.
           In practice, a version also needs an associated
           name for easy reference.

©Ian Sommerville 2004         Software Engineering, 7th edition. Chapter 29   Slide 30
Attribute-based queries
            An important advantage of attribute-based
            identification is that it can support queries so
            that you can find ‘the most recent version in
            Java’ etc.
            The query selects a version depending on
            attribute values
             •     AC3D (language =Java, platform = XP, date =
                   Jan 2003).




©Ian Sommerville 2004       Software Engineering, 7th edition. Chapter 29   Slide 31
Change-oriented identification
            Integrates versions and the changes made to create
            these versions.
            Used for systems rather than components.
            Each proposed change has a change set that
            describes changes made to implement that change.
            Change sets are applied in sequence so that, in
            principle, a version of the system that incorporates
            an arbitrary set of changes may be created.




©Ian Sommerville 2004     Software Engineering, 7th edition. Chapter 29   Slide 32
Release management
           Releases must incorporate changes forced
           on the system by errors discovered by users
           and by hardware changes.
           They must also incorporate new system
           functionality.
           Release planning is concerned with when to
           issue a system version as a release.




©Ian Sommerville 2004   Software Engineering, 7th edition. Chapter 29   Slide 33
System releases
           Not just a set of executable programs.
           May also include:
             •     Configuration files defining how the release is configured
                   for a particular installation;
             •     Data files needed for system operation;
             •     An installation program or shell script to install the system
                   on target hardware;
             •     Electronic and paper documentation;
             •     Packaging and associated publicity.
           Systems are now normally released on optical disks
           (CD or DVD) or as downloadable installation files
           from the web.


©Ian Sommerville 2004           Software Engineering, 7th edition. Chapter 29   Slide 34
Release problems
           Customer may not want a new release of the

           system
             •     They may be happy with their current system as
                   the new version may provide unwanted
                   functionality.
           Release management should not assume
           that all previous releases have been
           accepted. All files required for a release
           should be re-created when a new release is
           installed.

©Ian Sommerville 2004       Software Engineering, 7th edition. Chapter 29   Slide 35
Release decision making
            Preparing and distributing a system release
            is an expensive process.
            Factors such as the technical quality of the
            system, competition, marketing requirements
            and customer change requests should all
            influence the decision of when to issue a
            new system release.




©Ian Sommerville 2004   Software Engineering, 7th edition. Chapter 29   Slide 36
System release strategy
     Factor                 Description
     Technical quality of   If serious system faults are reported which affect the way in which
     the system             many customers use the system, it may be necessary to issue a fault
                            repair release. However, minor system faults may be repaired by issuing
                            patches (often distributed over the Internet) that can be applied to the
                            current release of the system.
     Platform changes       You may have to create a new release of a software application when a
                            new version of the operating system platform is released.
     Lehman’s fifth law     This suggests that the increment of functionality that is included in each
     (see Chapter 21)       release is approximately constant. Therefore, if there has been a system
                            release with significant new functionality, then it may have to be
                            followed by a repair release.
     Competition            A new system release may be necessary because a competing product is
                            available.
     Marketing              The marketing department of an organisation may have made a
     requirements           commitment for releases to be available at a particular date.
     Customer change        For customised systems, customers may have made and paid for a
     proposals              specific set of system change proposals and they expect a system release
                            as soon as these have been implemented.


©Ian Sommerville 2004                   Software Engineering, 7th edition. Chapter 29                    Slide 37
Release creation
            Release creation involves collecting all files
            and documentation required to create a
            system release.
            Configuration descriptions have to be written
            for different hardware and installation scripts
            have to be written.
            The specific release must be documented to
            record exactly what files were used to create
            it. This allows it to be re-created if
            necessary.
©Ian Sommerville 2004      Software Engineering, 7th edition. Chapter 29   Slide 38
System building
           The process of compiling and linking
           software components into an executable
           system.
           Different systems are built from different
           combinations of components.
           This process is now always supported by
           automated tools that are driven by ‘build
           scripts’.



©Ian Sommerville 2004      Software Engineering, 7th edition. Chapter 29   Slide 39
System building problems
        Do the build instructions include all required
        components?
          •     When there are many hundreds of components making up
                a system, it is easy to miss one out. This should normally
                be detected by the linker.
        Is the appropriate component version
        specified?
          •     A more significant problem. A system built with the wrong
                version may work initially but fail after delivery.
        Are all data files available?
          •     The build should not rely on 'standard' data files. Standards
                vary from place to place.




©Ian Sommerville 2004         Software Engineering, 7th edition. Chapter 29   Slide 40
System building problems
    Are data file references within components
    correct?
      •     Embedding absolute names in code almost always causes
            problems as naming conventions differ from place to place.
    Is the system being built for the right platform
      •     Sometimes you must build for a specific OS version or
            hardware configuration.
    Is the right version of the compiler and other
    software tools specified?
      •     Different compiler versions may actually generate different
            code and the compiled component will exhibit different
            behaviour.



©Ian Sommerville 2004        Software Engineering, 7th edition. Chapter 29   Slide 41
VCom
        ersion
      Sstem
      y manag
            Li
                        System building


      builder
        system
         Sourc
      Build Ey
          Obj
         comp
      script s
          com
         versi
©Ian Sommerville 2004      Software Engineering, 7th edition. Chapter 29   Slide 42
CASE tools for configuration management
            CM processes are standardised and involve
            applying pre-defined procedures.
            Large amounts of data must be managed.
            CASE tool support for CM is therefore
            essential.
            Mature CASE tools to support configuration
            management are available ranging from
            stand-alone tools to integrated CM
            workbenches.


©Ian Sommerville 2004   Software Engineering, 7th edition. Chapter 29   Slide 43
CM workbenches
            Open workbenches
             •     Tools for each stage in the CM process are
                   integrated through organisational procedures
                   and scripts. Gives flexibility in tool selection.
            Integrated workbenches
             •     Provide whole-process, integrated support for
                   configuration management. More tightly
                   integrated tools so easier to use. However, the
                   cost is less flexibility in the tools used.



©Ian Sommerville 2004         Software Engineering, 7th edition. Chapter 29   Slide 44
Change management tools
            Change management is a procedural process so it
            can be modelled and integrated with a version
            management system.
            Change management tools
             •     Form editor to support processing the change request
                   forms;
             •     Workflow system to define who does what and to
                   automate information transfer;
             •     Change database that manages change proposals and is
                   linked to a VM system;
             •     Change reporting system that generates management
                   reports on the status of change requests.



©Ian Sommerville 2004         Software Engineering, 7th edition. Chapter 29   Slide 45
Version management tools
           Version and release identification
             •     Systems assign identifiers automatically when a new version is
                   submitted to the system.
           Storage management.
             •     System stores the differences between versions rather than all
                   the version code.
           Change history recording
             •     Record reasons for version creation.
           Independent development
             •     Only one version at a time may be checked out for change.
                   Parallel working on different versions.
           Project support
             •     Can manage groups of files associated with a project rather than
                   just single files.



©Ian Sommerville 2004           Software Engineering, 7th edition. Chapter 29   Slide 46
VVVV
     eD1D3
      rsionr
       eD2
        rsio
         ers
     1.01.2
       1.11e
                 Delta-based versioning




          Ca
          ete
           ti
©Ian Sommerville 2004   Software Engineering, 7th edition. Chapter 29   Slide 47
System building
            Building a large system is computationally
            expensive and may take several hours.
            Hundreds of files may be involved.
            System building tools may provide
             •     A dependency specification language and
                   interpreter;
             •     Tool selection and instantiation support;
             •     Distributed compilation;
             •     Derived object management.


©Ian Sommerville 2004        Software Engineering, 7th edition. Chapter 29   Slide 48
comp
            Component dependencies



                 scan.o
                  syn.o
                    sem
                     cge
                 scan.o
                  syn.o
                    sem
                     cge
                  defs.h
©Ian Sommerville 2004   Software Engineering, 7th edition. Chapter 29   Slide 49
Key points
           Configuration management is the management of
           system change to software products.
           A formal document naming scheme should be
           established and documents should be managed in a
           database.
           The configuration data base should record
           information about changes and change requests.
           A consistent scheme of version identification should
           be established using version numbers, attributes or
           change sets.




©Ian Sommerville 2004    Software Engineering, 7th edition. Chapter 29   Slide 50
Key points
           System releases include executable code, data,
           configuration files and documentation.
           System building involves assembling components
           into a system..
            CASE tools are available to support all CM activities
           CASE tools may be stand-alone tools or may be
           integrated systems which integrate support for
           version management, system building and change
           management.




©Ian Sommerville 2004     Software Engineering, 7th edition. Chapter 29   Slide 51

Contenu connexe

Tendances

Ch25-Software Engineering 9
Ch25-Software Engineering 9Ch25-Software Engineering 9
Ch25-Software Engineering 9
Ian Sommerville
 
Introduction to Software Evolution: The Software Volcano
Introduction to Software Evolution: The Software VolcanoIntroduction to Software Evolution: The Software Volcano
Introduction to Software Evolution: The Software Volcano
Devnology
 
Ch9-Software Engineering 9
Ch9-Software Engineering 9Ch9-Software Engineering 9
Ch9-Software Engineering 9
Ian Sommerville
 
Ch24-Software Engineering 9
Ch24-Software Engineering 9Ch24-Software Engineering 9
Ch24-Software Engineering 9
Ian Sommerville
 
EMPIRICALLY VALIDATED SIMPLICITY EVALUATION MODEL FOR OBJECT ORIENTED SOFTWARE
EMPIRICALLY VALIDATED SIMPLICITY EVALUATION MODEL FOR OBJECT ORIENTED SOFTWAREEMPIRICALLY VALIDATED SIMPLICITY EVALUATION MODEL FOR OBJECT ORIENTED SOFTWARE
EMPIRICALLY VALIDATED SIMPLICITY EVALUATION MODEL FOR OBJECT ORIENTED SOFTWARE
ijseajournal
 

Tendances (20)

Ch25-Software Engineering 9
Ch25-Software Engineering 9Ch25-Software Engineering 9
Ch25-Software Engineering 9
 
Ch3. agile sw dev
Ch3. agile sw devCh3. agile sw dev
Ch3. agile sw dev
 
Introduction to Software Evolution: The Software Volcano
Introduction to Software Evolution: The Software VolcanoIntroduction to Software Evolution: The Software Volcano
Introduction to Software Evolution: The Software Volcano
 
Ch9-Software Engineering 9
Ch9-Software Engineering 9Ch9-Software Engineering 9
Ch9-Software Engineering 9
 
Ch2 sw processes
Ch2 sw processesCh2 sw processes
Ch2 sw processes
 
Software Evolution and Maintenance Models
Software Evolution and Maintenance ModelsSoftware Evolution and Maintenance Models
Software Evolution and Maintenance Models
 
Ian Sommerville, Software Engineering, 9th Edition Ch 4
Ian Sommerville,  Software Engineering, 9th Edition Ch 4Ian Sommerville,  Software Engineering, 9th Edition Ch 4
Ian Sommerville, Software Engineering, 9th Edition Ch 4
 
1 se-introduction
1 se-introduction1 se-introduction
1 se-introduction
 
Software Maintenance
Software MaintenanceSoftware Maintenance
Software Maintenance
 
Ch4 req eng
Ch4 req engCh4 req eng
Ch4 req eng
 
Software maintenance
Software maintenanceSoftware maintenance
Software maintenance
 
Types of operating system
Types of operating systemTypes of operating system
Types of operating system
 
Software evolution and maintenance basic concepts and preliminaries
Software evolution and maintenance   basic concepts and preliminariesSoftware evolution and maintenance   basic concepts and preliminaries
Software evolution and maintenance basic concepts and preliminaries
 
Software Evolution
Software EvolutionSoftware Evolution
Software Evolution
 
Developing reusable software components for distributed embedded systems
Developing reusable software components for distributed embedded systemsDeveloping reusable software components for distributed embedded systems
Developing reusable software components for distributed embedded systems
 
Ch24-Software Engineering 9
Ch24-Software Engineering 9Ch24-Software Engineering 9
Ch24-Software Engineering 9
 
Ch1 introduction
Ch1 introductionCh1 introduction
Ch1 introduction
 
EMPIRICALLY VALIDATED SIMPLICITY EVALUATION MODEL FOR OBJECT ORIENTED SOFTWARE
EMPIRICALLY VALIDATED SIMPLICITY EVALUATION MODEL FOR OBJECT ORIENTED SOFTWAREEMPIRICALLY VALIDATED SIMPLICITY EVALUATION MODEL FOR OBJECT ORIENTED SOFTWARE
EMPIRICALLY VALIDATED SIMPLICITY EVALUATION MODEL FOR OBJECT ORIENTED SOFTWARE
 
Ch11 reliability engineering
Ch11 reliability engineeringCh11 reliability engineering
Ch11 reliability engineering
 
Ijsea04021003
Ijsea04021003Ijsea04021003
Ijsea04021003
 

En vedette

En vedette (14)

PME
PMEPME
PME
 
Folkestone community market presentation
Folkestone community market presentationFolkestone community market presentation
Folkestone community market presentation
 
Startup assignment
Startup assignmentStartup assignment
Startup assignment
 
Laboratories
LaboratoriesLaboratories
Laboratories
 
Narrative
NarrativeNarrative
Narrative
 
Quality management 27
Quality management 27Quality management 27
Quality management 27
 
Conversation
ConversationConversation
Conversation
 
Tietoyhteiskuntaan liittyvästä juridisesta sääntelystä
Tietoyhteiskuntaan liittyvästä juridisesta sääntelystäTietoyhteiskuntaan liittyvästä juridisesta sääntelystä
Tietoyhteiskuntaan liittyvästä juridisesta sääntelystä
 
Permenpan2015 006
Permenpan2015 006Permenpan2015 006
Permenpan2015 006
 
Case Study of Naaptol published in Open Source For You magazine
Case Study of Naaptol published in Open Source For You magazine Case Study of Naaptol published in Open Source For You magazine
Case Study of Naaptol published in Open Source For You magazine
 
indikator pelaksanaan tugas pengamanan lapas
indikator pelaksanaan tugas pengamanan lapasindikator pelaksanaan tugas pengamanan lapas
indikator pelaksanaan tugas pengamanan lapas
 
Perpres no.44 tahun 2015 tentang kementerian hukum dan ham
Perpres no.44 tahun 2015 tentang kementerian hukum dan hamPerpres no.44 tahun 2015 tentang kementerian hukum dan ham
Perpres no.44 tahun 2015 tentang kementerian hukum dan ham
 
Ch28
Ch28Ch28
Ch28
 
secuencia didactica PEGUI el sistema solar desde la enseñanza tic
secuencia didactica PEGUI el sistema solar desde la enseñanza ticsecuencia didactica PEGUI el sistema solar desde la enseñanza tic
secuencia didactica PEGUI el sistema solar desde la enseñanza tic
 

Similaire à Configuration management24 (20)

Ch9
Ch9Ch9
Ch9
 
ch1.ppt
ch1.pptch1.ppt
ch1.ppt
 
01 unidad i introduccion
01 unidad i   introduccion01 unidad i   introduccion
01 unidad i introduccion
 
Se ii unit1-se_ii_intorduction
Se ii unit1-se_ii_intorductionSe ii unit1-se_ii_intorduction
Se ii unit1-se_ii_intorduction
 
Introduction to Software Enigneering
Introduction to Software Enigneering Introduction to Software Enigneering
Introduction to Software Enigneering
 
softwareMaintenance.pdf
softwareMaintenance.pdfsoftwareMaintenance.pdf
softwareMaintenance.pdf
 
Software Process Models
Software Process ModelsSoftware Process Models
Software Process Models
 
3 introduction
3 introduction3 introduction
3 introduction
 
SE2013_10.ppt
SE2013_10.pptSE2013_10.ppt
SE2013_10.ppt
 
962 sech04
962 sech04962 sech04
962 sech04
 
SE notes 2.pdf
SE notes 2.pdfSE notes 2.pdf
SE notes 2.pdf
 
Ch25
Ch25Ch25
Ch25
 
Lecture-17.ppt
Lecture-17.pptLecture-17.ppt
Lecture-17.ppt
 
Evolution-2.ppt
Evolution-2.pptEvolution-2.ppt
Evolution-2.ppt
 
Ch2.Part2.Modified.ppt
Ch2.Part2.Modified.pptCh2.Part2.Modified.ppt
Ch2.Part2.Modified.ppt
 
0273710133 pp01v2
0273710133 pp01v20273710133 pp01v2
0273710133 pp01v2
 
software configuration management
software configuration managementsoftware configuration management
software configuration management
 
Software Engineering - Ch17
Software Engineering - Ch17Software Engineering - Ch17
Software Engineering - Ch17
 
Ch1
Ch1Ch1
Ch1
 
Software Processes
Software ProcessesSoftware Processes
Software Processes
 

Dernier

Dernier (20)

Single or Multiple melodic lines structure
Single or Multiple melodic lines structureSingle or Multiple melodic lines structure
Single or Multiple melodic lines structure
 
NO1 Top Black Magic Specialist In Lahore Black magic In Pakistan Kala Ilam Ex...
NO1 Top Black Magic Specialist In Lahore Black magic In Pakistan Kala Ilam Ex...NO1 Top Black Magic Specialist In Lahore Black magic In Pakistan Kala Ilam Ex...
NO1 Top Black Magic Specialist In Lahore Black magic In Pakistan Kala Ilam Ex...
 
On National Teacher Day, meet the 2024-25 Kenan Fellows
On National Teacher Day, meet the 2024-25 Kenan FellowsOn National Teacher Day, meet the 2024-25 Kenan Fellows
On National Teacher Day, meet the 2024-25 Kenan Fellows
 
REMIFENTANIL: An Ultra short acting opioid.pptx
REMIFENTANIL: An Ultra short acting opioid.pptxREMIFENTANIL: An Ultra short acting opioid.pptx
REMIFENTANIL: An Ultra short acting opioid.pptx
 
ICT Role in 21st Century Education & its Challenges.pptx
ICT Role in 21st Century Education & its Challenges.pptxICT Role in 21st Century Education & its Challenges.pptx
ICT Role in 21st Century Education & its Challenges.pptx
 
Python Notes for mca i year students osmania university.docx
Python Notes for mca i year students osmania university.docxPython Notes for mca i year students osmania university.docx
Python Notes for mca i year students osmania university.docx
 
Google Gemini An AI Revolution in Education.pptx
Google Gemini An AI Revolution in Education.pptxGoogle Gemini An AI Revolution in Education.pptx
Google Gemini An AI Revolution in Education.pptx
 
Understanding Accommodations and Modifications
Understanding  Accommodations and ModificationsUnderstanding  Accommodations and Modifications
Understanding Accommodations and Modifications
 
2024-NATIONAL-LEARNING-CAMP-AND-OTHER.pptx
2024-NATIONAL-LEARNING-CAMP-AND-OTHER.pptx2024-NATIONAL-LEARNING-CAMP-AND-OTHER.pptx
2024-NATIONAL-LEARNING-CAMP-AND-OTHER.pptx
 
How to Give a Domain for a Field in Odoo 17
How to Give a Domain for a Field in Odoo 17How to Give a Domain for a Field in Odoo 17
How to Give a Domain for a Field in Odoo 17
 
HMCS Vancouver Pre-Deployment Brief - May 2024 (Web Version).pptx
HMCS Vancouver Pre-Deployment Brief - May 2024 (Web Version).pptxHMCS Vancouver Pre-Deployment Brief - May 2024 (Web Version).pptx
HMCS Vancouver Pre-Deployment Brief - May 2024 (Web Version).pptx
 
Jamworks pilot and AI at Jisc (20/03/2024)
Jamworks pilot and AI at Jisc (20/03/2024)Jamworks pilot and AI at Jisc (20/03/2024)
Jamworks pilot and AI at Jisc (20/03/2024)
 
SOC 101 Demonstration of Learning Presentation
SOC 101 Demonstration of Learning PresentationSOC 101 Demonstration of Learning Presentation
SOC 101 Demonstration of Learning Presentation
 
Key note speaker Neum_Admir Softic_ENG.pdf
Key note speaker Neum_Admir Softic_ENG.pdfKey note speaker Neum_Admir Softic_ENG.pdf
Key note speaker Neum_Admir Softic_ENG.pdf
 
Micro-Scholarship, What it is, How can it help me.pdf
Micro-Scholarship, What it is, How can it help me.pdfMicro-Scholarship, What it is, How can it help me.pdf
Micro-Scholarship, What it is, How can it help me.pdf
 
General Principles of Intellectual Property: Concepts of Intellectual Proper...
General Principles of Intellectual Property: Concepts of Intellectual  Proper...General Principles of Intellectual Property: Concepts of Intellectual  Proper...
General Principles of Intellectual Property: Concepts of Intellectual Proper...
 
Wellbeing inclusion and digital dystopias.pptx
Wellbeing inclusion and digital dystopias.pptxWellbeing inclusion and digital dystopias.pptx
Wellbeing inclusion and digital dystopias.pptx
 
Unit 3 Emotional Intelligence and Spiritual Intelligence.pdf
Unit 3 Emotional Intelligence and Spiritual Intelligence.pdfUnit 3 Emotional Intelligence and Spiritual Intelligence.pdf
Unit 3 Emotional Intelligence and Spiritual Intelligence.pdf
 
Graduate Outcomes Presentation Slides - English
Graduate Outcomes Presentation Slides - EnglishGraduate Outcomes Presentation Slides - English
Graduate Outcomes Presentation Slides - English
 
On_Translating_a_Tamil_Poem_by_A_K_Ramanujan.pptx
On_Translating_a_Tamil_Poem_by_A_K_Ramanujan.pptxOn_Translating_a_Tamil_Poem_by_A_K_Ramanujan.pptx
On_Translating_a_Tamil_Poem_by_A_K_Ramanujan.pptx
 

Configuration management24

  • 1. Configuration management ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 1
  • 2. Objectives To explain the importance of software configuration management (CM) To describe key CM activities namely CM planning, change management, version management and system building To discuss the use of CASE tools to support configuration management processes ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 2
  • 3. Topics covered Configuration management planning Change management Version and release management System building CASE tools for configuration management ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 3
  • 4. Configuration management New versions of software systems are created as they change: • For different machines/OS; • Offering different functionality; • Tailored for particular user requirements. Configuration management is concerned with managing evolving software systems: • System change is a team activity; • CM aims to control the costs and effort involved in making changes to a system. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 4
  • 5. Configuration management Involves the development and application of procedures and standards to manage an evolving software product. CM may be seen as part of a more general quality management process. When released to CM, software systems are sometimes called baselines as they are a starting point for further development. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 5
  • 6. Hind Prsio vWv PCS D e vrsr vr e vrs ev Initial systeme Lin System families e Sun vrsio e ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 6
  • 7. CM standards CM should always be based on a set of standards which are applied within an organisation. Standards should define how items are identified, how changes are controlled and how new versions are managed. Standards may be based on external CM standards (e.g. IEEE standard for CM). Some existing standards are based on a waterfall process model - new CM standards are needed for evolutionary development. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 7
  • 8. Concurrent development and testing A time (say 2pm) for delivery of system components is agreed. A new version of a system is built from these components by compiling and linking them. This new version is delivered for testing using pre-defined tests. Faults that are discovered during testing are documented and returned to the system developers. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 8
  • 9. Frequent system building It is easier to find problems that stem from component interactions early in the process. This encourages thorough unit testing - developers are under pressure not to ‘break the build’. A stringent change management process is required to keep track of problems that have been discovered and repaired. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 9
  • 10. Configuration management planning All products of the software process may have to be managed: • Specifications; • Designs; • Programs; • Test data; • User manuals. Thousands of separate documents may be generated for a large, complex software system. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 10
  • 11. The CM plan Defines the types of documents to be managed and a document naming scheme. Defines who takes responsibility for the CM procedures and creation of baselines. Defines policies for change control and version management. Defines the CM records which must be maintained. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 11
  • 12. The CM plan Describes the tools which should be used to assist the CM process and any limitations on their use. Defines the process of tool use. Defines the CM database used to record configuration information. May include information such as the CM of external software, process auditing, etc. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 12
  • 13. Configuration item identification Large projects typically produce thousands of documents which must be uniquely identified. Some of these documents must be maintained for the lifetime of the software. Document naming scheme should be defined so that related documents have related names. A hierarchical scheme with multi-level names is probably the most flexible approach. • PCL-TOOLS/EDIT/FORMS/DISPLAY/AST-INTERFACE/CODE ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 13
  • 14. PCL -MGE T OL O CDRS O EMA PMHL IBTE LS R I ED NE Configuration hierarchy FOR DIYUC SP RY LFOR AEQ U FOR M-SP ENTER CFA AS TTS -CE OB JCSM-I I DE ETES CO ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 14
  • 15. The configuration database All CM information should be maintained in a configuration database. This should allow queries about configurations to be answered: • Who has a particular system version? • What platform is required for a particular version? • What versions are affected by a change to component X? • How many reported faults in version T? The CM database should preferably be linked to the software being managed. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 15
  • 16. CM database implementation May be part of an integrated environment to support software development. • The CM database and the managed documents are all maintained on the same system CASE tools may be integrated with this so that there is a close relationship between the CASE tools and the CM tools. More commonly, the CM database is maintained separately as this is cheaper and more flexible. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 16
  • 17. Change management Software systems are subject to continual change requests: • From users; • From developers; • From market forces. Change management is concerned with keeping track of these changes and ensuring that they are implemented in the most cost- effective way. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 17
  • 18. The change management process Request change by completing a change request form Analyze change request if change is valid then Assess how change might be implemented Assess change cost Submit request to change control board if change is accepted then repeat make changes to software submit changed software for quality approval until software quality is adequate create new system version else reject change request else reject change request ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 18
  • 19. Change request form The definition of a change request form is part of the CM planning process. This form records the change proposed, requestor of change, the reason why change was suggested and the urgency of change(from requestor of the change). It also records change evaluation, impact analysis, change cost and recommendations (System maintenance staff). ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 19
  • 20. ChangeaR Pr Analys oject: a Proteus/P ools Numb 23/02 Change ro equester: I. Somm Date: 1/12/0 Requested When the name Change request form Change a G. Dean 10/12 Compone Display- Associate FileT p able Change im Relative available. toLow associat Change C Estimated 0.5CCB o days Date decis CCB to im 15/12/02 Change 1/2/0 Accept c deci Date Date subm QA Comment ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 20
  • 21. Change tracking tools A major problem in change management is tracking change status. Change tracking tools keep track the status of each change request and automatically ensure that change requests are sent to the right people at the right time. Integrated with E-mail systems allowing electronic change request distribution. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 21
  • 22. Change control board Changes should be reviewed by an external group who decide whether or not they are cost-effective from a strategic and organizational viewpoint rather than a technical viewpoint. Should be independent of project responsible for system. The group is sometimes called a change control board. The CCB may include representatives from client and contractor staff. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 22
  • 23. Derivation history This is a record of changes applied to a document or code component. It should record, in outline, the change made, the rationale for the change, who made the change and when it was implemented. It may be included as a comment in code. If a standard prologue style is used for the derivation history, tools can process this automatically. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 23
  • 24. Component header information ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 24
  • 25. Version and release management Invent an identification scheme for system versions. Plan when a new system version is to be produced. Ensure that version management procedures and tools are properly applied. Plan and distribute new system releases. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 25
  • 26. Versions/variants/releases Version An instance of a system which is functionally distinct in some way from other system instances. Variant An instance of a system which is functionally identical but non-functionally distinct from other instances of a system. Release An instance of a system which is distributed to users outside of the development team. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 26
  • 27. Version identification Procedures for version identification should define an unambiguous way of identifying component versions. There are three basic techniques for component identification • Version numbering; • Attribute-based identification; • Change-oriented identification. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 27
  • 28. Version numbering Simple naming scheme uses a linear derivation • V1, V1.1, V1.2, V2.1, V2.2 etc. The actual derivation structure is a tree or a network rather than a sequence. Names are not meaningful. A hierarchical naming scheme leads to fewer errors in version identification. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 28
  • 29. V1.1b V1.1 Version derivation structure V1.0V V1.1 V1.2 V2. V2 V1.1a ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 29
  • 30. Attribute-based identification Attributes can be associated with a version with the combination of attributes identifying that version • Examples of attributes are Date, Creator, Programming Language, Customer, Status etc. This is more flexible than an explicit naming scheme for version retrieval; However, it can cause problems with uniqueness - the set of attributes have to be chosen so that all versions can be uniquely identified. In practice, a version also needs an associated name for easy reference. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 30
  • 31. Attribute-based queries An important advantage of attribute-based identification is that it can support queries so that you can find ‘the most recent version in Java’ etc. The query selects a version depending on attribute values • AC3D (language =Java, platform = XP, date = Jan 2003). ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 31
  • 32. Change-oriented identification Integrates versions and the changes made to create these versions. Used for systems rather than components. Each proposed change has a change set that describes changes made to implement that change. Change sets are applied in sequence so that, in principle, a version of the system that incorporates an arbitrary set of changes may be created. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 32
  • 33. Release management Releases must incorporate changes forced on the system by errors discovered by users and by hardware changes. They must also incorporate new system functionality. Release planning is concerned with when to issue a system version as a release. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 33
  • 34. System releases Not just a set of executable programs. May also include: • Configuration files defining how the release is configured for a particular installation; • Data files needed for system operation; • An installation program or shell script to install the system on target hardware; • Electronic and paper documentation; • Packaging and associated publicity. Systems are now normally released on optical disks (CD or DVD) or as downloadable installation files from the web. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 34
  • 35. Release problems Customer may not want a new release of the system • They may be happy with their current system as the new version may provide unwanted functionality. Release management should not assume that all previous releases have been accepted. All files required for a release should be re-created when a new release is installed. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 35
  • 36. Release decision making Preparing and distributing a system release is an expensive process. Factors such as the technical quality of the system, competition, marketing requirements and customer change requests should all influence the decision of when to issue a new system release. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 36
  • 37. System release strategy Factor Description Technical quality of If serious system faults are reported which affect the way in which the system many customers use the system, it may be necessary to issue a fault repair release. However, minor system faults may be repaired by issuing patches (often distributed over the Internet) that can be applied to the current release of the system. Platform changes You may have to create a new release of a software application when a new version of the operating system platform is released. Lehman’s fifth law This suggests that the increment of functionality that is included in each (see Chapter 21) release is approximately constant. Therefore, if there has been a system release with significant new functionality, then it may have to be followed by a repair release. Competition A new system release may be necessary because a competing product is available. Marketing The marketing department of an organisation may have made a requirements commitment for releases to be available at a particular date. Customer change For customised systems, customers may have made and paid for a proposals specific set of system change proposals and they expect a system release as soon as these have been implemented. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 37
  • 38. Release creation Release creation involves collecting all files and documentation required to create a system release. Configuration descriptions have to be written for different hardware and installation scripts have to be written. The specific release must be documented to record exactly what files were used to create it. This allows it to be re-created if necessary. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 38
  • 39. System building The process of compiling and linking software components into an executable system. Different systems are built from different combinations of components. This process is now always supported by automated tools that are driven by ‘build scripts’. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 39
  • 40. System building problems Do the build instructions include all required components? • When there are many hundreds of components making up a system, it is easy to miss one out. This should normally be detected by the linker. Is the appropriate component version specified? • A more significant problem. A system built with the wrong version may work initially but fail after delivery. Are all data files available? • The build should not rely on 'standard' data files. Standards vary from place to place. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 40
  • 41. System building problems Are data file references within components correct? • Embedding absolute names in code almost always causes problems as naming conventions differ from place to place. Is the system being built for the right platform • Sometimes you must build for a specific OS version or hardware configuration. Is the right version of the compiler and other software tools specified? • Different compiler versions may actually generate different code and the compiled component will exhibit different behaviour. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 41
  • 42. VCom ersion Sstem y manag Li System building builder system Sourc Build Ey Obj comp script s com versi ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 42
  • 43. CASE tools for configuration management CM processes are standardised and involve applying pre-defined procedures. Large amounts of data must be managed. CASE tool support for CM is therefore essential. Mature CASE tools to support configuration management are available ranging from stand-alone tools to integrated CM workbenches. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 43
  • 44. CM workbenches Open workbenches • Tools for each stage in the CM process are integrated through organisational procedures and scripts. Gives flexibility in tool selection. Integrated workbenches • Provide whole-process, integrated support for configuration management. More tightly integrated tools so easier to use. However, the cost is less flexibility in the tools used. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 44
  • 45. Change management tools Change management is a procedural process so it can be modelled and integrated with a version management system. Change management tools • Form editor to support processing the change request forms; • Workflow system to define who does what and to automate information transfer; • Change database that manages change proposals and is linked to a VM system; • Change reporting system that generates management reports on the status of change requests. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 45
  • 46. Version management tools Version and release identification • Systems assign identifiers automatically when a new version is submitted to the system. Storage management. • System stores the differences between versions rather than all the version code. Change history recording • Record reasons for version creation. Independent development • Only one version at a time may be checked out for change. Parallel working on different versions. Project support • Can manage groups of files associated with a project rather than just single files. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 46
  • 47. VVVV eD1D3 rsionr eD2 rsio ers 1.01.2 1.11e Delta-based versioning Ca ete ti ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 47
  • 48. System building Building a large system is computationally expensive and may take several hours. Hundreds of files may be involved. System building tools may provide • A dependency specification language and interpreter; • Tool selection and instantiation support; • Distributed compilation; • Derived object management. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 48
  • 49. comp Component dependencies scan.o syn.o sem cge scan.o syn.o sem cge defs.h ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 49
  • 50. Key points Configuration management is the management of system change to software products. A formal document naming scheme should be established and documents should be managed in a database. The configuration data base should record information about changes and change requests. A consistent scheme of version identification should be established using version numbers, attributes or change sets. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 50
  • 51. Key points System releases include executable code, data, configuration files and documentation. System building involves assembling components into a system.. CASE tools are available to support all CM activities CASE tools may be stand-alone tools or may be integrated systems which integrate support for version management, system building and change management. ©Ian Sommerville 2004 Software Engineering, 7th edition. Chapter 29 Slide 51