在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

后端程序員是做什么的

工程師人生 ? 來源:工程師吳畏 ? 2019-07-26 17:14 ? 次閱讀

我剛開始做Web開發(fā)的時候,根本沒有前端,后端之說。

原因很簡單,那個時候服務(wù)器端的代碼就是一切:接受瀏覽器的請求,實現(xiàn)業(yè)務(wù)邏輯,訪問數(shù)據(jù)庫,用JSP生成HTML,然后發(fā)送給瀏覽器。

即使后來Javascript在瀏覽器中添加了一些AJAX的效果,那也是錦上添花,絕對不敢造次。因為頁面的HTML主要還是用所謂“套模板”的方式生成:美工生成HTML模板,程序員用JSP,Veloctiy,F(xiàn)reeMaker等技術(shù)把動態(tài)的內(nèi)容添加上去,僅此而已。

那個時候最流行的圖是這個樣子:

后端程序員是做什么的

在最初的J2EE體系中,這個表示層可不僅僅是瀏覽器中運行的頁面,還包括Java寫的桌面端,只是Java在桌面端太不爭氣, 沒有發(fā)展起來。

每個程序員都是所謂“全棧”工程師,不僅要搞定HTML, JavaScript, CSS,還要實現(xiàn)業(yè)務(wù)邏輯,編寫訪問數(shù)據(jù)庫的代碼。等到部署的時候,就把所有的代碼打成一個WAR包,往Tomcat指定的目錄一扔,測試一下沒問題,收工回家!

不差錢的公司會把程序部署到Weblogic,Websphere這樣的應(yīng)用服務(wù)器中,還會用上高大上的EJB。

雖然看起來生活“簡單”又“愜意”,但實際上也需要實現(xiàn)那些多變的、不講邏輯的業(yè)務(wù)需求,苦逼的本質(zhì)并沒有改變。

1前后端的分離

隨著大家對瀏覽器頁面的視覺和交互要求越來越高,“套模板”的方式漸漸無法滿足要求,這個所謂的表示層慢慢地遷移到瀏覽器當中去了,一大批像Angular, ReactJS之類的框架崛起,前后端分離了!

后端的工程師只負責(zé)提供接口和數(shù)據(jù),專注于業(yè)務(wù)邏輯的實現(xiàn),前端取到數(shù)據(jù)后在瀏覽器中展示,各司其職。

像Java這樣的語言很適合去實現(xiàn)復(fù)雜的業(yè)務(wù)邏輯,尤其是一些MIS系統(tǒng),行業(yè)軟件如稅務(wù)、電力、煙草、金融,通信等等。 所以剝離表示層,只做后端挺合適的。

但是如果僅僅是實現(xiàn)業(yè)務(wù)邏輯,那后端也不會需要這么多技術(shù)了,搞定SSH/SSM就行了。

2后端技術(shù)

互聯(lián)網(wǎng),尤其是移動互聯(lián)網(wǎng)開始興起以后,海量的用戶呼嘯而來,一個單機部署的小小War包肯定是撐不住了,必須得做分布式。

原來的單個Tomcat得變成Tomcat的集群,前邊弄個Web服務(wù)器做請求的負載均衡,不僅如此,還得考慮狀態(tài)問題,session的一致性。

業(yè)務(wù)越來越復(fù)雜,我們不得不把某些業(yè)務(wù)放到一個機器(或集群)上,把另外一部分業(yè)務(wù)放到另外一個機器(或集群)上,雖然系統(tǒng)的計算能力,處理能力大大增強,但是這些系統(tǒng)之間的通信就變成了頭疼的問題,消息隊列(MQ),RPC框架(如Dubbo)應(yīng)運而生,為了提高通信效率,各種序列化的工具(如Protobuf)也爭先空后地問世。

單個數(shù)據(jù)庫也撐不住了,那就做數(shù)據(jù)庫的讀寫分離,如果還不行,就做分庫和分表,把原有的數(shù)據(jù)庫垂直地切一切,或者水平地切一切, 但不管怎么切,都會讓應(yīng)用程序的訪問非常麻煩,因為數(shù)據(jù)要跨庫做Join/排序,還需要事務(wù),為了解決這個問題,又有各種各樣“數(shù)據(jù)訪問中間件”的工具和產(chǎn)品誕生。

