1.9軟件配置管理
軟件配置管理(SCM——Software Configuration Management)是ISO9001和CMM Level2中的重要組成元素,它在軟件產(chǎn)品開發(fā)的生命周期中,提供了結(jié)構(gòu)化的、有序化的、產(chǎn)品化的管理軟件工程的方法,是軟件開發(fā)和維護(hù)的基礎(chǔ)。
SCM是指通過技術(shù)及行政手段對軟件產(chǎn)品及其開發(fā)過程和生命周期進(jìn)行控制、規(guī)范的一系列措施和過程,它通過控制、記錄、追蹤對軟件的修改和每個(gè)修改生成的軟件組成部件來實(shí)現(xiàn)對軟件產(chǎn)品的管理。SCM可以協(xié)調(diào)軟件開發(fā)使得混亂減到最小,是一種標(biāo)識、組織和控制修改的技術(shù),目的是使錯(cuò)誤達(dá)到最小并最有效地提高生產(chǎn)效率。
SCM使軟件產(chǎn)品變?yōu)槭芸氐暮涂深A(yù)見的,它控制這樣幾個(gè)問題:
1. 誰做的變更?
2. 軟件有什么變更?
3. 什么時(shí)間做的變更?
4. 為何要變更?
通過實(shí)施SCM,可以達(dá)到可重用過程制度化,包括:滿足組織的政策方針、計(jì)劃和過程描述文檔化、分配適當(dāng)資源(包括資金,人員和工具)、確定責(zé)任和權(quán)限、培訓(xùn)相關(guān)人員、通過不同級別的管理方法和糾正活動(dòng)檢測狀態(tài)。
置于SCM之下的工作產(chǎn)品包括發(fā)送給用戶的軟件產(chǎn)品(如軟件需求文檔,軟件代碼),用于內(nèi)部使用的軟件工作產(chǎn)品(如過程描述),和用于創(chuàng)建工作產(chǎn)品的工具等(如操作系統(tǒng)、數(shù)據(jù)庫、開發(fā)工具)。
SCM還用于建立和維護(hù)軟件工作產(chǎn)品基線;是由配置項(xiàng)及相關(guān)實(shí)體組成的,包括組成軟件產(chǎn)品的相關(guān)版本、設(shè)計(jì)、代碼、用戶文檔等。它是軟件生命周期中各開發(fā)階段末尾的特定點(diǎn),即里程碑。通過正式的技術(shù)評審而得到的軟件配置的正式文本才能成為基線,它的作用是使各個(gè)階段工作的劃分更加明確化,使本來連續(xù)的工作在這些點(diǎn)上斷開,以便于檢驗(yàn)和肯定階段成果;是配置項(xiàng)繼續(xù)發(fā)展的一個(gè)固定基礎(chǔ)。
實(shí)施SCM不論是對軟件開發(fā)者、測試者、項(xiàng)目經(jīng)理、QA人員,還是客戶都將會(huì)獲得很多好處:有助于規(guī)范團(tuán)隊(duì)各個(gè)角色的行為,同時(shí)又為各個(gè)角色之間的任務(wù)傳遞和交流提供無縫的接合;能幫助項(xiàng)目經(jīng)理更好地了解項(xiàng)目的進(jìn)度、開發(fā)人員的負(fù)荷、工作效率和產(chǎn)品質(zhì)量狀況、交付日期等信息。
SCM分為四大功能領(lǐng)域:配置標(biāo)識、變更控制、配置狀態(tài)統(tǒng)計(jì)、配置審核。
配置標(biāo)識:包括標(biāo)識軟件系統(tǒng)的結(jié)構(gòu),標(biāo)識獨(dú)立部件,并使它們是可訪問的。配置標(biāo)識的目的,是在整個(gè)生命周期中標(biāo)識系統(tǒng)各部件并提供對軟件及其軟件產(chǎn)品的跟蹤能力。
配置變更控制:包括在軟件生命周期中控制軟件產(chǎn)品的發(fā)布和變更,目的是建立確保軟件產(chǎn)品質(zhì)量的機(jī)制。它回答:什么是受控的?受控產(chǎn)品怎樣變更?誰控制變更?何時(shí)接受,恢復(fù),驗(yàn)證變更?
配置狀態(tài)統(tǒng)計(jì):包括記錄和報(bào)告變更過程,目標(biāo)是不間斷記錄所有基線項(xiàng)的狀態(tài)和歷史,并進(jìn)行維護(hù),它解決以下問題:系統(tǒng)已經(jīng)做了什么變更?此問題將會(huì)對多少個(gè)文件產(chǎn)生影響?
配置審核:將驗(yàn)證軟件產(chǎn)品的構(gòu)造是否符合需求、標(biāo)準(zhǔn)、或合同的要求,目的是根據(jù)SCM的過程和程序,驗(yàn)證所有的軟件產(chǎn)品已經(jīng)產(chǎn)生并有正確標(biāo)識和描述,所有的變更需求都已解決。
SCM從應(yīng)用層次上可以從低到高分為三級:版本控制、以開發(fā)者為中心、過程驅(qū)動(dòng)。
版本控制:主要應(yīng)用于個(gè)人獨(dú)立開發(fā)或小組開發(fā),它可以控制任何文件的版本、實(shí)現(xiàn)分支和歸并功能、進(jìn)行文本比較、標(biāo)記注釋和版本報(bào)告信息,主要工具有我們目前用到的Visual SourceSafe及Intersolv PVCS。
以開發(fā)者為中心:主要應(yīng)用于部門級開發(fā),它可用于軟件維護(hù)、不斷增加的開發(fā)任務(wù)、并行開發(fā)、QA及測試,它面向大型團(tuán)隊(duì)、利于交流、能最大限度地利用人力資源,主要工具為Rational ClearCase及MKS Source Integrity。
過程驅(qū)動(dòng):主要使用于企業(yè)級開發(fā),著重解決新的工具引入、IT審核、管理報(bào)告、復(fù)雜的生命周期、應(yīng)用工具包、集成解決方案、資料庫等問題,實(shí)現(xiàn)真正規(guī)范的團(tuán)隊(duì)開發(fā)。
相關(guān)推薦:推薦:2010年計(jì)算機(jī)軟件水平考試必備完美攻略北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |