當前位置:首頁 » 編程語言 » java技術架構圖

java技術架構圖

發布時間: 2022-07-31 08:17:11

『壹』 java開發 詳細描述技術架構怎麼寫

技術架構 就是指你要做的模塊 業務層、數據層和展示層都用的什麼技術,然後用圖形顯示出來

『貳』 java架構有哪些

主流框架還是MVC框架技術
1:jsp+servlet+javaben適用於比較小的項目
2:strut+spring+hibnate
目前這是主流框架技術組合在一起就是ssh了
適用於要求可維護性強的框架技術
3:ejb jsf等重量級框架技術比較過時
WebWork 【Java開源 Web框架】
WebWork 是由OpenSymphony組織開發的,致力於組件化和代碼重用的拉出式MVC模式J2EE Web框架。WebWork目前最新版本是2.1,現在的WebWork2.x前身是Rickard Oberg開發的WebWork,但現在WebWork已經被拆分成了Xwork1和WebWork2兩個項目。 Xwork簡潔、靈活功能強大,它是一個標準的Command模式實現,並且完全從web層脫離出來。 Xwork提供了很多核心功能:前端攔截機(interceptor),運行時表單屬性驗證,類型轉換,強大的表達式語言(OGNL – the Object Graph Notation Language),IoC(Inversion of Control倒置控制)容器等。 WebWork2建立在Xwork之上,處理HTTP的響應和請求。WebWork2使用ServletDispatcher將HTTP請求的變成 Action(業務層Action類), session(會話)application(應用程序)范圍的映射,request請求參數映射。WebWork2支持多視圖表示,視圖部分可以使用 JSP, Velocity, FreeMarker, JasperReports,XML等。在WebWork2.2中添加了對AJAX的支持,這支持是構建在DWR與Dojo這兩個框架的基礎之上.【EclipseWork:用於WebWork輔助開發的一個Eclipse插件】
Struts 【Java開源 Web框架】
Struts 是一個基於Sun J2EE平台的MVC框架,主要是採用Servlet和JSP技術來實現的。由於Struts能充分滿足應用開發的需求,簡單易用,敏捷迅速,在過去的一年中頗受關注。Struts把Servlet、JSP、自定義標簽和信息資源(message resources)整合到一個統一的框架中,開發人員利用其進行開發時不用再自己編碼實現全套MVC模式,極大的節省了時間,所以說Struts是一個非常不錯的應用框架。【StrutsIDE:用於Struts輔助開發的一個Eclipse插件】
Hibernate 【Java開源 持久層框架】
Hibernate 是一個開放源代碼的對象關系映射框架,它對JDBC進行了非常輕量級的對象封裝,使得Java程序員可以隨心所欲的使用對象編程思維來操縱資料庫。 Hibernate可以應用在任何使用JDBC的場合,既可以在Java的客戶端程序實用,也可以在Servlet/JSP的Web應用中使用,最具革命意義的是,Hibernate可以在應用EJB的J2EE架構中取代CMP,完成數據持久化的重任。Eclipse平台下的Hibernate輔助開發工具:【Hibernate Synchronizer】【MiddlegenIDE】
Quartz 【Java開源 Job調度】
Quartz 是OpenSymphony開源組織在Job scheling領域又一個開源項目,它可以與J2EE與J2SE應用程序相結合也可以單獨使用。Quartz可以用來創建簡單或為運行十個,百個,甚至是好幾萬個Jobs這樣復雜的日程序表。Jobs可以做成標準的Java組件或 EJBs。Quartz的最新版本為Quartz 1.5.0。
Velocity 【Java開源 模板引擎】
Velocity 是一個基於java的模板引擎(template engine)。它允許任何人僅僅簡單的使用模板語言(template language)來引用由java代碼定義的對象。當Velocity應用於web開發時,界面設計人員可以和java程序開發人員同步開發一個遵循MVC架構的web站點,也就是說,頁面設計人員可以只關注頁面的顯示效果,而由java程序開發人員關注業務邏輯編碼。Velocity將java代碼從web頁面中分離出來,這樣為web站點的長期維護提供了便利,同時也為我們在JSP和PHP之外又提供了一種可選的方案。 Velocity的能力遠不止web站點開發這個領域,例如,它可以從模板(template)產生SQL和PostScript、XML,它也可以被當作一個獨立工具來產生源代碼和報告,或者作為其他系統的集成組件使用。Velocity也可以為Turbine web開發架構提供模板服務(template service)。Velocity+Turbine提供一個模板服務的方式允許一個web應用以一個真正的MVC模型進行開發。 【VeloEclipse :Velocity在Eclipse平台下的一個輔助開發插件】
IBATIS 【Java開源 持久層框架】
使用ibatis 提供的ORM機制,對業務邏輯實現人員而言,面對的是純粹的Java對象, 這一層與通過Hibernate 實現ORM 而言基本一致,而對於具體的數據操作,Hibernate 會自動生成SQL 語句,而ibatis 則要求開發者編寫具體的SQL 語句。相對Hibernate等 「全自動」ORM機制而言,ibatis 以SQL開發的工作量和資料庫移植性上的讓步,為系統設計提供了更大的自由空間。作為「全自動」ORM 實現的一種有益補充,ibatis 的出現顯 得別具意義。

『叄』 java分布式架構有哪些技術

既然是分布式系統,系統間通信的技術就不可避免的要掌握。

首先,我們必須掌握一些基本知識,例如網路通信協議(例如TCP / UDP等),網路IO(Blocking-IO,NonBlocking-IO,Asyn-IO),網卡(多隊列等)。 了解有關連接重用,序列化/反序列化,RPC,負載平衡等的信息。

在學習了這些基本知識之後,您基本上可以在分布式系統中編寫一個簡單的通信模塊,但這實際上還遠遠不夠。 現在,您已經進入了分布式欄位,您已經對規模有很多要求。 這意味著需要一種通信程序,該程序可以支持大量連接,高並發性和低資源消耗。

大量的連接通常會有兩種方式:

大量client連一個server

當前在NonBlocking-IO非常成熟的情況下,支持大量客戶端的伺服器並不難編寫,但是在大規模且通常是長連接的情況下,有一點需要特別注意 ,即伺服器掛起時不可能所有客戶端都在某個時間點啟動重新連接。 那基本上是一場災難。 我見過一些沒有經驗的類似案例。 客戶端規模擴大後,伺服器基本上會在重新啟動後立即刷新。 大量傳入連接中斷(當然,伺服器的積壓隊列首先應設置為稍大一些)。 可以使用的通常方法是在客戶端重新連接之前睡眠一段隨機的時間。 另外,重連間隔採用避讓演算法

一個client連大量的server

有些場景也會出現需要連大量server的現象,在這種情況下,同樣要注意的也是不要並發同時去建所有的連接,而是在能力范圍內分批去建。

除了建連接外,另外還要注意的地方是並發發送請求也同樣,一定要做好限流,否則很容易會因為一些點慢導致內存爆掉。

這些問題在技術風險上得考慮進去,並在設計和代碼實現上體現,否則一旦隨著規模上去了,問題一時半會還真不太好解。

高並發這個點需要掌握CAS、常見的lock-free演算法、讀寫鎖、線程相關知識(例如線程交互、線程池)等,通信層面的高並發在NonBlocking-IO的情況下,最重要的是要注意在整體設計和代碼實現上盡量減少對io線程池的時間佔用。

低資源消耗這點的話NonBlocking-IO本身基本已經做到。

伸縮性

分布式系統基本上意味著規模不小。 對於此類系統,在設計時必須考慮可伸縮性。 在體系結構圖上繪制的任何點,如果請求量或數據量繼續增加,該怎麼辦? 通過添加機器來解決。 當然,此過程不需要考慮無限的情況。 如果您有經驗的建築師,從相對較小的規模到非常大型的范圍,那麼優勢顯然並不小,而且它們也將越來越稀缺。 。

橫向可擴展性(Scale Out)是指通過增加伺服器數量來提高群集的整體性能。 垂直可伸縮性(Scale Up)是指提高每台伺服器的性能以提高集群的整體性能。 縱向可擴展性的上限非常明顯,而分布式系統則強調水平可伸縮性。

分布式系統應用服務最好做成無狀態的

應用服務的狀態是指運行時程序因為處理服務請求而存在內存的數據。分布式應用服務最好是設計成無狀態。因為如果應用程序是有狀態的,那麼一旦伺服器宕機就會使得應用服務程序受影響而掛掉,那存在內存的數據也就丟失了,這顯然不是高可靠的服務。把應用服務設計成無狀態的,讓程序把需要保存的數據都保存在專門的存儲上(eg. 資料庫),這樣應用服務程序可以任意重啟而不丟失數據,方便分布式系統在伺服器宕機後恢復應用服務。

伸縮性的問題圍繞著以下兩種場景在解決:

無狀態場景

對於無狀態場景,要實現隨量增長而加機器支撐會比較簡單,這種情況下只用解決節點發現的問題,通常只要基於負載均衡就可以搞定,硬體或軟體方式都有;

無狀態場景通常會把很多狀態放在db,當量到一定階段後會需要引入服務化,去緩解對db連接數太多的情況。

有狀態場景

所謂狀態其實就是數據,通常採用Sharding來實現伸縮性,Sharding有多種的實現方式,常見的有這么一些:

2.1 規則Sharding

基於一定規則把狀態數據進行Sharding,例如分庫分表很多時候採用的就是這樣的,這種方式支持了伸縮性,但通常也帶來了很復雜的管理、狀態數據搬遷,甚至業務功能很難實現的問題,例如全局join,跨表事務等。

2.2 一致性Hash

一致性Hash方案會使得加機器代價更低一些,另外就是壓力可以更為均衡,例如分布式cache經常採用,和規則Sharding帶來的問題基本一樣。

2.3 Auto Sharding

Auto Sharding的好處是基本上不用管數據搬遷,而且隨著量上漲加機器就OK,但通常Auto Sharding的情況下對如何使用會有比較高的要求,而這個通常也就會造成一些限制,這種方案例如HBase。

2.4 Copy

Copy這種常見於讀遠多於寫的情況,實現起來又會有最終一致的方案和全局一致的方案,最終一致的多數可通過消息機制等,全局一致的例如zookeeper/etcd之類的,既要全局一致又要做到很高的寫支撐能力就很難實現了。

即使發展到今天,Sharding方式下的伸縮性問題仍然是很大的挑戰,非常不好做。

上面所寫的基本都還只是解決的方向,到細節點基本就很容易判斷是一個解決過多大規模場景問題的架構師,:)

穩定性

作為分布式系統,必須要考慮清楚整個系統中任何一個點掛掉應該怎麼處理(到了一定機器規模,每天掛掉一些機器很正常),同樣主要還是分成了無狀態和有狀態:

無狀態場景

對於無狀態場景,通常好辦,只用節點發現的機制上具備心跳等檢測機制就OK,經驗上來說無非就是純粹靠4層的檢測對業務不太夠,通常得做成7層的,當然,做成7層的就得處理好規模大了後的問題。

有狀態場景

對於有狀態場景,就比較麻煩了,對數據一致性要求不高的還OK,主備類型的方案基本也可以用,當然,主備方案要做的很好也非常不容易,有各種各樣的方案,對於主備方案又覺得不太爽的情況下,例如HBase這樣的,就意味著掛掉一台,另外一台接管的話是需要一定時間的,這個對可用性還是有一定影響的;

全局一致類型的場景中,如果一台掛了,就通常意味著得有選舉機制來決定其他機器哪台成為主,常見的例如基於paxos的實現。

可維護性

維護性是很容易被遺漏的部分,但對分布式系統來說其實是很重要的部分,例如整個系統環境應該怎麼搭建,部署,配套的維護工具、監控點、報警點、問題定位、問題處理策略等等。

『肆』 Java開源技術框架是指什麼啊請你撿重點詳細的說一下,謝謝!

目前主流的開源技術框架 是SSH 即 Spring struts2和hibernate
Spring Framework 【Java開源 J2EE框架】
Spring 是一個解決了許多在J2EE開發中常見的問題的強大框架。 Spring提供了管理業務對象的一致方法並且鼓勵了注入對介面編程而不是對類編程的良好習慣。Spring的架構基礎是基於使用JavaBean屬性的 Inversion of Control容器。然而,這僅僅是完整圖景中的一部分:Spring在使用IoC容器作為構建完關注所有架構層的完整解決方案方面是獨一無二的。 Spring提供了唯一的數據訪問抽象,包括簡單和有效率的JDBC框架,極大的改進了效率並且減少了可能的錯誤。Spring的數據訪問架構還集成了 Hibernate和其他O/R mapping解決方案。Spring還提供了唯一的事務管理抽象,它能夠在各種底層事務管理技術,例如JTA或者JDBC事務提供一個一致的編程模型。 Spring提供了一個用標准Java語言編寫的AOP框架,它給POJOs提供了聲明式的事務管理和其他企業事務--如果你需要--還能實現你自己的 aspects。這個框架足夠強大,使得應用程序能夠拋開EJB的復雜性,同時享受著和傳統EJB相關的關鍵服務。Spring還提供了可以和IoC容器集成的強大而靈活的MVC Web框架。【SpringIDE:Eclipse平台下一個輔助開發插件】.