為了最大程度地提高性能,緩存肯定少不了,可以在本機做緩存(如Ehcache),也可以做分布式緩存(如Redis),如何搞數(shù)據(jù)分片,數(shù)據(jù)遷移,失效轉(zhuǎn)移,這又是一個超級大的主題了。

互聯(lián)網(wǎng)用戶喜歡上傳圖片和文件,還得搞一個分布式的文件系統(tǒng)(如FastDFS),要求高可用,高可靠。

數(shù)據(jù)量大了,搜索的需求就自然而然地浮出水面,你得弄一個支持全文索引的搜索引擎(如Elasticsearch ,Solr)出來。

林子大了,什么鳥都有,必須得考慮安全,數(shù)據(jù)的加密/解密,簽名、證書,防止SQL注入,XSS/CSRF等各種攻擊。

3“大后端”

前面提到了這么多的系統(tǒng),還都是分布式的,每次上線,運維的同學(xué)說:把這么多系統(tǒng)協(xié)調(diào)好,把老子都累死了。

得把持續(xù)集成做好,能自動化地部署,自動化測試(其實前端也是如此),后來出現(xiàn)了一個革命化的技術(shù)docker, 能夠讓開發(fā)、測試、生成環(huán)境保持一致,系統(tǒng)原來只是在環(huán)境(如Ngnix, JVM,Tomcat,MySQL等)上部署代碼,現(xiàn)在把代碼和環(huán)境一并打包, 運維的工作一下子就簡化了。

公司自己購買服務(wù)器比較貴,維護也很麻煩,又難于彈性地增長,那就搞點虛擬的服務(wù)器吧,硬盤、內(nèi)存都可以動態(tài)擴展(反正是虛擬的), 訪問量大的時候多用點,沒啥訪問量了就釋放一點,按需分配,很方便,這就是云計算的一個場景。

隨著時間的推移,各個公司和系統(tǒng)收集的數(shù)據(jù)越來越多,都堆成一座大山了,難道就放在那里白白地浪費硬盤空間嗎?

有人就驚奇地發(fā)現(xiàn),咦,我們利用這些數(shù)據(jù)搞點事情啊, 比如把數(shù)據(jù)好好分析一下,預(yù)測一下這個用戶的購買/閱讀/瀏覽習(xí)慣,給他推薦一點東西嘛。

可是這么多數(shù)據(jù),用傳統(tǒng)的方式計算好幾天甚至好幾個月才能出個結(jié)果,到時候黃花菜都涼了,所以也得利用分布式的技術(shù),想辦法把計算分到各個計算機去,然后再把計算結(jié)果收回來, 時勢造英雄,Hadoop及其生態(tài)系統(tǒng)就應(yīng)運而生了。

之前聽說過一個大前端的概念,把移動端和網(wǎng)頁端都歸結(jié)為“前端”,我這里造個詞“大后端”,把那些用戶直接接觸不到的、發(fā)生在服務(wù)器端的都歸結(jié)進來。

4怎么學(xué)?

現(xiàn)在無論是前端還是后端,技術(shù)領(lǐng)域多如牛毛,都嚴重地細分了,所以我認為真正的全棧工程師根本不存在,因為一個人精力有限,不可能搞定這么多技術(shù)領(lǐng)域,太難了。

培訓(xùn)機構(gòu)所說的“全棧”,我認為就是前后端還在拉拉扯扯,藕斷絲連,沒有徹底分離的時候的“全棧”工程師。

那么問題來了, 后端這么多東西,我該怎么學(xué)?

之前寫過一篇文章叫做《上天還是入地》,說了學(xué)習(xí)的廣度和深度,在這里也是相通的。

往深度挖掘,可以成為某個技術(shù)領(lǐng)域的專家,如搜索方面的專家、安全方面的專家,分布式文件的專家等等,不管是哪個領(lǐng)域,重點都不是學(xué)會使用某個工具和框架, 而是保證你可以自己的知識和技術(shù)去搞定這個領(lǐng)域的頂尖問題。

往廣度發(fā)展,各個技術(shù)領(lǐng)域都要了解,對于某種需求,能夠選取合適的軟件和技術(shù)架構(gòu)來實現(xiàn)它,把需求轉(zhuǎn)化成合適的技術(shù)組件,讓這些組件以合適的方式連接、部署、運行,這也需要持續(xù)地學(xué)習(xí)和不斷的經(jīng)驗積累。

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

    關(guān)注

    4

    文章

    954

    瀏覽量

    30238
