溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Servlet:我還活著呢!

發(fā)布時間:2020-08-19 01:19:53 來源:ITPUB博客 閱讀:175 作者:書寫人生 欄目:編程語言
原文鏈接: https://mp.weixin.qq.com/s/HcS-sgJbfrY8t7kYz-4yFQ

轉(zhuǎn)自:碼農(nóng)翻身(微信號:coderising)

我是Servlet, 由于很多框架把我深深地隱藏了起來,我變得似乎無關(guān)緊要了,很多人也選擇性的把我給遺忘了。 其實,我還活得好好的呢, 只不過是從前臺明星慢慢退居幕后而已。

1、好基友Servlet + JSP

想當(dāng)年我剛剛誕生的時候,無數(shù)人對我趨之若鶩。

因為那個時候Web服務(wù)器只能處理靜態(tài)的HTML頁面,圖片,JavaScript這樣的東西, 比如Apache 這個著名的Web服務(wù)器。

人類想要看一點動態(tài)的內(nèi)容,比如什么留言板,購物網(wǎng)站等,還得靠極為難用的CGI。

我一出生, 他們就歡呼著把CGI給拋棄,紛紛改用Java寫Servlet程序, 再后來我的好兄弟JSP問世,我們簡直形成了絕配。

我負責(zé)控制,JSP負責(zé)視圖,再加上負責(zé)數(shù)據(jù)的Java Bean, MVC三駕馬車正式形成,風(fēng)靡一時,想當(dāng)年,著名的開源論壇軟件Jive就是我們的巔峰之作。

Servlet:我還活著呢!

說起JSP,這小子有時候還不太服我,經(jīng)常振振有詞地說:“你Servlet沒什么了不起的,我也可以當(dāng)Controller!”

JSP確實可以當(dāng)Controller, 早些年我還真的見過,一個長達6000多行的JSP,行使著Controller的職責(zé),每當(dāng)程序員要改這些代碼就膽顫心驚,叫苦不迭。

其實JSP不知道,它本質(zhì)上也就是Servlet ,JSP只不過穿了一件漂亮的外衣,給了程序員們一個輕松寫動態(tài)頁面的工具而已,實際運行的時候會被編譯成Servlet類, 本質(zhì)上我們是一樣的。

我和JSP都生活在 Servlet Container當(dāng)中,Container這個詞有點高大上,但是說白了,無非就是能執(zhí)行Servlet和JSP的一個東西,比如說 Tomcat, 比如說 Jetty

但是無論是我還是JSP, 我們能處理的只是HTTP請求,必須得有人把HTTP請求轉(zhuǎn)發(fā)給我們才可以。

這件事情只有讓Tomcat, Jetty他們來做了,他們自己可以接收HTTP請求,然后轉(zhuǎn)發(fā)給我們;

他們也可以從別人,例如Apache那里接收HTTP請求,然后發(fā)給我們處理,處理完了再轉(zhuǎn)發(fā)給Apache, Apache再發(fā)給人類的瀏覽器。

雖然有點麻煩,但是這種方式確實非常靈活,各司其職,擴展性比較好,比如,一個Apache可以把請求分發(fā)給后臺多個Tomcat中的一個。

Apache,Nginx 他們專心致志地去處理靜態(tài)內(nèi)容(HTML, JS, 圖片) ,我們這里心無旁騖地執(zhí)地執(zhí)行“不講邏輯的”業(yè)務(wù)邏輯,訪問數(shù)據(jù)庫,然后生成頁面返回。

Servlet:我還活著呢!

2、Application Server

日子過得波瀾不驚,我一度認為,這個世界就將這么運行下去。

應(yīng)用程序越開發(fā)越多,出現(xiàn)了一些通用的需求,比如安全,事務(wù),分布式等等,這些需求應(yīng)用程序不愿意處理,想丟給操作系統(tǒng),操作系統(tǒng)也不愿意處理, 那怎么辦?

不知道是誰提了一個叫做中間件的概念: 你們不愿意做的,我們中間件來做。

Java 世界也不敢怠慢,也搞出了一大堆的規(guī)范,像什么EJB,JMS,JTA等等,把我和JSP也合并到其中,形成一個大“雜燴”,叫做J2EE。