Struts 【Java開源 Web框架】
Struts 是一個基於Sun J2EE平台的MVC框架,主要是採用Servlet和JSP技術來實現的。由於Struts能充分滿足應用開發的需求,簡單易用,敏捷迅速,在過去的一年中頗受關注。Struts把Servlet、JSP、自定義標簽和信息資源(message resources)整合到一個統一的框架中,開發人員利用其進行開發時不用再自己編碼實現全套MVC模式,極大的節省了時間,所以說Struts是一個非常不錯的應用框架。【StrutsIDE:用於Struts輔助開發的一個Eclipse插件】

Hibernate 【Java開源 持久層框架】
Hibernate 是一個開放源代碼的對象關系映射框架,它對JDBC進行了非常輕量級的對象封裝,使得Java程序員可以隨心所欲的使用對象編程思維來操縱資料庫。 Hibernate可以應用在任何使用JDBC的場合,既可以在Java的客戶端程序實用,也可以在Servlet/JSP的Web應用中使用,最具革命意義的是,Hibernate可以在應用EJB的J2EE架構中取代CMP,完成數據持久化的重任。Eclipse平台下的Hibernate輔助開發工具:【Hibernate Synchronizer】【MiddlegenIDE】

『伍』 Java目前主流框架都有哪些

1.Spring
這是其他Java框架中的絕對領導者。 掌握Spring是Java開發人員職位最普遍的要求之一。 造成這種情況的原因很多,但主要的原因是普遍性。
2.Play
Play是大多數開發人員喜歡的另一個輕量級框架。 它允許您使用Java和Scala構建Web應用程序。 它是為滿足現代移動和Web應用程序的需求而設計的。
3.Spark
Spark Framework是Java和Kotlin編程語言的一種微框架和特定於領域的語言。 Kotlin也可以在JVM上運行,並且可以與Java 100%互操作。 使用Spark,您可以輕松開發Web應用程序,微服務和REST API。
4. JHipster
Jhipster是最新的Java框架之一。 它於2013年發布。Jhipster將Spring Boot,Angular和React集成到一個大型框架中。 它使您可以輕松構建基於Java的現代Web應用程序。
5.Blade
Blade是一個輕量級的Java 8+ MVC框架。 當我們談論Blade的輕巧性時,是指其源代碼的大小,該大小不超過500KB。
6.Hibernate
在談論最佳的Java Web框架時,不能忽視Hibernate。
Hibernate是一個ORM(對象/關系映射)框架。 它允許您不使用SQL而是使用Java將查詢寫到資料庫伺服器,這通常會改變資料庫的常規外觀。
7. MyBatis
MyBatis是用於Java編程的映射框架。 它簡化了將Java應用程序與SQL資料庫鏈接的過程:它充當它們之間的中間件。
8.Struts
Struts是用於創建企業級Java Web應用程序的開源MVC(模型-視圖-控制器)框架。 最初的Struts框架(Struts 1.x)在2007年與WebWork框架合並時進行了重建。 Struts 1.x和Struts 2.x不可互換,因為它們之間存在重要區別。 您可以從Struts的Releases頁面下載。
9.Vaadin
Vaadin是一個開放源代碼客戶端伺服器框架,可讓您使用預先設計的UI組件創建Web應用程序。 它是專門針對業務應用程序而構建的,重點是可訪問,美觀且直觀的用戶界面。
10. JavaServer Faces(JSF)
JSF是一種JCP標准技術,用於在Java EE平台上創作基於組件的用戶界面。 該框架可能不是最好的框架,但是最大的好處是Oracle支持,許多其他工具,出色的文檔以及友好的社區。

『陸』 最新的javaee技術是什麼

JavaEE 是 J2EE的一個新的名稱,之所以改名,目的還是讓大家清楚J2EE只是Java企業應用.隨著WEB和EJB容器概念誕生,使得軟體應用業開始擔心SUN的夥伴們是否還在Java平台上不斷推出翻新的標准框架,致使軟體應用業的業務核心組件架構無所適從,從一直以來是否需要EJB的討論聲中說明了這種彷徨。
在2004年底中國軟體技術大會Ioc微容器(也就是Jdon框架的實現原理)演講中指出:我們需要一個跨J2SE/WEB/EJB的微容器,保護我們的業務核心組件(中間件),以延續它的生命力,而不是依賴J2SE/J2EE版本.此次J2EE改名為Java EE,實際也反映出業界這種共同心聲。
JavaEE的核心是EJB3.0, 其提供了更兼便捷的企業級的應用框架。
看來,現在大多數人傾向於更加突出Java了,J2EE容易讓初學者誤解是獨立於一套Java的技術方案。
從更深層次來看,Java誕生十年來,很多近十年前的業務組件至今還可以使用,軟體應用不再由於語言的更迭革命帶來毀滅的打擊了。
但是,隨著WEB和EJB容器概念誕生,使得軟體應用業開始擔心SUN的夥伴們是否還在Java平台上不斷推出翻新的標准框架,致使軟體應用業的業務核心組件架構無所適從,從一直以來是否需要EJB的討論聲中說明了這種彷徨。
筆者曾經在2004年底中國軟體技術大會Ioc微容器(也就是Jdon框架的實現原理)演講中指出:我們需要一個跨J2SE/WEB/EJB的微容器,保護我們的業務核心組件(中間件),以延續它的生命力,而不是依賴J2SE/J2EE版本
此次J2EE改名為Java EE,實際也反映出業界這種共同心聲。
讓我們看看Java EE 5有哪些新的功能或規定,我們可以從SUN網站下載Java EE 5規范。其架構圖如下:
JAVA EE 架構圖
圖中灰色加黑部分是Java EE 5新的功能,我們看到,在WEB層主要加入了JSF這個新的表現層框架,和我們日常開發關系密切的是,引入了新的Java Persistence標准,這個標准正在由EJB 3.0專家組制定。
值得指出的是,這個Java持久化標准也可以嵌入在WEB層調用,所以,它肯定不會從屬於EJB標准,這樣,當前所有的Java持久層標准如:JDBC/JDO/Hibernate/Entity Bean將可能統一,減少用戶的架構選擇 痛苦。
從架構圖可以看出,無論Web結構或EJB結構,提供實現的功能相差不多,這樣,我們的業務核心組件就可以根據需要部署在Web或EJB中運行,而不依賴具體的Java EE容器了。前面一章圖的目標在Java EE 5中可以實現了。
當然,Java EE 5重要改變還是:Java EE不再象以前那樣只注重大型商業系統的開發,而是更關注小到中型系統的開發,簡化這部分系統開發步驟。
落實這一簡化行動的最大特徵是在Java 5.0(Java 1.5)中加入Annotations,通過Annotations引入,降低Java EE開發時,既要寫code,又要寫XML配置文件之苦,來回照顧,疲於奔命,Annotations既是得益於C++語言,也是從開源項目xDoclet實踐中獲得經驗。
但是Annotations是一把雙刃劍,初學者用得不好,將會使得原本在XML中的Hard code(硬編碼) 寫進入代碼Annotations,破壞代碼的簡潔和靈活性,Annotations討論按這里。
當然,Annotations的引入不只是解決XML配置,從大的概念說,是解決一個資源注射問題(XML屬於其中一個資源),在原理J2EE中,容器管理的資源都是由JNDI向應用程序提供的,現在通過Annotations可以方便實現注射。
資源注射(Resource injection)設計概念其實是來自Ioc模式(Dependency Injection ),筆者設計開發的Jdon框架其實已經將Annotations這一宗旨的目的實現,在Jdon框架應用演示源碼SimpleJdonFrameworkTest中,在jdonframework.xml中有一段如下配置:
<pojoService class="com.jdon.framework.test..JdbcDAO" name="jdbcDAO">
<constructor value="java:/TestDS"/>
</pojoService>
這段配置是將資料庫的JNDI名java:/TestDS注射到JdbcDAO中。Jdon Framework下一個版本將是基於Java 5.0,這行配置 將可通過 Annotations寫在jdbcDAO代碼中,方便程序員開發。
從這里,大家也可以知道EJB 3.0和EJB 2.0的區別了,有的人疑惑,是學習EJB 3.0還是學習EJB 2.0,其實EJB 3.0並沒有在原理機制上對EJB有多大改動,只是做了編程方面的簡化,另外EJB CMP參考了Hibernate新特點,EJB 3.0最大簡化變動是CMP編程方法上。所以,無論學習EJb 3.0/2.0,EJB原理和運行機制都是一樣,這部分才是學習EJB最大的困難處,而不是因為到了EJB 3.0,理解EJB就會容易。
初學者可從Eclipse+Xdoclet開發EJB 2.0開始學習, EJB 3.0 = EJB 2.0 + xDoclet,這里有一篇Eclipse開發EJB教程,使用JBossIDE非常簡單,無需Lomboz等插件。
Security安全是Java EE的一個重要特點,也就是基於容器的安全訪問,無需自己手工編碼,具體實現可參考Jdon框架應用演示源碼JdonNews。這雖然是基於J2EE 1.3編寫,但是和Java EE 5區別不是很大。
事務管理Transaction Management也是Java EE 5的一個重要部分,該標准文檔從幾個方面闡述了事務管理的要點,標准中規定了在WEB層中使用事務和線程的處理關系,標准中規定:Web伺服器如Tomcat無需在Web層提供事務支持,因為Web組件根本不支持事務繁衍/傳遞。
因為目前一些架構如 Struts+Spring+Hibernate/Struts+Hibernate是標准中的Web結構,因此Java EE 5在J2EE 4.2.2規定了 Web組件事務的生命周期,如果Web組件直接調用JTA,事務就不可以跨一個客戶端的多個請求,事務只能在一個請求(Servlet/Jsp)中完成,這個標准規定了我們在Web架構中(如上述架構)無法使用長事務(如工作流/狀態圖中跨頁面請求事務),針對一個客戶端跨請求的事務目前只有唯一解決方案:只有使用EJB的有態Session。參考文章:I manage long ration transactions?
以上是Java EE 5主要部分,Java EE包含更多其他技術部分如Jdbc JMS JCA JNDI 等等,需要用戶在實踐中摸索。

