為什么要將程序部署到云服務(wù)器上?華為云618營銷季W(wǎng)eb及移動App上云體驗(yàn)
Web及移動App上云是指將Web應(yīng)用程序或移動應(yīng)用程序部署到云計算平臺上,以便用戶可以通過互聯(lián)網(wǎng)訪問這些應(yīng)用程序。這種部署方式可以提高應(yīng)用程序的可靠性、可擴(kuò)展性和安全性,同時也可以降低應(yīng)用程序的運(yùn)營成本。
三大特性決定系統(tǒng)的穩(wěn)定能力
部署應(yīng)用服務(wù)本身是一個比較簡單的事情,只要我們把開發(fā)好的代碼和依賴環(huán)境在服務(wù)器上安裝即可。真正給我們帶來困擾的是如何保障所部署的服務(wù)可以安全穩(wěn)定的在我們的服務(wù)器上運(yùn)行,確保我們的業(yè)務(wù)可以長期持續(xù)的給用戶提供服務(wù)。因此我們首先要對系統(tǒng)的穩(wěn)定性有一個概念,通常來說一個系統(tǒng)的穩(wěn)定性有三個比較重要的維度。
上面這張圖就是一個比較基礎(chǔ)的系統(tǒng)部署需要用到的相關(guān)服務(wù)。任何服務(wù)的本質(zhì)基本上也就是上面這一些服務(wù)所組成的,前端的應(yīng)用對后端應(yīng)用發(fā)起請求,后端服務(wù)處理請求后要么訪問數(shù)據(jù)庫的文件,要么訪問文件系統(tǒng)中的文件。因此這個系統(tǒng)的穩(wěn)定性也就聚焦在了服務(wù)的穩(wěn)定、文件系統(tǒng)的穩(wěn)定以及數(shù)據(jù)庫的穩(wěn)定。那對于服務(wù)器的穩(wěn)定性,我們更多考慮的是通過負(fù)載均衡的方式,讓多臺服務(wù)器共同處理前端的請求;對于文件系統(tǒng)的穩(wěn)定,則更多的是要考慮存儲硬件故障導(dǎo)致的文件丟失,以及服務(wù)端文件系統(tǒng)讀寫文件時消耗的貸款和IO資源。那對于數(shù)據(jù)庫來說,我們則要考慮數(shù)據(jù)庫的服務(wù)可靠性、容災(zāi)能力以及數(shù)據(jù)備份和恢復(fù)的能力。 以上就是一個穩(wěn)定性較高的業(yè)務(wù)系統(tǒng)在云上部署的形態(tài),可以看到首先在服務(wù)器的前端增加了負(fù)載均衡服務(wù),實(shí)現(xiàn)了多臺服務(wù)器共同處理業(yè)務(wù)請求,這樣的好處有兩個。 1. 負(fù)載均衡后掛載的任何一臺服務(wù)器故障,服務(wù)器本身并不會宕機(jī),因?yàn)檫有其他的服務(wù)器可以提供服務(wù)。 2. 服務(wù)過高時,我們可以通過簡單的增加負(fù)載均衡掛載的服務(wù)器數(shù)量,來增大我們服務(wù)器的基礎(chǔ)資源。 從這一點(diǎn)上實(shí)現(xiàn)了前端服務(wù)的線性擴(kuò)容,其次我們也可以注意到存儲系統(tǒng)在這里選擇了兩種類型。 1. 第一種是OBS存儲,OBS存儲是一種性價比較高的存儲服務(wù),它并不支持傳統(tǒng)的文件系統(tǒng),無法直接掛載在服務(wù)器上,當(dāng)然也不支持改寫的操作,但是訪問速度很快,可以直接對互聯(lián)網(wǎng)暴露服務(wù),非常適合存儲一些靜態(tài)的文件。比如圖片,音視頻或者是APP的安裝包,那么通過OBS來存儲靜態(tài)的大文件,可以有效的降低文件讀取時對本地存儲io性能消耗。 2. 第二種是SFS存儲,SFS存儲是一種支持在服務(wù)器上掛載的共享文件存儲服務(wù),通過NEX服務(wù),我們可以將多臺server需要存儲的數(shù)據(jù)存儲到這個共享存儲中,一來可以提供更高可靠性的數(shù)據(jù)安全能力。二來可以解決多臺server中存儲數(shù)據(jù)如何同步的問題。 最后是數(shù)據(jù)庫服務(wù),數(shù)據(jù)庫的可靠性和橫向擴(kuò)容相對復(fù)雜,實(shí)現(xiàn)數(shù)據(jù)庫的可靠性不可避免的要去實(shí)現(xiàn)一主一從或者一主多從的數(shù)據(jù)庫架構(gòu),同時需要增加儲備能力的反向代理。因此我們?nèi)?gòu)建可依靠的數(shù)據(jù)庫對于數(shù)據(jù)庫本身的技術(shù)要求和運(yùn)維要求就變得非常高,云服務(wù)提供的云數(shù)據(jù)庫本身就集成了這些能力,首先可以提供主從架構(gòu)的數(shù)據(jù)庫的服務(wù),同時可以提供可橫向擴(kuò)容的只讀節(jié)點(diǎn),另外支持實(shí)時備份和恢復(fù)能力,從而保證了數(shù)據(jù)庫服務(wù)的穩(wěn)定性。 可能會用到的華為云服務(wù) 華為云提供上面多個服務(wù),可以讓用戶輕松快捷的實(shí)現(xiàn)我們上面說的這個架構(gòu),幫助大家快速的在云上構(gòu)建一個穩(wěn)定性較強(qiáng)的業(yè)務(wù)環(huán)境。 首先是OBS對象服務(wù),OBS對象服務(wù)可以支持加密、防盜鏈、細(xì)粒度權(quán)限控制等多種數(shù)據(jù)安全功能,保障數(shù)據(jù)安全可信。同時又提供了非常大的出入口帶寬,來保障多個用戶在使用OBS的時候依然能夠獲得一個非常良好的體驗(yàn)。 第二個是SFS文件存儲,SFS文件存儲可以支持掛載到線上或者線下的服務(wù)器中,同樣也提供了非常強(qiáng)勁的io能力,在不同的業(yè)務(wù)層提供不同的吞吐量級別來保障滿足大家的用戶需求。 第三個是負(fù)載均衡服務(wù),ELB負(fù)載均衡服務(wù)單實(shí)例支持千萬級并發(fā),滿足用戶的海量業(yè)務(wù)訪問需求。具備多可用區(qū)多活能力,容災(zāi)場景業(yè)務(wù)無縫實(shí)時切換。靈活擴(kuò)展用戶應(yīng)用的對外服務(wù)能力。 最后是云數(shù)據(jù)庫,華為自主創(chuàng)新研發(fā)的分布式關(guān)系型數(shù)據(jù)庫。該產(chǎn)品具備企業(yè)級復(fù)雜事務(wù)混合負(fù)載能力,同時支持分布式事務(wù),同城跨AZ部署,數(shù)據(jù)0丟失,支持1000+節(jié)點(diǎn)的擴(kuò)展能力,PB級海量存儲。同時擁有云上高可用、高可靠、高安全、彈性伸縮、一鍵部署、快速備份恢復(fù)、監(jiān)控告警等關(guān)鍵能力,能為企業(yè)提供功能全面、穩(wěn)定可靠、擴(kuò)展性強(qiáng)、性能優(yōu)越的企業(yè)級數(shù)據(jù)庫服務(wù)。 高并發(fā)環(huán)境穩(wěn)定性建設(shè) 當(dāng)我們擁有了一個相對穩(wěn)定的業(yè)務(wù)系統(tǒng)時,我們往往會面臨一些其他的特殊場景,比如在我們短時出現(xiàn)大量用戶集體訪問的這種狀況,也就是我們所謂的高負(fù)載的系統(tǒng)如何去構(gòu)建它的穩(wěn)定性,當(dāng)我們業(yè)務(wù)發(fā)展到一定階段的時候,就會碰到這種高并發(fā)的場景。并發(fā)量過高會快速消耗我們的系統(tǒng)資源,導(dǎo)致系統(tǒng)崩潰、宕機(jī)、業(yè)務(wù)下線,那么除了橫向擴(kuò)容之外,面對高并發(fā)的業(yè)務(wù),我們還有哪些解決問題的思路呢?這里給大家總結(jié)三點(diǎn)。 1. 數(shù)據(jù)緩存:數(shù)據(jù)庫在高并發(fā)場景中往往是最脆弱的一個服務(wù),大量的查詢請求會快速的讓數(shù)據(jù)庫進(jìn)入到排隊執(zhí)行任務(wù)的狀態(tài),如果數(shù)據(jù)庫緩存優(yōu)化做的不好,那么最終的結(jié)果就是數(shù)據(jù)庫服務(wù)是系統(tǒng)承載能力的第一個瓶頸,因此如何做數(shù)據(jù)緩存為數(shù)據(jù)庫降壓就顯得尤為重要。 2. 應(yīng)用解耦:單體應(yīng)用在面對海量并發(fā)的時候往往力不從心,原因也很簡單。應(yīng)用之間沒有做解耦,導(dǎo)致任何一個模塊的崩潰,都會帶來整個系統(tǒng)的崩潰,那么如何將應(yīng)用拆分解耦以降低部分業(yè)務(wù)過高導(dǎo)致的系統(tǒng)崩潰,也是處理高并發(fā)問題的一種思路。 3. 應(yīng)用監(jiān)控:多個應(yīng)用之間相互調(diào)用會帶來一個弊病,就是一旦某一個單一的應(yīng)用發(fā)生故障,如何快速定位到這個故障應(yīng)用就變得相對復(fù)雜,當(dāng)然這也就延長了故障處理的時間。因此針對應(yīng)用的監(jiān)控、繪制應(yīng)用之間的依賴關(guān)系,以及應(yīng)用層級的報警就變得尤為重要。 上面是一個典型的微服務(wù)框架下的高并發(fā)系統(tǒng),這里面我們可以看到為了應(yīng)對高并發(fā)對系統(tǒng)帶來的沖擊,重點(diǎn)對如下的幾個方面做了加強(qiáng)。 1. 首先是CDN高并發(fā)帶來的第一個沖擊就是網(wǎng)絡(luò)資源的大量消耗,這里通過CDN服務(wù),我們把大量的靜態(tài)文件和大文件緩存到CDN節(jié)點(diǎn),這樣可以有效的降低系統(tǒng)入口帶來的壓力。 2. 第二就是我們?nèi)プ龆嗉壍木彺,通過Redis和消息隊列,我們實(shí)現(xiàn)數(shù)據(jù)庫與服務(wù)之間,應(yīng)用與應(yīng)用之間的數(shù)據(jù)緩存。同時消息隊列也可以有效的實(shí)現(xiàn)應(yīng)用之間的解耦,單個應(yīng)用的故障弱化,避免拉垮整個業(yè)務(wù)環(huán)境。 3. 第三就是應(yīng)用監(jiān)控與壓力的測試,通過成熟的應(yīng)用監(jiān)控和壓測服務(wù),實(shí)時的掌握應(yīng)用的健康狀態(tài),快速定位這個故障應(yīng)用通過應(yīng)用的降級,限流等措施來避免系統(tǒng)在高并發(fā)的業(yè)務(wù)狀態(tài)下被集體系統(tǒng)性的拖垮。 4. 第四就是我們的容器集群,通過強(qiáng)大的容器及群眾管理和編排能力,我們可以快速的臨時的創(chuàng)建我們的彈性容器,讓我們的系統(tǒng)能夠?qū)崿F(xiàn)秒級擴(kuò)容的這種擴(kuò)容能力。 可能會用到的華為云服務(wù) 通過上面幾種方式我們可以來應(yīng)對高并發(fā)對系統(tǒng)帶來的沖擊。以上是華為云相關(guān)的一些產(chǎn)品與服務(wù),這些服務(wù)可以幫助我們快速的構(gòu)建一個能夠應(yīng)對相對較高并發(fā)的業(yè)務(wù)系統(tǒng)。 首先是華為云的CDN,目前已經(jīng)在全球部署了超過2800個CDN節(jié)點(diǎn),同時也支持多種不同類型的協(xié)議接入,無論誰定協(xié)議都可以快速的進(jìn)入到我們的CDN服務(wù)中去。CDN通過將源站內(nèi)容分發(fā)至靠近用戶的加速節(jié)點(diǎn),使用戶可以就近獲得所需的內(nèi)容,解決Internet網(wǎng)絡(luò)擁擠的狀況,提高用戶訪問的響應(yīng)速度和成功率,從而提升業(yè)務(wù)的使用體驗(yàn)。 第二個云Redis服務(wù)大家可能也比較熟悉,是一個非常方便做數(shù)據(jù)緩存的應(yīng)用。但是商業(yè)化的華為云可以幫你提供更強(qiáng)的可靠性服務(wù),華為云可以真正做到持久化的數(shù)據(jù)存儲來幫助用戶去解決當(dāng)系統(tǒng)重啟,或者是一些環(huán)境變更帶來的數(shù)據(jù)丟失的問題。 第三個是云數(shù)據(jù)庫,華為自主創(chuàng)新研發(fā)的分布式關(guān)系型數(shù)據(jù)庫。該產(chǎn)品具備企業(yè)級復(fù)雜事務(wù)混合負(fù)載能力,同時支持分布式事務(wù),同城跨AZ部署,數(shù)據(jù)0丟失,支持1000+節(jié)點(diǎn)的擴(kuò)展能力,PB級海量存儲。同時擁有云上高可用、高可靠、高安全、彈性伸縮、一鍵部署、快速備份恢復(fù)、監(jiān)控告警等關(guān)鍵能力,能為企業(yè)提供功能全面、穩(wěn)定可靠、擴(kuò)展性強(qiáng)、性能優(yōu)越的企業(yè)級數(shù)據(jù)庫服務(wù)。 最后就是云容器引擎(Cloud Container Engine)提供高可靠高性能的企業(yè)級容器應(yīng)用管理服務(wù),支持Kubernetes社區(qū)原生應(yīng)用和工具,簡化云上自動化容器運(yùn)行環(huán)境搭建,面向云原生2.0打造CCE Turbo容器集群,計算、網(wǎng)絡(luò)、調(diào)度全面加速,全面加速企業(yè)應(yīng)用創(chuàng)新。據(jù)IDC報告顯示,華為云容器軟件中國市場份額排名第一。 總結(jié) 以上是這次Web及移動App上云實(shí)際測試中我選用的產(chǎn)品,這次用到了ECS服務(wù)器、云數(shù)據(jù)庫、Redis分布式緩存等多個產(chǎn)品。簡單搭建了一個高并發(fā)環(huán)境體驗(yàn)了一下,總結(jié)一下使用體驗(yàn)以及產(chǎn)品優(yōu)勢。 使用體驗(yàn) 在實(shí)際使用中我覺得大部分項(xiàng)目都適合部署上云,比如網(wǎng)站、應(yīng)用程序、數(shù)據(jù)庫、存儲、備份和恢復(fù)等。云服務(wù)器可以根據(jù)需要進(jìn)行擴(kuò)展和縮小,可以提高可用性和靈活性,同時可以降低成本和管理負(fù)擔(dān)。對于一些需要高性能計算、需要大量存儲空間、需要低延遲的應(yīng)用程序,華為云也有對應(yīng)的產(chǎn)品可以支持,比如云上HPC、熱存儲、冷存儲、IES小站等。 產(chǎn)品優(yōu)勢 一站上云更敏捷 •豐富云服務(wù) 包括計算、網(wǎng)絡(luò)、存儲、安全、域名等多類云服務(wù),助力企業(yè)一站式高效上云,計算底層資源使用華為云IaaS服務(wù),安全可靠高性能,滿足Web及移動App應(yīng)用全棧部署需求 •多鏈路 多線接入BGP,自動感知接入線路網(wǎng)絡(luò)狀況,運(yùn)營商內(nèi)部故障時,能夠快速切換到其他運(yùn)營商接入鏈路,確保訪問質(zhì)量 •高可用 輕松應(yīng)對高并發(fā)、流量峰值場景,為用戶提供極致的站點(diǎn)訪問體驗(yàn) 安全可靠服務(wù)好 •數(shù)據(jù)安全很放心 1、不用技術(shù)手段非法獲取客戶數(shù)據(jù) 2、不強(qiáng)迫客戶交換數(shù)據(jù) 3、不對客戶數(shù)據(jù)進(jìn)行商業(yè)變現(xiàn),機(jī)房安全等級(Tier4)全國最高,安全設(shè)備投入數(shù)十億,40多種安全服務(wù)可供使用 4、安全上的專項(xiàng)研發(fā)占總體研發(fā)投入5% •業(yè)務(wù)安全不焦慮 恪守業(yè)務(wù)邊界,不與客戶/伙伴搶業(yè)務(wù) •合規(guī)可信通全球 1、全球120+合規(guī)認(rèn)證,服務(wù)全球客戶 2、研發(fā)全流程安全可信,歷經(jīng)嚴(yán)苛考驗(yàn) •華為品質(zhì)服務(wù) 1、300+城市本地團(tuán)隊 2、7x24咨詢,深度定制解決方案 3、VIP客戶專人服務(wù) 省錢省心創(chuàng)新快 •企業(yè)級應(yīng)用特性全面 業(yè)務(wù)高可用(ECS集群高可用,數(shù)據(jù)庫高可用),數(shù)據(jù)高可靠(數(shù)據(jù)多備份),服務(wù)高安全(業(yè)務(wù)安全、數(shù)據(jù)安全、系統(tǒng)安全) •靈活按需投資少 1、按需付費(fèi),無需固定資產(chǎn)投資 2、超強(qiáng)靈活彈性,隨業(yè)務(wù)發(fā)展自動快速按需擴(kuò)縮容,既能輕松應(yīng)對超大業(yè)務(wù)流量峰值,也能在業(yè)務(wù)閑時節(jié)省業(yè)務(wù)開支 •加速創(chuàng)新成本低 1、降低試錯成本,創(chuàng)新風(fēng)險更低、速度更快 2、云上隨時使用最新的技術(shù):大數(shù)據(jù),人工智能,物聯(lián)網(wǎng),無需重新采購軟件,按需使用,實(shí)施周期大大縮短 技術(shù)很強(qiáng)資源多 •領(lǐng)先技術(shù)實(shí)力,更懂企業(yè)客戶 1、研發(fā)持續(xù)高投入,掌握云計算根技術(shù),輕松應(yīng)對企業(yè)業(yè)務(wù)安全、高并發(fā)、快速創(chuàng)新等業(yè)務(wù)挑戰(zhàn) 2、承襲華為30+年企業(yè)服務(wù)經(jīng)驗(yàn)積淀,更懂企業(yè)需求,全面覆蓋企業(yè)業(yè)務(wù)場景,并提供對應(yīng)解決方案與最佳實(shí)踐 •資源覆蓋全球,全球一張網(wǎng) 1、華為云在全球20多個地理區(qū)域運(yùn)營數(shù)十個可用區(qū),覆蓋100多個國家和地區(qū) 2、提供安全、穩(wěn)定、低時延的高質(zhì)量網(wǎng)絡(luò)選擇,打造50ms用戶優(yōu)質(zhì)體驗(yàn)服務(wù)圈 •專屬資源滿足特定行業(yè) 提供專屬資源,滿足特定行業(yè)數(shù)據(jù)物理隔離需求,資源獨(dú)享,無需擔(dān)心資源搶占,最低0.5ms穩(wěn)定低時延,99.9999%業(yè)務(wù)高可用 剛好華為云618營銷季活動還在繼續(xù),截止到6月31日,訪問華為云官網(wǎng)活動頁就可領(lǐng)取超多福利,有需要的小伙伴不妨上華為云官網(wǎng)看看吧。
● 系統(tǒng)的可靠性:系統(tǒng)的可靠性是指系統(tǒng)環(huán)境在一定程度下發(fā)生故障,比如硬件故障、軟件故障、甚至一些人為操作帶來的故障下是否依然能夠正常工作。當(dāng)然這種故障一定是局部故障,一套相對完整的系統(tǒng)中,往往由多個小系統(tǒng)組成,任何一個小系統(tǒng)的故障是否會影響導(dǎo)致整體業(yè)務(wù)系統(tǒng)的崩潰,則是用來衡量系統(tǒng)可靠性的重要因素。 ● 系統(tǒng)的可擴(kuò)展性:這種可擴(kuò)展性包括了橫向的負(fù)載能力,以及業(yè)務(wù)模塊的擴(kuò)展。在這里我們重點(diǎn)關(guān)注的是系統(tǒng)負(fù)載能力的擴(kuò)展,業(yè)務(wù)負(fù)載過大的業(yè)務(wù),在業(yè)務(wù)負(fù)載增大的過程中,往往會帶來CPU內(nèi)存硬盤網(wǎng)絡(luò)資源的大量消耗。那過去我們常用的手段就是升級服務(wù)器的配置。這種方法一來會導(dǎo)致業(yè)務(wù)短時間的下線、二來也是有上限的。那么如何保證系統(tǒng)可以線性、持續(xù)的擴(kuò)容下去、則是我們要思考的問題。 ● 系統(tǒng)的可維護(hù)性:隨著我們業(yè)務(wù)功能的增加,當(dāng)一個相對復(fù)雜的系統(tǒng)部署后,是否能夠方便的監(jiān)控、快速的定位問題、則是保障系統(tǒng)本身穩(wěn)定性的又一個重要的因素。
大家都在看

重磅推薦
英特爾 i9-13900K / KS 處理器將采用更精簡包裝,減少運(yùn)輸成本
華碩 5 月營收 363.16 億元新臺幣,環(huán)比增長 16.1%
華碩發(fā)布 RISC-V 架構(gòu)單板計算機(jī) Tinker V:配備 1.0 Ghz 單核芯片,保修 5 年
Intel Mac 退出蘋果舞臺,消息稱明年將啟動“macOS 退休”計劃
奔馳擊敗特斯拉,拿下美國加州首張自動駕駛汽車許可證
比亞迪 F 品牌官宣定名“方程豹”:年內(nèi)發(fā)布首款車型,定位新能源硬派 SUV
全球最大安全氣囊制造商奧托立夫開啟 8000 人大裁員,以精簡業(yè)務(wù)和控制成本
2023Q1 出貨量增長 400%,榮耀品牌在海外逆勢快速擴(kuò)張