java web現在流行用什麼框架?

Java是開源的,框架很多,這些框架都能解決特定的問題,提高開發效率、簡化我們的代碼複雜度,現在除了很多大家通用的一些主流框架外,很多公司針對自己的業務會自定義一些公司內部的框架,當然作爲學習者我們首先要清楚Javaweb都有哪些框架需要學習。

回答這個問題首先要看我們的項目規模,對於”體量”較小的單應用項目,和需要處理海量數據、高併發的分佈式項目所學習使用的框架還是不同的。



對於“體量”較小的單應用項目:

ORM型框架,很多Javaweb程序都需要使用關係數據庫來進行數據的持久化,所以對於這種需要進行數據庫操作的框架,也就是對JDBC進行封裝的ORM框架是需要學習的,目前比較流行的是基於SQL的mybatis框架,這是一個輕量級的ORM框架,學習使用起來比較容易上手,同類型的還有Hibernate框架。

MVC型框架,MVC把程序從邏輯上分爲視圖層、控制層、模型層,各層各司其職,之間是相互調用的關係而不是相互依賴的關係,這種模式能很好的適應需求的變化及軟件的升級變更。目前應用較多的MVC框架是spring MVC框架,這個框架有清晰的角色劃分,有強大而直接的配置方式,高效的綁定和驗證等很多優勢。較早的Struts2框架也是MVC框架。

Spring框架,其實Java的從業者很多都繞不開Spring ,Spring家族有很多“工具”,編程思想從面相過程到面相對象是一個巨大的進步,然而隨着程序越來越複雜,對象越來越多,高效的“管理”及應用這些對象變得越來越重要,Spring的IoC就是把對象的創建、“管理”交由Spring容器來進行,來實現控制反轉,同時提供了各種注入值(DI)的方式,大大提高和簡化了我們的工作,這就是javaweb需要學習的spring的IoC/DI;我們程序的業務比較複雜時,除了要完成核心功能外,還需要完成注入異常處理、日誌記錄、事務處理等常規功能,這些常規的操作比較耗費精力,springAOP(面向切面編程)就是解決這個問題的。

Javaweb需要學習一些前端框架,尤其是問題中提到的已經寫好了數據接口,或者是已經有了簡單的後臺,前端框架jQuery是一定要學習的,如果項目基於效率考慮,需要前後端分離,可以學習vue等框架。

對於海量數據、高併發類型的分佈式項目,這種類型項目的特點就是前面提到的需要處理的數據量大,例如雙十一阿里需要處理的訂單數據,比如12306的搶票等。

提升查詢效率的緩存數據庫框架Redis,這個框架在單應用程序中爲了提升數據的讀取效率也可以使用,先把數據從關係數據庫通過Redis存放到緩存中,從緩存中讀取數據的速度比直接從硬盤上讀取就要高多了,另外Redis還能進行集羣配置主從服務器等,使用非常方便,同類型的還有memcached框架;

在分佈式中,服務集羣中的負載均衡特別重要,Nginx是一個高性能的HTTP和反向代理服務框架,支持多種負載均衡算法;

消息隊列框架:RabbitMQ、ActiveMQ、RocketMQ等,在電商系統中,當結算訂單後,需要進行積分的變化等操作,這些操作的量很大,如果等積分變化結束後在通知用戶結算成功,顯然不可行,那麼此時積分的變更操作交由消息隊列來完成。

搜索框架,爲了提升搜索的效率,創建搜索索引庫及中文搜索分詞等,可以使用solr框架,同類型的還有ElasticSearch

用於文件使用的分佈式文件系統框架Fastdfs

Spring boot框架,簡化了spring 的複雜配置,提供了Thymeleaf模板,很多微服務都是基於Springboot的;

微服務框架,把應用拆分成若干個爲服務後,很好的適用了高併發及海量數據的處理,但是微服務的管理也很重要,目前基於服務註冊、服務監控的框架有Dubbo+zookeeper,還有SpringCloud,裏面包括SpringCloud Eureka,SpringCloud Ribbon,SpringCloud Feign,SpringCloudHystrix,SpringCloudZuul,SpringCloud Config,SpringCloud ZipKin,SpringCloud Sleuth等;

其它框架,還有很多根據項目特定要求的一些框架,例如進行日誌記錄的log4j框架,進行認證和授權的shiro框架,工作流處理的Activite框架等。

總結一下:學習框架最好的方式就是在實際項目中去應用,這對框架的原理、應用流程都能有很好的學習效果,如果單純的做一些簡單的Demo,框架的很多應用場景、優化、注意事項等是學習不全面的。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章