收藏 人收藏

    評論

    相關(guān)推薦
    熱點推薦

    如下圖所示,這個二極管是做什么的呢?

    如下圖所示,這個二極管是做什么的呢?歡迎大家交流。
    發(fā)表于 03-06 07:00

    阿里云升級通義靈碼AI程序員,全面上線

    近日,阿里云宣布其備受矚目的通義靈碼AI程序員已正式全面上線,為開發(fā)者帶來更為強大和便捷的編程輔助工具。 此次上線的通義靈碼AI程序員,在功能上實現(xiàn)了全面升級。現(xiàn)在,它支持VS Code
    的頭像 發(fā)表于 01-09 11:16 ?593次閱讀

    AI工作流自動化是做什么的

    AI工作流自動化是指利用人工智能技術(shù),對工作流程中的重復(fù)性、規(guī)則明確的任務(wù)進行自動化處理的過程。那么,AI工作流自動化是做什么的呢?接下來,AI部落小編為您分享。
    的頭像 發(fā)表于 01-06 17:57 ?558次閱讀

    TMS320C6000程序員指南

    電子發(fā)燒友網(wǎng)站提供《TMS320C6000程序員指南.pdf》資料免費下載
    發(fā)表于 12-24 17:19 ?0次下載
    TMS320C6000<b class='flag-5'>程序員</b>指南

    TMS320C55x DSP CPU程序員參考補充

    電子發(fā)燒友網(wǎng)站提供《TMS320C55x DSP CPU程序員參考補充.pdf》資料免費下載
    發(fā)表于 12-21 11:36 ?0次下載
    TMS320C55x DSP CPU<b class='flag-5'>程序員</b>參考補充

    UCD3138A64/UCD3138128程序員手冊

    電子發(fā)燒友網(wǎng)站提供《UCD3138A64/UCD3138128程序員手冊.pdf》資料免費下載
    發(fā)表于 12-09 14:42 ?0次下載
    UCD3138A64/UCD3138128<b class='flag-5'>程序員</b>手冊

    機械革命發(fā)布CODE AI程序員

    近日,英特爾新質(zhì)生產(chǎn)力技術(shù)生態(tài)大會在成都舉行,機械革命作為重要參展商帶來了多款明星產(chǎn)品引爆全場!其中更是在AI PC軟件生態(tài)產(chǎn)品發(fā)布分論壇上,Intel、智譜、機械革命三方聯(lián)合發(fā)布了專為程序員設(shè)計的CODE AI程序員本,成為本次大會的一大亮點。
    的頭像 發(fā)表于 11-30 10:34 ?905次閱讀

    Linux驅(qū)動程序程序員指南

    電子發(fā)燒友網(wǎng)站提供《Linux驅(qū)動程序程序員指南.pdf》資料免費下載
    發(fā)表于 11-22 15:53 ?0次下載
    Linux驅(qū)動<b class='flag-5'>程序</b><b class='flag-5'>程序員</b>指南

    AI編程工具會不會搶程序員飯碗

    AI編程工具可輔助編程,減少手動編碼,提升效率,對程序員有積極影響也有挑戰(zhàn)。程序員需深化技能、拓寬知識應(yīng)對。長遠看,AI與人類程序員將共生共榮。
    的頭像 發(fā)表于 11-08 10:17 ?447次閱讀

    第五屆長沙·中國1024程序員節(jié)開幕

    據(jù)官方媒體報道,10月24日;? 第五屆長沙·中國1024程序員節(jié)在湖南湘江新區(qū)開幕;本次中國1024程序員節(jié)以“智能應(yīng)用新生態(tài)”為主題。設(shè)置有岳麓對話、技術(shù)英雄會、主題峰會及賽事、展覽等活動,一場
    的頭像 發(fā)表于 10-25 15:42 ?406次閱讀

    京東上萬程序員都AI用它!

    對大模型生成代碼進行智能修復(fù),為程序員開啟代碼漏洞修復(fù)的“自動駕駛”模式,不但減少人工接入、提高工作效率,更為企業(yè)抵御內(nèi)外部各種攻擊構(gòu)建起一道堅固的安全屏障,確保業(yè)務(wù)的連續(xù)性和穩(wěn)定性。 JoyCoder是京東云自主研發(fā)的一款輔助開發(fā)人員
    的頭像 發(fā)表于 07-17 16:29 ?416次閱讀
    京東上萬<b class='flag-5'>程序員</b>都AI用它!

    程序員節(jié)視頻創(chuàng)意大賽,用串口屏贏取千元大獎

    10月24日,程序員專屬的節(jié)日里,我們盛大開啟“程序員節(jié)視頻創(chuàng)意大賽”特別活動!這不僅是一場視覺的盛宴,更是智慧與創(chuàng)意的璀璨碰撞。我們誠摯邀請每一位程序員及編程愛好者,拿起你的鏡頭,記錄下那些平凡日子中的不凡瞬間,讓編程的魅力與
    的頭像 發(fā)表于 07-08 10:38 ?72次閱讀
    <b class='flag-5'>程序員</b>節(jié)視頻創(chuàng)意大賽,用串口屏贏取千元大獎

    程序員節(jié)視頻創(chuàng)意盛宴,邀您共襄盛舉!

    10月24日,程序員專屬的節(jié)日里,我們盛大開啟“程序員節(jié)視頻創(chuàng)意大賽”特別活動!這不僅是一場視覺的盛宴,更是智慧與創(chuàng)意的璀璨碰撞。我們誠摯邀請每一位程序員及編程愛好者,拿起你的鏡頭,記錄下那些平凡日子中的不凡瞬間,讓編程的魅力與
    的頭像 發(fā)表于 07-04 09:00 ?67次閱讀
    <b class='flag-5'>程序員</b>節(jié)視頻創(chuàng)意盛宴,邀您共襄盛舉!

    助力程序員告別困擾已久的夢魘-Bug

    程序員的噩夢是什么?不用懷疑,就是讓你加班到崩潰的Bug!下面是經(jīng)過業(yè)界大佬們“長期加班”積累的小妙招,助力你離早下班又進一步~一、定位Bug范圍及性質(zhì)要有效解決問題,首先要縮小范圍,集中關(guān)注最近
    的頭像 發(fā)表于 07-02 08:10 ?586次閱讀
    助力<b class='flag-5'>程序員</b>告別困擾已久的夢魘-Bug

    大模型時代,程序員當下如何應(yīng)對 AI 的挑戰(zhàn)

    隨著 AI 技術(shù)的飛速發(fā)展,特別是大模型的出現(xiàn),傳統(tǒng)的程序員角色正在經(jīng)歷深刻的變革,我們不得不重新對自己進行審視和思考。 通用領(lǐng)域大模型的“泛化能力” 在過去的二十年內(nèi),AI 領(lǐng)域的大部分研究
    的頭像 發(fā)表于 06-28 16:19 ?789次閱讀
    大模型時代,<b class='flag-5'>程序員</b>當下如何應(yīng)對 AI 的挑戰(zhàn)
    主站蜘蛛池模板: 日本不卡一区二区三区在线观看 | a一级日本特黄aaa大片 | 快色视频免费观看 | 欧美性黑人极品hd网站 | 天堂成人一区二区三区 | 婷婷综合影院 | 欧美一区二区三区性 | 性天堂网 | 亚洲精品91大神在线观看 | 天堂网最新版www中文 | 亚州怡红院 | 日韩亚 | 韩国十八禁毛片无遮挡 | 久久天天躁夜夜躁狠狠 | 欧美αv| 欧美黄又粗暴一进一出抽搐 | 欧美午夜色视频国产精品 | 午夜视频免费看 | 九七婷婷狠狠成人免费视频 | 国产特黄一级片 | 人人搞人人 | 国产小视频免费在线观看 | 精品综合久久88色鬼首页 | 午夜日本一区二区三区 | 亚洲一级色 | 亚洲第一网站 | 亚洲一区二区三区中文字幕5566 | 色老久久精品偷偷鲁一区 | 四虎最新网站 | 欧美日韩国产在线一区 | 性欧美黑人 | 能在线观看的一区二区三区 | 国产超爽人人爽人人做 | 台湾一级毛片永久免费 | 国产亚洲欧洲人人网 | 国产大片黄在线看免费 | 97久久草草超级碰碰碰 | 簧片视频在线观看 | 69精品久久久久 | 国产成人91青青草原精品 | 天堂免费在线视频 |