0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

架構(gòu)師是干什么的

工程師人生 ? 來源:工程師吳畏 ? 2019-04-04 16:28 ? 次閱讀

一、先說下大家對架構(gòu)師認識的誤區(qū)

1、架構(gòu)師不是不食人間煙火,不是只在一個人的隔間里設(shè)計架構(gòu),而是需要和產(chǎn)品方,需求方,程序員等各路人馬打交道。

2、架構(gòu)師偏重于技術(shù),這個不假,但絕不能是技術(shù)完美主義者,因為任何產(chǎn)品或網(wǎng)站的架構(gòu)都充滿著妥協(xié)。

3、高級程序員和架構(gòu)師的界限并不明顯,不是哪天高級程序員學(xué)好了什么課程,掌握了一門技術(shù)就自動升級到架構(gòu)了,有些要求不高的項目里,甚至由高級開發(fā)來充當架構(gòu)的角色。

4、架構(gòu)師并不是門門都精通,而是得知道某個需求要點可以有哪些實現(xiàn)方案,然后會根據(jù)當前的預(yù)算,人員等情況合適地選擇適合當前項目組的。

5、對架構(gòu)師而言,不是什么都是得自己設(shè)計,比如實現(xiàn)負載均衡時,不可能讓架構(gòu)師用java實現(xiàn)一套解決方案,而是至少選用哪種組件,比如nginx,能在項目中把這套組件搭建起來。

6、架構(gòu)師設(shè)計出來的,是產(chǎn)品,未必是藝術(shù)品。架構(gòu)師設(shè)計出來的產(chǎn)品可能僅僅能滿足流量等的需求,可能只能遠觀,近看可能就一團糟了。但公司恰恰是要結(jié)果的,而且產(chǎn)品開發(fā)的周期會很緊,所以最終上線的架構(gòu)也就只能是應(yīng)付當前的需求。

二、高級開發(fā)升級到架構(gòu)師的必要條件

在很多場景里,高級開發(fā)只有具備了如下的條件,才有資格升級到架構(gòu)師,這里我是拿java架構(gòu)舉例。

1、Java Core以及Java web的基本技能,比如集合,多線程,SSM框架就不說了,這個是必須要掌握的。

2、至少能會在linux上看日志,如果可以,最好具備在linux上部署和運行程序的能力。

3、具備一定的調(diào)優(yōu)能力,比如需要能通過看日志,進行JVM內(nèi)存調(diào)優(yōu),或者通過看執(zhí)行計劃等方式,進行SQL調(diào)優(yōu)。

4、得了解設(shè)計模式,可以不用精通,但至少得知道,在哪種場景里,可以通過哪種模式來優(yōu)化結(jié)構(gòu)。

5、這個是關(guān)鍵的一條,考慮問題時,得擺脫“單機版”的局限,在知識儲備里,得包含負載均衡,消息隊列,數(shù)據(jù)庫集群等基于分布式的知識點。

6、和人打交道時,至少沒障礙,至少得能清晰地表達出自己的意思。

三、高級開發(fā)不會自動升級到架構(gòu),除非認真準備過

在大多數(shù)公司里,會有高級開發(fā)升級到架構(gòu)師的案例,我也見過不少高級開發(fā)通過跳槽,成為架構(gòu)師的案例。但機會只給有準備的人。

如果高級開發(fā)一直關(guān)注手頭上的事情,工作之余也不學(xué)習(xí),那可能就無法完成升級了,而且這個升級的步驟要比初級開發(fā)升高級的要難得多,為什么呢?

公司一般都是需要具備有過實踐經(jīng)驗的架構(gòu),而高級開發(fā)一般是通過跳槽來完成升級的,但如果你當前是高級開發(fā),估計很難有實踐架構(gòu)的機會,所以很難通過架構(gòu)師的面試,沒有架構(gòu)師的實踐機會,那么如何升級呢?這似乎是個死循環(huán)。

下面說下我見過的完成升級的捷徑:

1、如果你所在的公司是互聯(lián)網(wǎng)公司,那么高級開發(fā)多少會接觸些分布式高并發(fā)架構(gòu)的知識,那么高級開發(fā)在平時可以多觀察多積累,等到組內(nèi)架構(gòu)師離職了,一般就有機會了。

