云時代架構讀后感4--IT架構的本質

IT架構的本質 原文地址:http://mp.weixin.qq.com/s?__biz=MzAwNTQ4MTQ4NQ==&mid=2453562304&idx=1&sn=be86a7bc682c4e76e06b87a10ad45188&chksm=8cd136a2bba6bfb430103e50f94b670e799412d0a1cae4eded0eb901847b6d462359ae317635&mpshare=1&scene=23&srcid=#rd

這篇文章是由一位具有十二年工作經驗的架構師總結而成,他從自己的工作經驗中總結出五條道理:

1.需求優化最重要:少查少寫少依賴,Less is more

2.群集設計通用規則:前端復制后端拆,實時改異步,三組件互換

3.理解硬件天性:角色選型時要看硬件的天然特性

4.數據的產生和消失:數據不會憑空產生,但會憑空消失

5.各環節都不可盲信:容災設計中都盡人事和聽天命

通過閱讀他總結出的五條經驗,應該會對我們以后的工作有所幫助。

在第一點中提到,一個IT系統是多角色多模塊分層分級的,像OSI模型上層應用簡單依賴下層支撐,SOA設計中同級角色也只看對方的接口。

各角色分工明確方便快速實現業務,但是給架構優化也埋下大坑,底層的盲目支撐是巨大資源浪費,平級調度協作也沒任何彈性。

而做架構設計最重要的就是砍需求,將上層應用的需求優化刪減,讓同級的業務能容錯。

前端對后端少輸入少查詢多容錯,應該抓住核心訴求,不該要的東西都不要。

第二點指出,架構常見技巧就像空中華爾茲一樣自然優雅。要做架構就要上群集,而群集設計調優翻來覆去就是這三板斧:前端復制后端拆,實時改異步,IO-算力-空間可互換。

前端是管道是邏輯,而后端是狀態是數據,所以前端復制后端拆。

絕大部分“實時操作”都不是業務需求,而是某應用無法看到后端和Peer狀態,默認就要實時處理結果了。

在群集性能規劃中,網絡和硬盤IO+CPU算力+磁盤和內存空間是可以互換的,架構師要完成補不足而損有余的選型。

第三點說道:別讓硬盤扛性能,別讓內存保持久,別讓網線扛穩定。

架構層軟件技術已經足夠成熟,所謂技術選型不如說是適應場景;在做具體角色選型時,最深度也最易忽視的原則是順應硬件天性。

如果一個服務依賴硬盤,那這個服務就不適合扛性能壓力。

第四點告訴我們:數據不會憑空產生,我們要便捷輕巧安全可靠的獲取數據,就要選好數據源,保障好傳輸路徑,定義好數據變換規則。

但是會憑空消失,在一個數據生命周期內,為了防止數據全部或部分憑空消失,數據的容錯校驗、關聯復原、冷熱備份和安全刪除都要考慮到位。

最后一點談到,整個IT系統中就沒有可靠的組件,架構師既不能盲目信任撞大運,又不能無限冗余嚇唬自己,而是在盡人事和聽天命之間做好權衡。

?

這篇文章主要講的是架構工作的“道”,對與架構之“術”并不提及。不同的業務系統的架構之術完全不同,能拿來匯總借鑒的只有這幾條簡單的道理。

如果我們有架構之道做思想支撐,即使接手全新業務類型,庖丁可以解牛也可以殺豬,我們一樣能游刃有余心里不慌。

?

轉載于:https://www.cnblogs.com/sakura--/p/11050369.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/275467.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/275467.shtml
英文地址,請注明出處:http://en.pswp.cn/news/275467.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

蘋果風格ui_蘋果如何使Soft-UI成為未來

蘋果風格ui重點 (Top highlight)Apple announced some pretty wild updates at WWDC 2020 today.蘋果今天在WWDC 2020上宣布了一些相當瘋狂的更新。 But technology aside, let’s focus on how their UI has changed. It went through the first bitmap representations, thr…

【數據結構】量子危機

問題 宇宙時間公元 5.55 億年,由于某種原因兩大聯盟展開了激戰(maxingc 聯盟采用了微子技術): 邪惡的 maxingc 聯盟采集好了微子能,就要運輸。Maxingc 聯盟的領袖 xc 此時才發現,自己的軍事基地中由微子發射…

android 自定義menu背景,Android編程實現自定義系統菜單背景的方法

本文實例講述了Android編程實現自定義系統菜單背景的方法。分享給大家供大家參考,具體如下:不多說,上圖,見代碼。package lab.sodino.menutest;import android.content.Context;import android.app.Activity;import android.os.Bu…

面試官問 async、await 函數原理是在問什么?

大家好,我是若川。這是 源碼共讀活動《1個月,200人,一起讀了4周源碼》 第四期,紀年小姐姐的第四次投稿。紀年小姐姐通過本次學習提早接觸到generator,協程概念,了解了async/await函數的原理等。第四期是 學…

一步步優化JVM六:優化吞吐量[轉]

2019獨角獸企業重金招聘Python工程師標準>>> 原文:http://ganlv.iteye.com/blog/1571315 參考:http://www.myexception.cn/software-architecture-design/1455594.html 現代JVM是一個具有靈活適應各種應用能力的軟件,盡管很多應用…