『柒』 如何利用XMind繪制Java知識點框架圖

首先,雙擊打開XMind軟體,會看到各種不同的圖形模板,
選擇「思維導圖」,進入選擇風格,默認選擇「專業」,確定後點擊「新建」按鈕
這是,編輯窗口會出現一個橢圓形矩形,上面的內容是「中心主題
將上述的「中心主題」修改成「Java知識框架」,在矩形上方滑鼠右鍵,依次進行「插入---->主題」,這是會出現「分支主題1」
同理,再次在「中心主題」後插入一個「分支主題」,然後在第一個「分支主題」後再插入一個「子主題」,並修改顯示的內容
設計好了之後,可以將文件導出成圖片,也可以直接保存成xmind文件。下面將講述文件導出成圖片的操作,找到「文件」,點擊「導出」,選擇「圖片」
進入「下一步」,選擇圖片格式和導出圖片路徑,點擊「完成」
這是,會彈出成功導出的提示窗口,點擊「關閉」按鈕
到指定的路徑查看導出的圖片
也可以將文件導出成xmind文件

『捌』 Java的技術架構有哪些

服務分離

隨著系統的的上線,用戶量也會逐步上升,很明顯一台伺服器已經滿足不了系統的負載,這時候,我們就要在伺服器還沒有超載的時候,提前做好准備。

由於我們是單體架構,優化架構在短時間內是不現實的,增加機器是一個不錯的選擇。這時候,我們可能要把應用和資料庫服務單獨部署,如果有條件也可以把文件伺服器單獨部署。

反向代理

為了提升服務處理能力,我們在Tomcat容器前加一個代理伺服器,我一般使用Nginx,當然你如果更熟悉apache也未嘗不可。

用戶的請求發送給反向代理,然後反向代理把請求轉發到後端的伺服器。

嚴格意義上來說,Nginx是屬於web伺服器,一般處理靜態html、css、js請求,而Tomcat屬於web容器,專門處理JSP請求,當然Tomcat也是支持html的,只是效果沒Nginx好而已。