其中最春風(fēng)得意的就是EJB這家伙,獨自生活在 EJB Container中(又是Container?。柗Q能支持真正地分布式計算:一個EJB可以有多個實例,分布到多個服務(wù)器中,應(yīng)對用戶的請求, 聽起來很高深的技術(shù)。

他們把Servlet Container稱為 Web Container , 和EJB Container 一起,還有其他的一些東西,被合并到一個叫做 Application Server當(dāng)中去了。 最知名的幾個Application Server 就是 Weblogic , WebSphere , JBoss。

國內(nèi)的金蝶也實現(xiàn)過一個,叫做Apusic,雖然影響力不如前面那幾位,但值得贊賞。

Servlet:我還活著呢!

3、退居幕后

我和JSP都沒有料到,EJB搶了我們的風(fēng)頭,成了系統(tǒng)的中心, 讓我們極為不爽。

我和JSP豈能善罷甘休? 我們決定抓住EJB的弱點進行反擊, 我們和人類一個叫做Rod Johnson的聯(lián)合,讓他出面,列舉出EJB的36大罪狀,昭告天下,這些罪狀包括但不限于:笨重,性能低下,難于測試,昂貴…

EJB確實是個扶不起的阿斗, 很快就被人批得體無完膚,大家紛紛投入Rod Johnson 創(chuàng)建的Spring的懷抱。

我松了一口氣, 可是很快就發(fā)現(xiàn)事情不對勁, 大家紛紛用起了框架! 比如Struts, SpringMVC…

在這些框架中,我雖然處于一個非常重要的角色, 但是通常情況下只要配置一下web.xml,就可以把我扔到一邊了。

Container 照例把HTTP請求傳遞給我,但是我卻不能親手處理,我需要傳遞給框架,框架分派給Controller,沒我什么事了!

那些程序員們要做的事情就是寫Controller, Service , DAO這些和我八班桿子打不著的東西。

我恨框架, 但是看到程序員們寫代碼寫得那么高興,又無話可說,畢竟框架極大地減少了他們的工作量:

之前對于每個HTTP請求,程序員得手工地去解析URL, 調(diào)用相關(guān)的Java Bean。
現(xiàn)在只需要用個配置文件或者注解就可以把URL給映射到一個Java 類。

之前對于HTTP請求中的參數(shù), 程序員也得手工解析和驗證。
現(xiàn)在也可以直接映射到Java 對象或者變量

用起來這么簡單,他們不用才怪。

Servlet:我還活著呢!

更讓人生氣的是,Rod他們后來倒騰出來一個叫做 Spring Boot的東西,徹底地把我給隱藏起來了!

尤其是對于一個新手來說,甚至完全不知道我的存在。

Tomcat和Jetty這樣的Servlet Container也很悲催,他們竟然被內(nèi)嵌到了Spring Boot中! 程序員開發(fā)出的Web應(yīng)用,就像一個普通的Java程序一樣,從main函數(shù)開始運行。

我們徹底地退居幕后了!

不過我有義務(wù)提醒一下學(xué)習(xí)后端編程的同學(xué),不要一上來就學(xué)習(xí)框架,不要被框架迷住你的雙眼!

還是應(yīng)該好好看看最基本的Java Web, 就是我和我的兄弟JSP。

skycto JEEditor:一鍵生成基于SSH框架的功能代碼

4、威脅來臨

雖然是退居幕后,但是我的核心地位依然穩(wěn)固,是Java Web應(yīng)用的中堅力量,我生活在Servlet Container中,專門處理HTTP請求,這么多年難逢敵手。

直到有一天,有個叫做Netty的家伙上門挑戰(zhàn)。

這個Netty居然完全不用Servlet Container,或者換句話說,人家自己就是一個“Container” , 這對我來說絕對是釜底抽薪的攻擊, 我引以為傲的Servlet 規(guī)范, Servlet API統(tǒng)統(tǒng)不管用了。

我只能處理HTTP, 可是這個Netty支持各種各樣的協(xié)議:HTTP, FTP, UDP, 它還支持實現(xiàn)各種各樣自定義的協(xié)議! 這就意味著程序員完全可以自定義一套自己應(yīng)用的RPC協(xié)議,然后放到Netty上運行。

它的底層是Java NIO,又封裝了Java NIO那些復(fù)雜的底層細節(jié),可以輕松實現(xiàn)高性能、高可靠的網(wǎng)絡(luò)服務(wù)器, 這實在是太可怕了。

我似乎看到了一個可怕的場景: 用Netty 開發(fā)的服務(wù)器端,運行著眾多的Web 服務(wù),他們之間使用私有的協(xié)議在互相調(diào)用,效率極高,性能極高, 根本沒有Servlet, HTTP, Tomcat什么事。

讓我稍感安慰的是,直接使用Netty的程序員們還不多,雖說有不少人在使用基于Netty的Dubbo, 但是Netty也被封裝隱藏起來了。 我估計真正具有鉆研精神的程序員才愿意去研究他吧。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI