Tomcat服務器集群與負載均衡實現

一、前言

在單一的服務器上執行WEB應用程序有一些重大的問題,當網站成功建成并開始接受大量請求時,單一服務器終究無法滿足需要處理的負荷量,所以就有點顯得有點力不從心了。另外一個常見的問題是會產生單點故障,如果該服務器壞掉,那么網站就立刻無法運作了。不論是因為要有較佳的擴充性還是容錯能力,我們都會想在一臺以上的服務器計算機上執行WEB應用程序。所以,這時候我們就需要用到集群這一門技術了。

在進入集群系統架構探討之前,先定義一些專門術語:

1. 集群(Cluster):是一組獨立的計算機系統構成一個松耦合的多處理器系統,它們之間通過網絡實現進程間的通信。應用程序可以通過網絡共享內存進行消息傳送,實現分布式計算機。

2. 負載均衡(Load Balance):先得從集群講起,集群就是一組連在一起的計算機,從外部看它是一個系統,各節點可以是不同的操作系統或不同硬件構成的計算機。如一個提供Web服務的集群,對外界來看是一個大Web服務器。不過集群的節點也可以單獨提供服務。

3. 特點:在現有網絡結構之上,負載均衡提供了一種廉價有效的方法擴展服務器帶寬和增加吞吐量,加強網絡數據處理能力,提高網絡的靈活性和可用性。集群系統(Cluster)主要解決下面幾個問題:
高可靠性(HA):利用集群管理軟件,當主服務器故障時,備份服務器能夠自動接管主服務器的工作,并及時切換過去,以實現對用戶的不間斷服務。
高性能計算(HP):即充分利用集群中的每一臺計算機的資源,實現復雜運算的并行處理,通常用于科學計算領域,比如基因分析,化學分析等。
負載平衡:即把負載壓力根據某種算法合理分配到集群中的每一臺計算機上,以減輕主服務器的壓力,降低對主服務器的硬件和軟件要求。

總體來說,在負載均衡的思路下,多臺服務器為對等方式,每臺服務器都具有同等的地位,可以單獨對外提供服務而無須其他服務器的輔助。通過負載分擔技術,將外部發送來的請求按一定規則分配到對稱結構中的某一臺服務器上,而接收到請求的服務器都獨立回應客戶機的請求。

提供服務的一組服務器組成了一個應用服務器集群(cluster),集群下的對等多機環境可以增加系統的并發處理能力,和單臺機器出現故障系統的錯誤冗余能力;同時實現了負載均衡和系統高可靠性。

二、常用負載均衡技術

1. 基于DNS的負載均衡

通過DNS服務中的隨機名字解析來實現負載均衡,在DNS服務器中,可以為多個不同的地址配置同一個名字,而最終查詢這個名字的客戶機將在解析這個名字時得到其中一個地址。因此,對于同一個名字,不同的客戶機會得到不同的地址,他們也就訪問不同地址上的Web服務器,從而達到負載均衡的目的。

2. 反向代理負載均衡 (如Apache+JK2+Tomcat這種組合)

使用代理服務器可以將請求轉發給內部的Web服務器,讓代理服務器將請求均勻地轉發給多臺內部Web服務器之一上,從而達到負載均衡的目的。這種代理方式與普通的代理方式有所不同,標準代理方式是客戶使用代理訪問多個外部Web服務器,而這種代理方式是多個客戶使用它訪問內部Web服務器,因此也被稱為反向代理模式。

3. 基于NAT(Network Address Translation)的負載均衡技術 (如Linux Virtual Server,簡稱LVS)

網絡地址轉換為在內部地址和外部地址之間進行轉換,以便具備內部地址的計算機能訪問外部網絡,而當外部網絡中的計算機訪問地址轉換網關擁有的某一外部地址時,地址轉換網關能將其轉發到一個映射的內部地址上。因此如果地址轉換網關能將每個連接均勻轉換為不同的內部服務器地址,此后外部網絡中的計算機就各自與自己轉換得到的地址上服務器進行通信,從而達到負載分擔的目的。

三、Apache+JK2實現Tomcat集群與負載均衡

客戶系統一般采用Apache httpd作為web服務器,即作為Tomcat的前端處理器,根據具體情況而定,有些情況下是不需要Apache httpd作為 web 服務器的,如系統展現沒有靜態頁面那就不需要Apache httpd,那時可以直接使用Tomcat作為web 服務器來使用。使用Apache httpd主要是它在處理靜態頁面方面的能力比Tomcat強多了。

1. 集群實現原理

image

如上圖所示,主要通過 Apache-Server 作為中轉服務器,實現多個 tomcat 服務器之間的分布式處理,用戶直接請求 Apache-Server ,然后 Apache-Server 會將請求分發到具體的 tomcat-server ,之后 tomcat-server 響應客戶請求并返回結果到 Apache-Server ,最后 Apache-Server 返回結果給用戶。

2. 配置負載均衡器

文件說明:

(a) mod_jk.conf,主要定義 mod_jk 模塊的位置以及 mod_jk 模塊的連接日志設置,還有定義 worker.properties 文件的位置。

(b) worker.properties,定義 worker 的參數,主要是連接 tomcat 主機的地址和端口信息。如果 Tomcat 與 apache 不在同一臺機器上,或者需要做多臺機器上 tomcat 的負載均衡只需要更改 workers.properties 文件中的相應定義即可。% APACHE_HOME %為你的安裝目錄。

環境說明:主要使用了一個 Apache Server 和兩個 Tomcat ,在同一臺電腦上進行測試。

(a)準備軟件

Jdk1.6 下載地址:http://java.sun.com

tomcat -6.0.29 下載地址:http://jakarta.apache.org

apache_2.2.4-win32-x86-no_ssl.msi 下載地址:http://httpd.apache.org/download.cgi

mod_jk-1.2.31-httpd-2.0.52.so ( 主要作用是建立 Apache Server 與 Tomcat 之間的連接 )下載地址:http://www.apache.org/dist/tomcat/tomcat-connectors/jk/binaries/

說明: apache-server 安裝完成后,可以在瀏覽器中輸入http://localhost/來測試,如果出現 ” It works!”則表示安裝成功。

(b)安裝 mod_jk 連接模塊

安裝好 Jdk 、 tomcat 、 apache 后 , 加入 mod_jk 連接模塊,就是把 mod_jk- 1.2.31 -httpd-2.2.3.so 文件拷貝到% APACHE_HOME % \modules 下,把 jk 模塊的配置放到單獨的文件中來,在% APACHE_HOME % \conf 目錄新建 mod_jk.conf 、 workers.properties 文件。

在 httpd.conf 最后加上:

# JK module settings

Include conf/mod_jk.conf

說明:以上表示將 mod_jk.conf 配置文件包含進來

(c)修改 mod_jk.conf 文件

為了保持 httpd.conf 文件的簡潔,把 jk 模塊的配置放到單獨的文件中來。在 mod_jk.conf 文件中添加以下內容:

# Load mod_jk2 module

LoadModule jk_module modules/mod_jk-1.2.31-httpd-2.2.3.so

# Where to find workers.properties( 引用 workers 配置文件 )

JkWorkersFile conf/workers.properties

# Where to put jk logs(log 文件路徑 )

JkLogFile logs/mod_jk2.log

# Set the jk log level [debug/error/info](log 級別 )

JkLogLevel info

# Select the log format(log 格式 )

JkLogStampFormat "[%a %b %d %H:%M:%S %Y] "

# JkOptions indicate to send SSL KEY SIZE,

JkOptions +ForwardKeySize +ForwardURICompat -ForwardDirectories

# JkRequestLogFormat set the request format

JkRequestLogFormat "%w %V %T"

# Send JSPs for context / to worker named loadBalancer(URL 轉發配置,匹配的 URL 才轉發到 tomcat 進行處理 )