反向代理的優勢,如下:

  • 隱藏真實後端服務

  • 負載均衡集群

  • 高可用集群

  • 緩存靜態內容實現動靜分離

  • 安全限流

  • 靜態文件壓縮

  • 解決多個服務跨域問題

  • 合並靜態請求(HTTP/2.0後已經被弱化)

  • 防火牆

  • SSL以及http2

  • 動靜分離

    基於以上Nginx反向代理,我們還可以實現動靜分離,靜態請求如html、css、js等請求交給Nginx處理,動態請求分發給後端Tomcat處理。

    Nginx 升級到1.9.5+可以開啟HTTP/2.0時代,加速網站訪問。

    當然,如果公司不差錢,CDN也是一個不錯的選擇。

    服務拆分

    在這分布式微服務已經普遍流行的年代,其實我們沒必要踩過多的坑,就很容易進行拆分。市面上已經有相對比較成熟的技術,比如阿里開源的Dubbo(官方明確表示已經開始維護了),spring家族的spring cloud,當然具體如何去實施,無論是技術還是業務方面都要有很好的把控。

    Dubbo

    SpringCloud

  • 服務發現——Netflix Eureka

  • 客服端負載均衡——Netflix Ribbon

  • 斷路器——Netflix Hystrix

  • 服務網關——Netflix Zuul

  • 分布式配置——Spring Cloud Config

  • 微服務與輕量級通信

  • 同步通信和非同步通信

  • 遠程調用RPC

  • REST

  • 消息隊列

  • 持續集成部署

    服務拆分以後,隨著而來的就是持續集成部署,你可能會用到以下工具。

    Docker、Jenkins、Git、Maven

    圖片源於網路,基本拓撲結構如下所示:

    整個持續集成平台架構演進到如下圖所示:

    服務集群

    Linux集群主要分成三大類( 高可用集群, 負載均衡集群,科學計算集群)。其實,我們最常見的也是生產中最常接觸到的就是負載均衡集群。

    負載均衡實現

  • DNS負載均衡,一般域名注冊商的dns伺服器不支持,但博主用的阿里雲解析已經支持

  • 四層負載均衡(F5、LVS),工作在TCP協議下

  • 七層負載均衡(Nginx、haproxy),工作在Http協議下

  • 分布式session

    大家都知道,服務一般分為有狀態和無狀態,而分布式sessoion就是針對有狀態的服務。

    分布式Session的幾種實現方式

  • 基於資料庫的Session共享

  • 基於resin/tomcat web容器本身的session復制機制

  • 基於oscache/Redis/memcached 進行 session 共享。

  • 基於cookie 進行session共享

  • 分布式Session的幾種管理方式

  • Session Replication 方式管理 (即session復制)
    簡介:將一台機器上的Session數據廣播復制到集群中其餘機器上
    使用場景:機器較少,網路流量較小
    優點:實現簡單、配置較少、當網路中有機器Down掉時不影響用戶訪問
    缺點:廣播式復制到其餘機器有一定廷時,帶來一定網路開銷

  • Session Sticky 方式管理
    簡介:即粘性Session、當用戶訪問集群中某台機器後,強制指定後續所有請求均落到此機器上
    使用場景:機器數適中、對穩定性要求不是非常苛刻
    優點:實現簡單、配置方便、沒有額外網路開銷
    缺點:網路中有機器Down掉時、用戶Session會丟失、容易造成單點故障

  • 緩存集中式管理
    簡介:將Session存入分布式緩存集群中的某台機器上,當用戶訪問不同節點時先從緩存中拿Session信息
    使用場景:集群中機器數多、網路環境復雜
    優點:可靠性好
    缺點:實現復雜、穩定性依賴於緩存的穩定性、Session信息放入緩存時要有合理的策略寫入

『玖』 java 架構設計圖用什麼軟體

架構圖用office家族的visio最牛逼,各種圖都可以畫出來。

用VISIO畫的分層架構設計圖

熱點內容
少兒編程排行 發布:2025-01-24 04:40:46 瀏覽:698
搭建伺服器怎麼使用 發布:2025-01-24 04:19:34 瀏覽:443
平行進口霸道哪些配置有用 發布:2025-01-24 04:19:32 瀏覽:873
ngram演算法 發布:2025-01-24 04:03:16 瀏覽:658
迷宮游戲c語言 發布:2025-01-24 03:59:09 瀏覽:358
榮耀30pro存儲類型 發布:2025-01-24 03:54:02 瀏覽:556
客戶端文件上傳 發布:2025-01-24 03:48:44 瀏覽:257
推特更改密碼的用戶名是什麼 發布:2025-01-24 03:45:55 瀏覽:596
cc編譯選項 發布:2025-01-24 03:45:18 瀏覽:512
銀行密碼怎麼被鎖 發布:2025-01-24 03:37:02 瀏覽:431