element-ui 網格_UI備忘單:列表與網格

element-ui 網格重點 (Top highlight)Grids or lists? That is the question we will look at in this cheat sheet. While they can be used anywhere in your site, we are going to look primarily at search results, catalogs and newsfeeds. Making this choice will de…

asp.net mvc使用TagBuilder的應用程序集

在asp.net mvc編寫擴展方法中需要使用到TagBuilder類,根據msdn的說法應該應用System.Web.Mvc.dll 程序集。 TagBuilder 構造函數 .NET Framework 4 初始化 TagBuilder 類的新實例。命名空間: System.Web.Mvc程序集: System.Web.Mvc&#xf…

50行 koa-compose,面試常考的中間件原理原來這么簡單?

大家好,我是若川。源碼共讀《1個月,200人,一起讀了4周源碼》 活動第五期是學習 koa 源碼的整體架構,淺析koa洋蔥模型原理和co原理中的koa-compose源碼原理,閱讀不到50行的koa-compose源碼。這篇是izjing小哥哥的投稿。…

sqlite3源碼編譯到Android,實現SQLite跨全平臺使用

文/何曉杰Dev(高級Android架構師)著作權歸作者所有,轉載請聯系作者獲得授權。初看這個標題你可能會不解,SQLite 本身就是一個跨平臺的數據庫,在這里再說跨平臺有什么意義呢?其實不然,目前我就遇到了一個項目…

在Red Hat 4 AS U7上安裝oracle10gR2

軟件:Red Hat 4 AS U7, Oracle 10g R2 for linux32, VMWare 7, Windows 7詳細步驟清單:在Red Hat 4 AS U7上安裝oracle10gR2 1. 硬件需求: =======&#xff1…

illustrator下載_平面設計:16個Illustrator快捷方式可加快工作流程

illustrator下載I know, I know — keyboard shortcuts sound so nerdy, and you’re a graphic designer, not an IT Director, why should you learn keyboard shortcuts?我知道,我知道—鍵盤快捷鍵聽起來很書呆,而且您是圖形設計師,而不是…

手把手教你五分鐘扒個源碼寫個無敵外掛

大家好,我是若川。源碼共讀《1個月,200人,一起讀了4周源碼》 活動進行到第五期了,歡迎點鏈接加我微信 ruochuan12 報名參加。前言前段時間群里分享了一個小游戲,多次懷疑自己的眼睛以后,嘗試去寫個外掛。中…

Kubernetes 1.14重磅來襲,多項關鍵特性生產可用

走過了突飛猛進的2018年,Kubernetes在2019年終于迎來了第一個大動作:Kubernetes 1.14版本的正式發布!Kubernetes 本次發布的 1.14 版本,包含了 31 項增強,其中 10 項為 GA,12 項進入 beta 試用階段&#xf…

中英文

http://it.freesion.com/3220/4888028/13606306/#轉載于:https://www.cnblogs.com/yqskj/articles/2082326.html

open ai gpt_讓我們來談談將GPT-3 AI推文震撼到核心的那條推文

open ai gpt重點 (Top highlight)“設計師”插件 (The ‘Designer’ plugin) A couple days ago, a tweet shared by Jordan Singer turned the heads of thousands of designers. With the capabilities of GPT-3 (from OpenAI), he shared a sample of what he was able to c…

我歷時3年才寫了10余篇源碼文章,但收獲了100w+閱讀

你好,我是若川。最近來了一些讀者朋友,在這里簡單介紹自己的經歷,也許對你有些啟發。之前發過這篇文章,現在修改下聲明原創,方便保護版權。最近組織了源碼共讀活動1個月,200人,一起讀了4周源碼&…

android onlescan 參數,Android BLE:從iOS外設廣告時,在onLeScan()回調中檢索服務UUID

我正在使用Nexus 4(4.4 kitkat)作為中央和iPad作為外設.外圍設備有廣告服務.廣告包有一些數據(22字節)的服務UUID.當我嘗試從Android掃描外圍設備時,iPad外圍設備被發現.但是當我嘗試從回調中的scanRecord參數獲取服務UUID時,我找不到它.我得到的是外設發送的20byte數據.當我嘗…

第 8 章 容器網絡 - 061 - flannel 的連通與隔離

flannel 的連通與隔離 測試 bbox1 和 bbxo2 的連通性: bbox1 能夠 ping 到位于不同 subnet 的 bbox2,通過 traceroute 分析一下 bbox1 到 bbox2 的路徑。 1) bbox1 與 bbox2 不是一個 subnet,數據包發送給默認網關 10.2.9.1&#…

Javascript 檢測 頁面是否在iframe中

//檢測是否在iframe中if(self.frameElement ! null && (self.frameElement.tagName "IFRAME" || self.frameElement.tagName "iframe")){parent.parent.location "login.jsp";}轉載于:https://www.cnblogs.com/kenkofox/archive/2011…

寫給前端的算法進階指南,我是如何兩個月零基礎刷200題 等推薦

大家好,我是若川。話不多說,這一次花了幾小時精心為大家挑選了20余篇好文,供大家閱讀學習。本文閱讀技巧,先粗看標題,感興趣可以都關注一波,一起共同進步。前端從進階到入院作者ssh就職于字節跳動基礎工程團…