JkMount /*.jsp controller

# JkMount /*.* loadBalancer

(d)修改 workers.properties 文件

在 workers.properties 文件中添加以下內容:

#server 列表

worker.list = controller,tomcat1,tomcat2

# tomcat1(ajp13 端口號,在tomcat下server.xml配置,默認8009)

worker.tomcat1.port=8009

#tomcat 的主機地址,如不為本機,請填寫ip地址

worker.tomcat1.host=localhost

worker.tomcat1.type=ajp13

#server 的加權比重,值越高,分得的請求越多

worker.tomcat1.lbfactor = 1

# tomcat2

worker.tomcat2.port=9009

worker.tomcat2.host=localhost

worker.tomcat2.type=ajp13

worker.tomcat2.lbfactor = 1

# controller( 負載均衡控制器)

worker.controller.type=lb

# 指定分擔請求的tomcat

worker.controller.balanced_workers=tomcat1,tomcat2

#worker.controller.sticky_session=true

說明:此文件配置了 2 個 tomcat 服務器進行負載均衡處理

(e)修改 tomcat 配置文件 server.xml

更改其中一個的設置打開 tomcat2/conf/server.xml 文件,修改里面所有的端口設置,將 8 改為 9 ,如下:

(f)編寫一個測試頁面 teat1.jsp

建立一個 test 的 web 應用,里面新建一個 test1.jsp, 內容為:

image

(g)啟動服務器并進行測試

依次啟動 apache-server 、 tomcat1 、 tomcat2 ,通過http://localhost/test/test1.jsp訪問,查看 tomcat1 的窗口,可以看到打印了一行 "==========" ,再刷新一次, tomcat2 也打印了一條,再刷新,可以看到請求會被 tomcat1,tomcat2 輪流處理 , 實現了負載均衡

3.集群(session復制 )

只配置負載均衡還不行,還要 session 復制,也就是說其中任何一個 tomcat 的添加的 session ,是要同步復制到其它 tomcat , 集群內的 tomcat 都有相同的 session:

(a)Tomcat配置

修改 tomcat1, tomcat2 的 server.xml 文件添加集群內容, tomcat5.5 無需添加,只需要去掉注釋符, tomcat6.0 需要添加,內容如下:

<Cluster className="org.apache.catalina.cluster.tcp.SimpleTcpCluster"

managerClassName="org.apache.catalina.cluster.session.DeltaManager"

expireSessionsOnShutdown="false"

useDirtyFlag="true"

notifyListenersOnReplication="true">

<Membership

className="org.apache.catalina.cluster.mcast.McastService"

mcastAddr="228.0.0.4"

mcastPort="45564"

mcastFrequency="500"

mcastDropTime="3000"/>

<Receiver

className="org.apache.catalina.cluster.tcp.ReplicationListener"

tcpListenAddress="auto"

tcpListenPort="4001"

tcpSelectorTimeout="100"

tcpThreadCount="6"/>

<Sender

className="org.apache.catalina.cluster.tcp.ReplicationTransmitter"

replicationMode="pooled"

ackTimeout="15000"

waitForAck="true"/>

<Valve className="org.apache.catalina.cluster.tcp.ReplicationValve"

filter=".*\.gif;.*\.js;.*\.jpg;.*\.png;.*\.htm;.*\.html;.*\.css;.*\.txt;"/>

<Deployer className="org.apache.catalina.cluster.deploy.FarmWarDeployer"

tempDir="/tmp/war-temp/"

deployDir="/tmp/war-deploy/"

watchDir="/tmp/war-listen/"

watchEnabled="false"/>

<ClusterListener className="org.apache.catalina.cluster.session.ClusterSessionListener"/>

</Cluster>

分別添加以上內容后,在 tomcat2 中,修改 tcpListenPort="4001" 為 4002。

Engine 增加 jvmRoute 屬性設置, jvmRoute 的值來自于 workers.properties 文件所設置的服務器名稱。

<Engine name="Catalina" defaultHost="localhost"jvmRoute="tomcat1">

#server 列表

worker.list = controller,tomcat1,tomcat2

(b) 添加 test.jsp 頁面

imageimage

修改 web.xml 文件,加入 <distributable/>節點,如下所示:

image

(c)Session復制測試

測試步驟如下:

1) 啟動 apache-server 、 tomcat1 、 tomcat2

2) 訪問http://localhost/test/test.jsp,輸入名稱: test0001 、值: 123 并點擊“提交查詢內容”按鈕,顯示效果如下:

如上圖所示, tomcat1 創建了一個新的 session , session 中有屬性 test0001, 值為 123

3) 關閉 tomcat1 服務器, tomcat1 端口為 8080 ,如下圖:

4) 在頁面中再次點擊“提交查詢內容”按鈕,效果如下:

前端頁面并沒有發生改變,接下來查看后臺情況:

如圖所示,可以發現 session 已成功復制到 tomcat2 中,以此證明 tomcat 集群已配置成功。

5) 另外來看看不關閉 tomcat1 服務器再次提交的情況

如圖所示,請求并沒有轉發到 tomcat2 服務器,而是再次轉回 tomcat1 服務器,這種情況是由于配置了 jvmRoute 所致,以個人理解,配置了此屬性后, apache-server 會根據 session 情況來進行路由,同一個 session 會轉發給同一個服務器。

6) 打開一個新的 IE 窗口,并訪問http://localhost/test/test.jsp



新窗口的請求轉發到了 tomcat2 服務器, session 的 id 為 DD9E6C8181653B9BCCF534FC8760B264.tomcat2 ,根據測試結果可以說明,在不發生服務器關閉的情況下,每個 session 會綁定到同一個服務器中,而不會在服務器間發生復制。

四、總結

介紹完上面的集群技術之后,下面就基于Tomcat的集群架構方案進行說明:

1. 用戶的網頁瀏覽器做完本地 DNS和企業授權的DNS之的請求/響應后,這時候企業授權的DNS(即21cn BOSS DNS)會給用戶本地的DNS服務器提供一個NAT請求分配器(即網關)IP。
2. NAT分配器,它會根據特定的分配算法,來決定要將連接交給哪一臺內部 Apache httpd來處理請求。大多數的NAT請求分配器提供了容錯能力:根據偵測各種WEB服務器的失效狀況,停止將請求分配給已經宕掉的服務器。并且有些分配器還可以監測到WEB服務器機器的負載情況,并將請求分配給負載最輕的服務器等等。Linux Virtual Server是一個基于Linux操作系統上執行的VS-NAT開源軟件套件,而且它有豐富的功能和良好的說明文件。商業硬件解決方案 Foundry Networks的ServerIron是目前業界公認最佳的請求分配器之一。
3. Apache httpd + Mod_JK2在這里是作為負載均衡器,那為什么要做集群呢?如果集群系統要具備容錯能力,以便在任何單一的硬件或軟件組件失效時還能100%可用,那么集群系統必須沒有單點故障之憂。所以,不能只架設一臺有mod_jk2的Apache httpd,因為如果 httpd或mod_jk2失效了,將不會再有請求被會送交到任何一個Tomcat 實例。這種情況下,Apache httpd就是瓶勁,特別在訪問量大的網站。
4. Mod_JK2負載均衡與故障復原,決定把Apache httpd當成web服務器,而且使用mod_jk2將請求傳送給Tomcat,則可以使用mod_jk2的負載均衡與容錯功能。在集群系統中,帶有mod_jk2的Apache httpd可以做的事情包括:

A 將請求分配至一或多個Tomcat實例上你可以在mod_jk2的workers.properties文件中,設定許多Tomcat實例,并賦于每個實例一個lb_factor值,以作為請求分配的加權因子。
B. 偵測Tomcat實例是否失敗當Tomcat實例的連接器服務不再響應時,mod_jk2會及時偵測到,并停止將請求送給它。其他的Tomcat實例則會接受失效實例的負載。
C. 偵測Tomcat實例在失效后的何時恢復因連接器服務失效,而停止將請求分配給Tomcat實例之后,mod_jk2會周期性地檢查是否已恢復使用性,并自動將其加入現行的Tomcat實例池中。

5. Tomcat中的集群原理是通過組播的方式進行節點的查找并使用TCP連接進行會話的復制。這里提示一下就是,對每個請求的處理,Tomcat都會進行會話復制,復制后的會話將會慢慢變得龐大。
6. Mod_jk2同時支持會話親和和會話復制。在tomcat 5中如何實現會話親和和會話復制?把server.xml中的標簽去掉就實現會話親和,把標簽加上就實現會話復制。
7. 會話親和:就是表示來自同會話的所有請求都由相同的Tomcat 實例來處理,這種情況下,如果Tomcat實例或所執行的服務器機器失效,也會喪失Servlet的會話數據。即使在集群系統中執行更多的Tomcat實例,也永遠不會復制會話數據。這樣是提高集群性能的一種方案,但不具備有容錯能力了。
8. 使用會話復制,則當一個Tomcat實例宕掉時,由于至少還有另一個Tomcat實例保有一份會話狀態數據,因而數據不會喪失。但性能會有所降低。

其實無論是分布式,數據緩存,還是負載均衡,無非就是改善網站的性能瓶頸,在網站源碼不做優化的情況下,負載均衡可以說是最直接的手段了。其實拋開這個名詞,放開了說,就是希望用戶能夠分流,也就是說把所有用戶的訪問壓力分散到多臺服務器上,也可以分散到多個tomcat里,如果一臺服務器裝多個tomcat,那么即使是負載均衡,性能也提高不了太多,不過可以提高穩定性,即容錯性。當其中一個主tomcat當掉,其他的tomcat也可以補上,因為tomcat之間實現了Session共享。待tomcat服務器修復后再次啟動,就會自動拷貝所有session數據,然后加入集群。這樣就可以不間斷的提供服務。如果要真正從本質上提升性能,必須要分布到多臺服務器。

其實多臺服務器各配置一個tomcat也可以實現負載均衡,而且那樣的話,可以使用安裝版的tomcat,而不用是下文中的免安裝的tomcat,而且tomcat端口配置也就不用修改了。


本文轉自:http://my.oschina.net/xianggao/blog/87469


本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:
http://www.pswp.cn/news/443722.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/443722.shtml
英文地址,請注明出處:http://en.pswp.cn/news/443722.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Linux服務器 | 事件處理模式:Reactor模式、Proactor模式

文章目錄Reactor模式Proactor模式同步I/O模型模擬Proactor模式兩者的優缺點ReactorProactor同步I/O模型通常用于實現 Reactor 模式&#xff0c;異步I/O模型通常用于實現 Proactor 模式。&#xff08;不是絕對的&#xff0c;同步I/O也可模擬出 Proactor 模式&#xff09; React…

Linux服務器 | 服務器模型與三個模塊、兩種并發模式:半同步/半異步、領導者/追隨者

文章目錄兩種服務器模型及三個模塊C/S模型P2P模型I/O處理單元、邏輯單元、存儲單元并發同步與異步半同步/半異步模式變體&#xff1a;半同步/半反應堆模式改進&#xff1a;高效的半同步/半異步模式領導者/追隨者模式組件 &#xff1a;句柄集、線程集、事件處理器工作流程兩種服…

香農信息熵之可憐的小豬

文章目錄題目解析香農熵公式樣例具體分析代碼題目 有 n 桶液體&#xff0c;其其中 正好 有一桶含有毒藥&#xff0c;其裝的都是水。它們從外觀看起來都一樣。為了弄清楚哪只水桶含有毒藥&#xff0c;你可以喂一些豬喝&#xff0c;通過觀察豬是否會死進行判斷&#xff0c;實驗對…

字符串匹配之KMP(KnuthMorrisPratt)算法(圖解)

文章目錄最長相等前后綴next數組概念代碼實現圖解GetNext中的回溯改進代碼實現代碼復雜度分析最長相等前后綴 給出一個字符串 ababa 前綴集合&#xff1a;{a, ab, aba, abab} 后綴集合&#xff1a;{a, ba, aba, baba} 相等前后綴 即上面用同樣顏色標識出來的集合元素&#…

linux下tomcat6.0與jdk安裝詳細步驟

安裝Tomcat6.0和JDK1.6 在linux系統上安裝tomcat和jdk應該說是我學習linux知識的第一課了&#xff0c;之前只 是聽說過&#xff0c;從沒接觸過&#xff0c;但我們公司項目都是部署在linux系統上的&#xff0c;那天上司突 然給我發了幾個文檔&#xff0c;讓我看一下&#xff…

Android入門(一) | Android Studio的配置與使用

文章目錄安裝配置Android Studio使用Android Studio模擬器更改Android SDK的路徑Hello World&#xff01;安裝配置Android Studio 從這一步開始&#xff1a; 一直點 next 即可&#xff0c;直到存儲路徑的選擇上&#xff0c;可以放到非 C 盤&#xff0c;這里我放到 D 盤了&am…

Android 入門(四) | Intent 實現 Activity 切換

文章目錄Intent顯式 Intent定義兩個 xml 文件android:orientationmatch_parent 和 wrap_contentIntent函數定義兩個 Activity隱式 Intent更多隱式 Intent 的用法用隱式 Intent 打開系統瀏覽器自建 Activity 以響應打開網頁的 Intent向下一個活動傳遞數據返回數據給上一個活動In…

Android入門(二) | 項目目錄及主要文件作用分析

文章目錄項目目錄分析app目錄分析AndroidManifest.xml 分析MainActivity.kt 分析build.gradle 分析最外層目錄下的 build.gradleapp 目錄下的 build.gradle項目目錄分析 我們來看一下 src/main/res 下的一些文件&#xff1a; .gradle 和 .idea &#xff1a;這兩個目錄下放置…

Android入門(三) | Android 的日志工具 Logcat

文章目錄日志工具類 android.util.LogLogcat 中的過濾器日志工具類 android.util.Log Log 從屬日志工具類 android.util.Log &#xff0c;該類提供了五個方法供我們打印日志&#xff1a; Log.v() &#xff1a;用于打印那些最為瑣碎的、意義最小的日志信息。對應級別 verbose&…

Android 客戶端與服務器交互方式

突然想到一個問題就是Android客戶端與服務器交互有幾種方式&#xff0c;因為在腦袋里想當然的就是webservices和json。要在Android手機客戶端與pc服務器交互&#xff0c;需要滿足下面幾種條件&#xff1a;跨平臺、傳輸數據格式標準、交互方便...。 為了與服務器通訊其實無非就…

Android入門(五) | Activity 的生命周期

文章目錄Activity 的狀態及生命周期實現管理生命周期FirstActivitySecondActivityDialogActivity運行結果舊活動被回收了還能返回嗎&#xff1f;Activity 的狀態及生命周期 Android 的應用程序運用 棧&#xff08;Back Stack&#xff09; 的思想來管理 Activity&#xff1a; …

Android入門(六) | Activity 的啟動模式 及 生產環境中關于 Activity 的小技巧

文章目錄Activity 的啟動模式standardsingleTopsingleTasksingleInstance技巧了解當前界面是哪個 Activity隨時隨地退出程序啟動活動的最佳寫法Activity 的啟動模式 standard&#xff1a;默認的啟動方式&#xff0c;每次啟動一個活動都會重新創建singleTop&#xff1a;如果該活…

Android入門(七) | 常用控件

文章目錄TextView 控件&#xff1a;文本信息Button 控件&#xff1a;按鈕EditText 控件&#xff1a;輸入框ImageView 控件&#xff1a;圖片ProgressBar 控件&#xff1a;進度條AlertDialog 控件&#xff1a;提示框ProgressDialog 控件&#xff1a;帶有進度條的提示框TextView 控…

Android入門(八) | 常用的界面布局 及 自定義控件

文章目錄LinearLayout &#xff1a;線性布局android:layout_gravity &#xff1a;控件的對齊方式android:layout_weight&#xff1a;權重RelativeLayout &#xff1a;相對布局相對于父布局進行定位相對于控件進行定位邊緣對齊FrameLayout &#xff1a;幀布局Percent &#xff1…

Android入門(九)| 滾動控件 ListView 與 RecyclerView

文章目錄ListView內置類型的簡單運用定制數據類型提升效率點擊事件RecyclerView布局管理器點擊事件ListView 內置類型的簡單運用 由于手機屏幕空間有限&#xff0c;能夠一次性在屏幕上顯示的內容不多&#xff0c;當我們的程序有大量數據需要顯示的時候就可以借助 ListView 來…

關于“三門問題”的一些想法

三門問題&#xff08;Monty Hall problem&#xff09;亦稱為蒙提霍爾問題、蒙特霍問題或蒙提霍爾悖論&#xff0c;大致出自美國的電視游戲節目Let’s Make a Deal。問題名字來自該節目的主持人蒙提霍爾&#xff08;Monty Hall&#xff09;。參賽者會看見三扇關閉了的門&#xf…

Android入門(10)| Fragment碎片詳解

文章目錄為什么要使用碎片&#xff08;Fragment&#xff09;實例布局文件FragmentActivity動態添加碎片布局文件FragmentActivity碎片通信Fragment布局文件Activity生命周期為什么要使用碎片&#xff08;Fragment&#xff09; 我們在手機上看新聞可能是這樣的&#xff1a; Re…

Android開發(1) | Fragment 的應用——新聞應用

文章目錄Item&#xff1a;標題子項布局文件Java代碼標題碎片布局文件Java代碼新聞內容碎片布局文件Java代碼新聞內容活動布局文件Java代碼首界面布局文件Java代碼Item&#xff1a;標題子項 布局文件 news_item.xml&#xff1a; <TextViewxmlns:android"http://schema…

Java Web整體異常處理

在實際的J2EE項目中&#xff0c;系統內部難免會出現一些異常&#xff0c;就如StrutsSpringHibernate項目&#xff1a;通常一個頁面請求到達后臺以后&#xff0c;首先是到action&#xff08;就是MVC中的controller&#xff09;&#xff0c;在action層會調用業務邏輯層service&am…

Android入門(11)| 全局廣播與本地廣播

文章目錄廣播概念接收廣播動態注冊實例靜態注冊實例發送廣播發送標準廣播廣播的跨進程特性發送有序廣播本地廣播廣播概念 Android 中的每個應用程序都可以對自己感興趣的廣播進行注冊&#xff0c;這樣該程序就只會接收到自己所關心的廣播內容&#xff0c;這些廣播可能是來自系…