最近自己做了幾個(gè)Java Web項(xiàng)目膘螟,有公司的商業(yè)項(xiàng)目成福,也有個(gè)人做著玩的小項(xiàng)目,寫篇文章記錄總結(jié)一下收獲荆残,列舉出在做項(xiàng)目的整個(gè)過(guò)程中奴艾,所需要用到的技能和知識(shí)點(diǎn),帶給還沒有真正接觸過(guò)完整Java Web項(xiàng)目的同學(xué)一個(gè)比較完整的視角内斯,提供一個(gè)所謂的“大局觀”蕴潦,也以便于同學(xué)們更有針對(duì)性地學(xué)習(xí)。當(dāng)然俘闯,這里所用到的例子項(xiàng)目是非常初級(jí)品擎,簡(jiǎn)單的項(xiàng)目,所以大神們就可以不用往下看了备徐。
首先我們從網(wǎng)站的架構(gòu)談起。一般來(lái)說(shuō)甚颂,我們將網(wǎng)站分為前端和后端蜜猾。前端主要負(fù)責(zé)頁(yè)面的展示,后端則是業(yè)務(wù)邏輯的實(shí)現(xiàn)振诬。由于html5的興起蹭睡,前端領(lǐng)域已經(jīng)越來(lái)越火熱,前端技術(shù)發(fā)展極快赶么,今天我們不做過(guò)多介紹肩豁,因?yàn)楝F(xiàn)在的互聯(lián)網(wǎng)公司,前端工程師和Java工程師是完全不同的兩種技術(shù)崗位辫呻。所以我們還是以Java的角度去看待一個(gè)項(xiàng)目清钥。在前端沒有那么火的前幾年,或者說(shuō)在經(jīng)典的Java Web的開發(fā)模式中放闺,我們使用Jsp技術(shù)來(lái)作為展現(xiàn)層的實(shí)現(xiàn)祟昭,其實(shí)也就是所謂的前端。當(dāng)然只懂得Jsp是不夠的還需要懂html,css,js,ajax等一些前端的基礎(chǔ)技術(shù)怖侦,Jsp技術(shù)在其中扮演外層包裝的角色篡悟。那么后端呢谜叹?后端是由于一些實(shí)現(xiàn)了業(yè)務(wù)邏輯Java代碼和數(shù)據(jù)庫(kù)組成。說(shuō)到這搬葬,就可以推出Web開發(fā)中經(jīng)典的MVC模式荷腊,Model-View-Controller。View,急凰,就是指表現(xiàn)層女仰,Model,是用來(lái)承載數(shù)據(jù)的抽象結(jié)構(gòu)香府,而Controller則是View和Model的橋梁董栽。View存在與前端代碼中,Controller企孩,Model存在與后端代碼中锭碳。在后端代碼中,為了保證代碼的整潔勿璃,易讀性擒抛,一般會(huì)采用分層的辦法,自頂向下分為controller層补疑,service層歧沪,dao層,數(shù)據(jù)層或者叫持久層(直接與數(shù)據(jù)庫(kù)打交道)莲组。有時(shí)候诊胞,為了達(dá)到解耦的目的,會(huì)在上述基層中間加入響應(yīng)的接口層锹杈,以使得接口與實(shí)現(xiàn)分離撵孤。在更加大型的網(wǎng)站中,會(huì)出現(xiàn)更加復(fù)雜的架構(gòu)竭望,比如dao層與數(shù)據(jù)層之間要有緩存層邪码,或者訪問壓力增大后,需要使用集群咬清,負(fù)載均衡等高級(jí)技術(shù)闭专,但在這里,我們就不深入討論復(fù)雜架構(gòu)了旧烧。
所以以上我們看到影钉,一個(gè)Web 項(xiàng)目前端需要表現(xiàn)層,后端有controller層粪滤,service層斧拍,dao層,持久層杖小。在表現(xiàn)層肆汹,除了剛才提到的html,css,js,ajax,jsp等基礎(chǔ)知識(shí)愚墓,在實(shí)際開發(fā)中,我們還會(huì)用到許多框架技術(shù)昂勉,比如tiles,velocity,freemarker等模板技術(shù)來(lái)簡(jiǎn)化表現(xiàn)層的開發(fā)己儒。在持久層挨决,除了jdbc外,還有Mybatis,Hibernate等框架來(lái)提高開發(fā)效率。在Java Web中最耀眼的當(dāng)屬Spring了梯啤,Spring作為一個(gè)貫穿整個(gè)項(xiàng)目的框架嫩实,為項(xiàng)目開發(fā)帶來(lái)依賴注入堕汞,面向切面編程的功能罪帖。除了這些,我們還需要熟練掌握一種關(guān)系型數(shù)據(jù)庫(kù)的使用迫吐,如MySQL,Oracle等库菲,當(dāng)然更好地話還需要掌握一種非關(guān)系型數(shù)據(jù)庫(kù),MongoDB志膀,Redis熙宇。
掌握了以上知識(shí)點(diǎn),恭喜你溉浙,你已經(jīng)可以開始寫Java Web項(xiàng)目了烫止。但是只會(huì)寫而不會(huì)部署,我們的項(xiàng)目仍然不能拿出來(lái)用戳稽。所以說(shuō)到這里馆蠕,我們的項(xiàng)目代碼已經(jīng)寫好,接下來(lái)該怎么辦呢惊奇?當(dāng)然是需要找一個(gè)容器來(lái)運(yùn)行我們的代碼荆几。這里的容器是當(dāng)然不是指Java里的數(shù)據(jù)類型,而是指應(yīng)用服務(wù)器赊时,此處要特別區(qū)分應(yīng)用服務(wù)器與Web服務(wù)器,至于Web服務(wù)器是什么行拢,稍后會(huì)介紹祖秒。(如果有同學(xué)不是很清楚服務(wù)器的概念,可以先看下一段舟奠,再回來(lái)看)目前竭缝,市面主要流行的應(yīng)用服務(wù)器有Tomcat,Jetty,JBoss等沼瘫。很多人會(huì)問我們?yōu)槭裁葱枰獞?yīng)用服務(wù)器抬纸?顧名思義,應(yīng)用服務(wù)器就是用來(lái)運(yùn)行我們的應(yīng)用代碼的耿戚。這里需要特別提到的是湿故,Java Web用到了像Jsp阿趁,servlet這樣的動(dòng)態(tài)web技術(shù),而這些技術(shù)的代碼是必須運(yùn)行中應(yīng)用服務(wù)器中的坛猪。所以當(dāng)我們寫好應(yīng)用代碼后脖阵,需要把自己的應(yīng)用部署到應(yīng)用服務(wù)器上。應(yīng)用部署好后墅茉,那么用戶們?cè)撛趺丛L問呢命黔?直接訪問應(yīng)用服務(wù)器嗎?這個(gè)時(shí)候就需要web服務(wù)器出場(chǎng)了就斤。在互聯(lián)網(wǎng)上悍募,最強(qiáng)大的應(yīng)用層協(xié)議當(dāng)屬http協(xié)議了,人們?cè)L問網(wǎng)站就是通過(guò)http協(xié)議來(lái)進(jìn)行訪問的洋机,而Web服務(wù)器就是支持http協(xié)議的服務(wù)器坠宴,所以就叫http服務(wù)器。Web服務(wù)器接收http請(qǐng)求槐秧,然后再將請(qǐng)求轉(zhuǎn)交給應(yīng)用服務(wù)器啄踊。有人會(huì)問用戶直接訪問應(yīng)用服務(wù)器不好嗎?為什么要給web服務(wù)器刁标,然后再到應(yīng)用服務(wù)器颠通?從功能實(shí)現(xiàn)上來(lái)說(shuō),是可以的膀懈。許多應(yīng)用服務(wù)器顿锰,比如Tomcat是具有web服務(wù)器的功能,所以直接訪問也可以启搂。但是由于在實(shí)際的生產(chǎn)環(huán)境中硼控,由于負(fù)載均衡,cdn加速等原因胳赌,我們還是需要在應(yīng)用服務(wù)器的前端再加一個(gè)web服務(wù)器來(lái)提高訪問效率牢撼,常用的有Nginx,Apache這樣的服務(wù)器。
之前老是在講這個(gè)服務(wù)器疑苫,那個(gè)服務(wù)器熏版,不知道有沒有同學(xué)聽懵了。其實(shí)服務(wù)器這個(gè)概念捍掺,我們應(yīng)該在真正接觸計(jì)算機(jī)專業(yè)領(lǐng)域之前早就聽說(shuō)過(guò)撼短,比如以前打游戲覺得卡的時(shí)候大家都時(shí)不時(shí)會(huì)用到服務(wù)器這個(gè)詞匯。但是我真正理解并研究服務(wù)器是在學(xué)習(xí)tomcat, jetty之后才開始的挺勿。那么服務(wù)器到底什么呢曲横?服務(wù)器這個(gè)概念其實(shí)很簡(jiǎn)單,就是一臺(tái)電腦不瓶,那它和我們?nèi)粘S玫碾娔X有什么區(qū)別禾嫉?第一灾杰,它一般沒有顯示器,它只有主機(jī)夭织。第二吭露,它的操作系統(tǒng)不同于我們常用的windows , Mac OS。更多的是nix系統(tǒng)尊惰。第三讲竿,它運(yùn)行了一些服務(wù)器端軟件。比如說(shuō)弄屡,我們上文提到的Tomcat , Jetty , Nginx,Apache,其實(shí)這些都是服務(wù)器軟件题禀,只是主機(jī)運(yùn)行了這些軟件,所以有時(shí)候大家就混淆了叫法膀捷。所以所謂的數(shù)據(jù)庫(kù)服務(wù)器迈嘹,大家也知道了,其實(shí)就是運(yùn)行了數(shù)據(jù)庫(kù)的主機(jī)全庸。說(shuō)到服務(wù)器秀仲,我們所需要掌握的重點(diǎn)知識(shí)就是服務(wù)器操作系統(tǒng),也就是nix系統(tǒng)壶笼,比如CentOS , Ubuntu等神僵。說(shuō)到這里,其實(shí)一個(gè)簡(jiǎn)單的完整的Java Web項(xiàng)目就差不多了覆劈。我們簡(jiǎn)單回顧一下保礼,首先,我們需要利用各種框架和開發(fā)技術(shù)寫出應(yīng)用代碼责语。接下來(lái)炮障,我們需要一個(gè)臺(tái)安裝了*nix系統(tǒng)的主機(jī),在上面安裝好Web服務(wù)器軟件坤候,應(yīng)用服務(wù)器軟件胁赢,再把我們的應(yīng)用代碼部署到應(yīng)用服務(wù)器上。現(xiàn)在我們只需要獲取到主機(jī)的IP地址白筹,就能夠遠(yuǎn)程訪問應(yīng)用了徘键。
知識(shí)點(diǎn)列表:
開發(fā):
- 視圖層技術(shù)——HTML,CSS,JS,AJAX,Tiles,Velocity,FreeMarker
- 持久層技術(shù)——MyBatis,Hibernate
- Spring , Spring MVC
- 項(xiàng)目構(gòu)建工具M(jìn)aven
- 日志Log4j
- 版本控制 Git
數(shù)據(jù)庫(kù)技術(shù):1. SQL語(yǔ)句2. 參數(shù)調(diào)優(yōu)
操作系統(tǒng):
- 熟練掌握一種Linux系統(tǒng),原理遍蟋,Shell命令
服務(wù)器技術(shù):
- 熟練使用并理解一個(gè)應(yīng)用服務(wù)器技術(shù)的原理(Tomcat)
- 熟練使用并理解一個(gè)Web服務(wù)器技術(shù)的原理(Nginx)
附加:
緩存技術(shù):
- 熟練使用并理解一種緩存技術(shù)(Redis,Memcache,EhCache)
非關(guān)系型數(shù)據(jù)庫(kù)
- 熟練使用并理解一種非關(guān)系型數(shù)據(jù)庫(kù)(MongoDB)
中間件技術(shù):
- JMS:activeMQ和kafka
- RPC: Dubbo
設(shè)計(jì)模式:
- 了解并能夠使用幾種最主要的設(shè)計(jì)模式
網(wǎng)絡(luò):
- 熟練使用并理解一個(gè)網(wǎng)絡(luò)開發(fā)技術(shù)(Netty)
- 熟悉http螟凭,TCP協(xié)議
Java虛擬機(jī):
- 熟悉jvm運(yùn)行原理虚青,內(nèi)存分布
- jvm參數(shù)調(diào)優(yōu)
基本不用簡(jiǎn)書了
喜歡的可以關(guān)注知乎 L.JA