2、有些公司還是用傳統(tǒng)的技術(shù),比如還是用單機版的SSM,甚至用JDBC+java的開發(fā)模式,在這類公司里,升級似乎有些難,但不是不可以。在這里公司里干活的高級開發(fā),平時一定得多看相關(guān)書籍,看的時候圍繞一個主題:如果讓我設(shè)計一個能滿足雙十一流量的架構(gòu),我該怎么做?再具體下,如果讓我設(shè)計一個高并發(fā)流量的秒殺系統(tǒng),我又該怎么做?其實很多架構(gòu)面試題就圍繞這兩方面。

經(jīng)過學(xué)習(xí),至少高級開發(fā)能有架構(gòu)師的技能了,至于這類高級開發(fā)如何在簡歷中寫架構(gòu)方面的經(jīng)驗,別問我,我不能說,或者是,大家可能都知道,但我不可說。

四、架構(gòu)師必備的技能(再說升級的方式)

1、圍繞著剛才說的,實現(xiàn)一套能滿足高并發(fā)的系統(tǒng),那么得了解負載均衡,限流,模塊間的消息隊列,緩存,熱備冗余,數(shù)據(jù)庫集群等知識。

其實對高級開發(fā)而言,學(xué)習(xí)本身不是難點,關(guān)鍵是不知道該學(xué)什么,以及每個要點該學(xué)到什么程度?這里,如果你要面試成功,那么每個知識點知道個大概即可。

2、具體到學(xué)習(xí)路線,目前我知道的有阿里路線,我也見過有人把spring cloud各組件了解透,然后完成升級的案例。

3、對我而言,我升級時是看《億級流量網(wǎng)站架構(gòu)核心技術(shù)》這本書,其中涵蓋的知識面比較全,然后我再根據(jù)其中給出的知識體系逐一再深入,比方說,我看了其中有提到用hystrix做限流,我就再看其它資料,深入了解下這個組件的配置等詳細用法??傊?,先看面,再深入點,隨后再根據(jù)各組件,組裝一個能應(yīng)付高并發(fā)的系統(tǒng)。

4、實踐很重要,而且在實踐中別怕犯錯誤,但犯了錯得及時總結(jié)。

可以這樣說,架構(gòu)師開始幾個設(shè)計的項目,一定是慘不忍睹的,一定會不停地重構(gòu)。所以,在架構(gòu)師的實習(xí)階段,加班是常有的,甚至可能會不斷被領(lǐng)導(dǎo)說,設(shè)計出來的產(chǎn)品也有可能被抱怨。

這時一定得堅持,然后不斷反思下,同時在設(shè)計架構(gòu)時,一定能接觸到各類相關(guān)的知識,這樣架構(gòu)師就慢慢成長了。

5、這個是比較容易忽視的一點,架構(gòu)師一定得會溝通,這往往也是升級的瓶頸。

架構(gòu)師得和產(chǎn)品溝通,以得到本系統(tǒng)的需求,同時得和需求方協(xié)調(diào),在有限的時間里一定做不到面面俱到,一定得有所放棄,這個得事先談好。然后再設(shè)計,拼接組件,然后得和開發(fā)或開發(fā)經(jīng)理溝通,別讓開發(fā)誤解自己設(shè)計架構(gòu)時的本意。

我目前不是架構(gòu),還在升級的路上,根據(jù)我接觸到的架構(gòu)師的升級經(jīng)驗,以及我本身的升級體會,在這里來總結(jié)下架構(gòu)師的技術(shù)升級要點:用兩個字來描述:集群,用三個字:分布式,再用多點的文字:把海量的流量和數(shù)據(jù)合理分攤到數(shù)量合適的機器上。

想明白這點,后面就能知道該學(xué)哪些了,比如流量分攤時得負載均衡,存儲海量數(shù)據(jù)時得靠數(shù)據(jù)庫集群,或分庫分表,為了防止單點失效,得設(shè)計冗余系統(tǒng),系統(tǒng)間通訊時得用消息中間件,不能讓每次請求都走后臺,所以可以搭建緩存,單個緩存容易失效,所以可以搭建分布式緩存,為了監(jiān)控性能,所以得上一些監(jiān)控措施,比如監(jiān)控JVM,監(jiān)控數(shù)據(jù)等的,為了等看日志,所以得上一些日志組件。等等。

上述知識點掌握后,再組裝起來,比如搭建一個秒殺系統(tǒng)以檢驗自己的學(xué)習(xí)成果。

五、架構(gòu)師平時干什么?

1、開會,開需求會,開設(shè)計評審會等。大概會占到平時工作的30%到50%。

2、如果不是資深架構(gòu)或技術(shù)總監(jiān),那么未必會設(shè)計一套全新的架構(gòu),往往是在現(xiàn)有基礎(chǔ)上改進,比如做擴容,分庫分表,上新的日志監(jiān)控系統(tǒng)。這方面,架構(gòu)師往往會做個案例,比如在一臺linux上搭個日志系統(tǒng),把步驟寫清楚,讓開發(fā)依樣畫葫蘆。對于資深架構(gòu)而言,可能得重頭開始設(shè)計,或者作出調(diào)整技術(shù)組件等的決定,這一般也先在部分系統(tǒng)或部分機器上做試驗。

3、解決技術(shù)問題。這些問題未必是架構(gòu)級別的,但只要是高級開發(fā)解決不了的問題,架構(gòu)一般都得上,誰讓架構(gòu)是大牛呢?如果是架構(gòu)組件方的問題,比如配置或部署方面的問題,架構(gòu)師更得上。

4、但最重要的是學(xué)習(xí),比如想,當前流量是2000每秒,到了5000時我該怎么辦?然后再找些機器搭些組件來實驗一下。

六、架構(gòu)師更多的是和人打交道

和技術(shù)打交道容易,和人打交道難,因為一百個人會有一百個想法。

所以說,除了技術(shù)之外,架構(gòu)師還得具備如下的能力:

1、能通過交流展示自己的想法。

2、在各方利益不一致時得會協(xié)調(diào)妥協(xié),其實這也得靠各方溝通。

3、管理團隊的能力。

4、充分傾聽別人想法的能力。

所以說,很多公司的架構(gòu)師絕不是“兩耳不聞窗外事”,當然這類架構(gòu)師也有,但這類絕對是大神級別的。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 架構(gòu)師
    +關(guān)注

    關(guān)注

    0

    文章

    47

    瀏覽量

    4644
收藏 人收藏

    評論

    相關(guān)推薦

    英特爾前Xeon首席架構(gòu)師加盟高通

    高通公司近日宣布,英特爾前Xeon服務(wù)器處理器首席架構(gòu)師Sailesh Kottapalli已正式加入高通,并擔任高級副總裁一職。此舉被視為高通進軍數(shù)據(jù)中心CPU市場的重要一步
    的頭像 發(fā)表于 01-15 15:30 ?203次閱讀

    TLC555這個電路的二極管是干什么用的,它是從哪來的?

    就這個電路二極管不知道干什么用的,它是從哪來的? 仿真結(jié)果跟官方的不一樣
    發(fā)表于 11-08 15:37

    LM318 COMP管腳是什么引腳,干什么用的?

    LM318 COMP 管腳是什么引腳,干什么用的,PSPICEFORTI 里面沒有318的COMP管腳在怎么應(yīng)用
    發(fā)表于 07-31 07:45

    中級自動駕駛架構(gòu)師應(yīng)該學(xué)習(xí)哪些知識

    隨著自動駕駛技術(shù)的成熟,對系統(tǒng)架構(gòu)師的需求逐漸增加。自動駕駛系統(tǒng)架構(gòu)師負責設(shè)計整個系統(tǒng)的結(jié)構(gòu)、組件、接口和數(shù)據(jù)流;需要協(xié)調(diào)不同領(lǐng)域的專業(yè)知識,確保系統(tǒng)的可靠性、安全性和性能??傊?,自動駕駛系統(tǒng)架構(gòu)師
    的頭像 發(fā)表于 06-20 21:47 ?313次閱讀

    初級自動駕駛架構(gòu)師應(yīng)該學(xué)習(xí)哪些知識

    隨著自動駕駛技術(shù)的成熟,對系統(tǒng)架構(gòu)師的需求逐漸增加。自動駕駛系統(tǒng)架構(gòu)師負責設(shè)計整個系統(tǒng)的結(jié)構(gòu)、組件、接口和數(shù)據(jù)流;需要協(xié)調(diào)不同領(lǐng)域的專業(yè)知識,確保系統(tǒng)的可靠性、安全性和性能。總之,自動駕駛系統(tǒng)架構(gòu)師
    的頭像 發(fā)表于 06-20 21:45 ?342次閱讀

    請問CUBE中SPI配置的CRC Polynomial多項式是干什么用的?

    初學(xué)STM32,用原子的板子在學(xué),現(xiàn)在學(xué)到SPI,配置的時候看到這個東西,請問是干什么用的?和傳統(tǒng)庫中哪個匹配的? 而且這個配置沒有選項,貌似全是自己輸入的。
    發(fā)表于 05-07 06:41

    美國云服務(wù)器是干什么的

    美國云服務(wù)器主要用于提供計算資源、托管網(wǎng)站、應(yīng)用程序以及存儲數(shù)據(jù)等。很多用戶想要了解美國云服務(wù)器具體是干什么的,rak部落小編為您整理發(fā)布美國云服務(wù)器是干什么的。 美國云服務(wù)器是一種**基于云
    的頭像 發(fā)表于 04-10 10:16 ?462次閱讀

    英偉達是干什么的?

    英偉達(NVIDIA)是一家全球知名的圖形處理器(GPU)和人工智能(AI)技術(shù)公司,專門打造面向計算機、消費電子和移動終端,能夠改變整個行業(yè)的創(chuàng)新產(chǎn)品。
    的頭像 發(fā)表于 03-01 16:41 ?6668次閱讀

    請問CYUSB3014芯片的OTG_ID引腳是干什么用的?

    USB3014芯片的OTG_ID引腳是干什么用的??用電阻下拉接地可以嗎? 電阻的大小有要求嗎?
    發(fā)表于 02-29 08:21

    美國云服務(wù)器是干什么的

    對于美國服務(wù)器是干什么的,相信很多小白用戶不是非常了解,接下來小編就為您整理發(fā)布美國云服務(wù)器是干什么的相關(guān)資訊,希望對您有幫助。
    的頭像 發(fā)表于 02-19 09:53 ?468次閱讀

    云服務(wù)器是干什么的

     云服務(wù)器是干什么的?很多小白用戶會有疑惑,今天小編為您整理云服務(wù)器是干什么的相關(guān)資料,希望對您了解云服務(wù)器是干什么的有幫助。
    的頭像 發(fā)表于 02-18 09:58 ?1527次閱讀

    電磁爐工作原理 電磁爐板上有個可調(diào)電位器的作用是干什么的?

    電磁爐工作原理 電磁爐板上有個可調(diào)電位器的作用是干什么的? 電磁爐是一種利用電磁感應(yīng)原理來加熱食物的廚房電器。其工作原理是通過電路中的電感線圈產(chǎn)生高頻交變電磁場,使鐵制的鑲嵌在爐板下方的發(fā)熱盤產(chǎn)生
    的頭像 發(fā)表于 02-05 10:29 ?2600次閱讀

    法拉電容是干什么用的?

    法拉電容是干什么用的? 法拉電容是一種用于儲存和釋放電荷的電子元件。它是電容器的一種,與傳統(tǒng)的微型電容器相比,法拉電容能夠儲存更多的電能,并且能夠更快速地釋放電能。它的容量單位是法拉(F)。在本文
    的頭像 發(fā)表于 02-02 10:51 ?3880次閱讀

    gpu服務(wù)器是干什么的 gpu服務(wù)器與cpu服務(wù)器的區(qū)別有哪些

    gpu服務(wù)器是干什么的 gpu服務(wù)器與cpu服務(wù)器的區(qū)別 GPU服務(wù)器是一種專門用于處理圖形運算的服務(wù)器,而CPU服務(wù)器則是一種處理通用計算任務(wù)的服務(wù)器。它們之間的主要區(qū)別在于服務(wù)器所搭載的主要
    的頭像 發(fā)表于 01-30 15:31 ?925次閱讀

    什么是溫補晶振?溫補晶振是干什么的?

    什么是溫補晶振?溫補晶振是干什么的?? 溫補晶振是指對晶體振蕩器進行溫度補償?shù)囊环N技術(shù)。晶體振蕩器是一種電子設(shè)備,通過驅(qū)動晶體諧振頻率上的機械振動來產(chǎn)生穩(wěn)定的電信號。它在現(xiàn)代電子設(shè)備中廣泛應(yīng)用,如
    的頭像 發(fā)表于 01-23 16:42 ?1204次閱讀