長(cháng)沙java軟件開(kāi)發(fā)培訓,Java是開(kāi)源的,框架很多,這些框架都能解決特定的問(wèn)題,提高開(kāi)發(fā)效率、簡(jiǎn)化我們的代碼復雜度,現在除了很多大家通用的一些主流框架外,很多公司針對自己的業(yè)務(wù)會(huì )自定義一些公司內部的框架,當然作為學(xué)習者我們首先要清楚Javaweb都有哪些框架需要學(xué)習。
回答這個(gè)問(wèn)題首先要看我們的項目規模,對于"體量"較小的單應用項目,和需要處理海量數據、高并發(fā)的分布式項目所學(xué)習使用的框架還是不同的。
對于"體量"較小的單應用項目:
ORM型框架,很多Javaweb程序都需要使用關(guān)系數據庫來(lái)進(jìn)行數據的持久化,所以對于這種需要進(jìn)行數據庫操作的框架,也就是對JDBC進(jìn)行封裝的ORM框架是需要學(xué)習的,目前比較流行的是基于SQL的mybatis框架,這是一個(gè)輕量級的ORM框架,學(xué)習使用起來(lái)比較容易上手,同類(lèi)型的還有Hibernate框架。
MVC型框架,MVC把程序從邏輯上分為視圖層、控制層、模型層,各層各司其職,之間是相互調用的關(guān)系而不是相互依賴(lài)的關(guān)系,這種模式能很好的適應需求的變化及軟件的升級變更。目前應用較多的MVC框架是spring MVC框架,這個(gè)框架有清晰的角色劃分,有強大而直接的配置方式,高效的綁定和驗證等很多優(yōu)勢。較早的Struts2框架也是MVC框架。
Spring框架,其實(shí)Java的從業(yè)者很多都繞不開(kāi)Spring ,Spring家族有很多"工具",編程思想從面相過(guò)程到面相對象是一個(gè)巨大的進(jìn)步,然而隨著(zhù)程序越來(lái)越復雜,對象越來(lái)越多,高效的"管理"及應用這些對象變得越來(lái)越重要,Spring的IoC就是把對象的創(chuàng )建、"管理"交由Spring容器來(lái)進(jìn)行,來(lái)實(shí)現控制反轉,同時(shí)提供了各種注入值(DI)的方式,大大提高和簡(jiǎn)化了我們的工作,這就是javaweb需要學(xué)習的spring的IoC/DI;我們程序的業(yè)務(wù)比較復雜時(shí),除了要完成核心功能外,還需要完成注入異常處理、日志記錄、事務(wù)處理等常規功能,這些常規的操作比較耗費精力,springAOP(面向切面編程)就是解決這個(gè)問(wèn)題的。
Javaweb需要學(xué)習一些前端框架,尤其是問(wèn)題中提到的已經(jīng)寫(xiě)好了數據接口,或者是已經(jīng)有了簡(jiǎn)單的后臺,前端框架jQuery是一定要學(xué)習的,如果項目基于效率考慮,需要前后端分離,可以學(xué)習vue等框架。
對于海量數據、高并發(fā)類(lèi)型的分布式項目,這種類(lèi)型項目的特點(diǎn)就是前面提到的需要處理的數據量大,例如雙十一阿里需要處理的訂單數據,比如12306的搶票等。
提升查詢(xún)效率的緩存數據庫框架Redis,這個(gè)框架在單應用程序中為了提升數據的讀取效率也可以使用,先把數據從關(guān)系數據庫通過(guò)Redis存放到緩存中,從緩存中讀取數據的速度比直接從硬盤(pán)上讀取就要高多了,另外Redis還能進(jìn)行集群配置主從服務(wù)器等,使用非常方便,同類(lèi)型的還有memcached框架;
在分布式中,服務(wù)集群中的負載均衡特別重要,Nginx是一個(gè)高性能的HTTP和反向代理服務(wù)框架,支持多種負載均衡算法;
消息隊列框架:RabbitMQ、ActiveMQ、RocketMQ等,在電商系統中,當結算訂單后,需要進(jìn)行積分的變化等操作,這些操作的量很大,如果等積分變化結束后在通知用戶(hù)結算成功,顯然不可行,那么此時(shí)積分的變更操作交由消息隊列來(lái)完成。
搜索框架,為了提升搜索的效率,創(chuàng )建搜索索引庫及中文搜索分詞等,可以使用solr框架,同類(lèi)型的還有ElasticSearch
用于文件使用的分布式文件系統框架Fastdfs
Spring boot框架,簡(jiǎn)化了spring 的復雜配置,提供了Thymeleaf模板,很多微服務(wù)都是基于Springboot的;
微服務(wù)框架,把應用拆分成若干個(gè)為服務(wù)后,很好的適用了高并發(fā)及海量數據的處理,但是微服務(wù)的管理也很重要,目前基于服務(wù)注冊、服務(wù)監控的框架有Dubbo+zookeeper,還有SpringCloud,里面包括SpringCloud Eureka,SpringCloud Ribbon,SpringCloud Feign,SpringCloudHystrix,SpringCloudZuul,SpringCloud Config,SpringCloud ZipKin,SpringCloud Sleuth等;
其它框架,還有很多根據項目特定要求的一些框架,例如進(jìn)行日志記錄的log4j框架,進(jìn)行認證和授權的shiro框架,工作流處理的Activite框架等。
總結一下:學(xué)習框架好的方式就是在實(shí)際項目中去應用,這對框架的原理、應用流程都能有很好的學(xué)習效果,如果單純的做一些簡(jiǎn)單的Demo,框架的很多應用場(chǎng)景、優(yōu)化、注意事項等是學(xué)習不全面的。