許多科技公司明年都把移動(dòng)戰(zhàn)略放在第一位了。移動(dòng)設(shè)備,包括平板電腦,正在超越傳統(tǒng)PC,而成為更受歡迎的上網(wǎng)方式。
預(yù)計(jì)接下來(lái)的三年,移動(dòng)項(xiàng)目的增長(zhǎng)將以4:1的比例超越PC項(xiàng)目的增長(zhǎng)。在2016年,全球移動(dòng)設(shè)備數(shù)量有望超過人口數(shù)量。
對(duì)于開發(fā)團(tuán)隊(duì)的挑戰(zhàn)是:如何調(diào)整“移動(dòng)第一”或“移動(dòng)先行”的心態(tài)。這要求開發(fā)者將用戶體驗(yàn)放在第一位,并提供強(qiáng)大的內(nèi)容和個(gè)性化體驗(yàn)。這也意味著需要積累跨多個(gè)平臺(tái)和設(shè)備的經(jīng)驗(yàn),了解其復(fù)雜性,掌握?qǐng)?zhí)行移動(dòng)項(xiàng)目所需的特殊技能以及搭建強(qiáng)大后臺(tái)基礎(chǔ)的專業(yè)知識(shí)。
現(xiàn)在的應(yīng)用都需要將用戶多個(gè)平臺(tái)的信息融合起來(lái)。 你不可避免的將要面對(duì)多個(gè)客戶端操作系統(tǒng)平臺(tái)上的產(chǎn)品迭代更新,管理開發(fā)周期也越來(lái)越富有挑戰(zhàn)性。公司也會(huì)在移動(dòng)策略上給予技術(shù)領(lǐng)導(dǎo)人更大的壓力。在接下來(lái)的這一年,如何以移動(dòng)第一為口號(hào),讓開發(fā)團(tuán)隊(duì)和運(yùn)營(yíng)團(tuán)隊(duì)更好的團(tuán)結(jié)在一起,也變得比以往更加重要和具有挑戰(zhàn)性。
接下來(lái)是開發(fā)者在2013年需要考慮的,十分緊迫的4件事:
將“移動(dòng)第一”的觀念帶給你的核心開發(fā)團(tuán)隊(duì)
由于對(duì)跨平臺(tái)技術(shù)的需求越來(lái)越大,將移動(dòng)開發(fā)業(yè)務(wù)外包正成為一種趨勢(shì)。然而隨著開放的網(wǎng)絡(luò)標(biāo)準(zhǔn)(如JavaScript 以及HTML5)的日益流行,將促使內(nèi)部移動(dòng)開發(fā)變得更加容易。 這是非常幸運(yùn)的,因?yàn)槲磥?lái)移動(dòng)開發(fā)的周期將會(huì)越來(lái)越短,迭代更新越來(lái)越頻繁。如果沒有內(nèi)部移動(dòng)開發(fā)人員,將會(huì)讓開發(fā)過程變得非常麻煩,還要將外部資源做好協(xié)調(diào)并整合進(jìn)來(lái)。
你需要慎重考慮將移動(dòng)開發(fā)業(yè)務(wù)托付于誰(shuí),比如很多網(wǎng)頁(yè)設(shè)計(jì)師是從PC端轉(zhuǎn)型過來(lái),他們并沒有任何為移動(dòng)用戶設(shè)計(jì)產(chǎn)品的經(jīng)驗(yàn)。產(chǎn)品形態(tài)的變化、觸摸感以及內(nèi)容交互上的確需要不同的設(shè)計(jì)體驗(yàn)。
為移動(dòng)應(yīng)用或網(wǎng)絡(luò)調(diào)整服務(wù)器架構(gòu)
目前的復(fù)合應(yīng)用對(duì)后臺(tái)架構(gòu)的影響越來(lái)越大。大多數(shù)應(yīng)用都基于一系列API,能夠使應(yīng)用的用戶界面和后臺(tái)運(yùn)行進(jìn)行更好的交互,并實(shí)現(xiàn)跨平臺(tái)轉(zhuǎn)移。需要注意的是,這些后臺(tái)應(yīng)用(復(fù)合應(yīng)用)不只是用來(lái)表現(xiàn)原有后臺(tái)架構(gòu)的,他們需要支持更個(gè)性化、更具互動(dòng)性的移動(dòng)應(yīng)用功能。因此,原有的純粹傳遞技術(shù)之用,沒有經(jīng)過改造的架構(gòu)不足以稱為真正的“移動(dòng)先行”。
不過可喜的是現(xiàn)在越來(lái)越多的移動(dòng)公司采用了云架構(gòu)。
2013年選擇哪種后臺(tái)作為運(yùn)行架構(gòu)的確很重要。比如,你將如何應(yīng)對(duì)由需求增長(zhǎng)引起的海量移動(dòng)設(shè)備訪問你的應(yīng)用?這需要一個(gè)比以往更有彈性的后臺(tái)支撐系統(tǒng)。此外,你又將如何制定合理、靈敏的開發(fā)周期,以適應(yīng)客戶端和服務(wù)器端兩個(gè)層面的變化?你又將如何保證應(yīng)用后臺(tái)的容錯(cuò)性和冗余度?
關(guān)鍵是要保證你已經(jīng)選擇了一個(gè)彈性的、有足夠容錯(cuò)性的云架構(gòu)平臺(tái),以支撐你的移動(dòng)網(wǎng)絡(luò)應(yīng)用所產(chǎn)生的這一系列需求。
統(tǒng)一開發(fā)及運(yùn)營(yíng)
移動(dòng)先行戰(zhàn)略給開發(fā)和運(yùn)營(yíng)團(tuán)隊(duì)協(xié)作方面帶來(lái)了新的要求。
盡管“devops”(development+operation)這個(gè)詞在前幾年是作為一個(gè)熱點(diǎn)詞匯冒出來(lái)的,不過隨著關(guān)于“開發(fā)和運(yùn)營(yíng)團(tuán)隊(duì)完美協(xié)作”的理念的流行,它現(xiàn)在不再是一個(gè)可有可無(wú)的關(guān)注領(lǐng)域,而是需要開發(fā)團(tuán)隊(duì)給予足夠重視。
實(shí)際上,在移動(dòng)應(yīng)用失敗因素中,運(yùn)營(yíng)相關(guān)失誤是最重要的因素之一。來(lái)自Carnegie Mellon 大學(xué)的調(diào)研顯示,引起移動(dòng)應(yīng)用失敗的因素包括:軟件升級(jí)失敗、未能滿足潛在需求、資源匱乏、配置錯(cuò)誤等。這說(shuō)明在應(yīng)用程序發(fā)布之前運(yùn)維人員對(duì)應(yīng)用安全性、可靠性的部署與開發(fā)人員對(duì)核心代碼的調(diào)試是一樣重要的。
舉例來(lái)說(shuō),在應(yīng)用迭代開發(fā)環(huán)境中,需要對(duì)應(yīng)用的客戶端和服務(wù)器端頻繁更新,你如何確保在應(yīng)用的開發(fā)到發(fā)布過程中不出現(xiàn)配置錯(cuò)誤?一般的做法是開發(fā)人員在這個(gè)過程中寫出詳細(xì)的編碼細(xì)則,讓運(yùn)維人員在應(yīng)用發(fā)布過程中有所指導(dǎo),這些細(xì)則包括應(yīng)用版本、安裝準(zhǔn)則,以及具體執(zhí)行什么樣的命令。
在開發(fā)與運(yùn)維人員工作轉(zhuǎn)換時(shí)保證不出差錯(cuò)的關(guān)鍵是將其自動(dòng)化。開發(fā)人員需要把已經(jīng)測(cè)試過的可自動(dòng)執(zhí)行的文件包交給運(yùn)維人員。
當(dāng)軟件版本升級(jí)出現(xiàn)問題時(shí),由新版本給已經(jīng)發(fā)布的軟件帶來(lái)潛在可能性錯(cuò)誤時(shí),你將如何處理?這需要更好的實(shí)時(shí)故障診斷工具,避免開發(fā)人員重復(fù)錯(cuò)誤。另外,如果能讓軟件輕而易舉的回到初始版本,也是一個(gè)不錯(cuò)的主意。
所以,應(yīng)用程序的部署必須同時(shí)保障高效(支持頻繁迭代更新),以及高質(zhì)量產(chǎn)品。
讓“移動(dòng)第一”戰(zhàn)略具有可實(shí)施性
盡管實(shí)施“移動(dòng)第一”戰(zhàn)略聽起來(lái)很難,但如果你在重新思考應(yīng)用的開發(fā)、部署和管理方式過程中,同時(shí)把團(tuán)隊(duì)進(jìn)行合理整合,事情會(huì)變得更容易些。
應(yīng)用的開發(fā)和運(yùn)維所需的技能和工具是全然不同的:無(wú)論是在設(shè)計(jì)用戶界面,搭建API云架構(gòu),建立彈性后臺(tái)基礎(chǔ)設(shè)施,還是避免“devops”協(xié)作不善出現(xiàn)的應(yīng)用程序錯(cuò)誤時(shí)。事實(shí)上,解決問題的方法不止是改進(jìn)整個(gè)流程、提高自動(dòng)化程度,還包括一個(gè)良好的老式的團(tuán)隊(duì)協(xié)作。
(注:本文作者Andi Gutmans是Zend Technologies的聯(lián)合創(chuàng)始人兼CEO)
相關(guān)閱讀