Ⅰ 如何提高高性能伺服器並發量
消除瓶頸是提高伺服器性能和並發能力的唯一途徑。 如果你能夠消除所有的瓶頸,你就能夠最大的發揮硬體性能,讓系統的性能和並發數到達最佳。 採用多線程多核編程,使用事件驅動或非同步消息機制,盡量減少阻塞和等待操作(如I/O阻塞、同步等待或計時/超時等)。 原理: 1、多線程多核編程,消除cpu瓶頸。 2、採用IOCP或epoll,利用狀態監測和通知方式,消除網路I/O阻塞瓶頸。 3、採用事件驅動或非同步消息機制,可以消除不必要的等待操作。 4、如果是linux,可以採用AIO來消除磁碟I/O阻塞瓶頸。 5、在事件驅動框架或非同步消息中統一處理timer事件,變同步為非同步,而且可以在一個線程處理無數timer事件。 6、深入分析外部的阻塞來源,消除它。 比如資料庫查詢較慢,導致伺服器處理較慢,並發數上不去,這時就要優化資料庫性能。 7、如果與某個其他server通信量很大,導致性能下降較多。 可以考慮把這兩個server放在一個主機上,採用共享內存的方式來做IPC通信,可以大大提高性能。
Ⅱ 如何提高伺服器的性能
1、伺服器系統架構的不合理。
伺服器在設計時,必須考慮整個系統架構的高效、穩定,高的可靠性和可用性。這點我深有體會,在最近的一個項目中,由於伺服器需要接受大批量小數據的多客戶端並發請求,對伺服器的業務處理提出了挑戰。原先的設計採用的了串列業務處理流程,結果導致伺服器大量業務堆積,造成丟包現象異常嚴重。經過討論後,為了提高伺服器的業務處理能力,採用了生產者——消費者模型,在業務上來時,直接進隊,然後返回,繼續接受下一個請求,縮短通信的滯留時間。然後多條業務線程從隊列取業務,加快業務處理速度,這樣就有效的提高了伺服器處理業務的能力。
2、通信協議的不合理。
對於大批量小數據多客戶端並發,可以考慮用UDP協議,由於UDP是一種無連接傳輸協議,可以有效的降低系統開銷,特別對大批量小數據的請求,效果明顯,而TCP在這種情況對系統的消耗是很大的,往往會導致連接被拒絕,或者socket句柄已經存在的錯誤。有人可能就會問了,在服務端可以採用短連接,這樣就可以節約資源。其實不然,大量socket的創建與銷毀本來就是一種對系統性能的極度消耗,有時這種還沒有直接使用長連接來的效率高。
在目前的P3項目就有體現,原本我們採用的就是TCP連接,當時並發量一直提不上去,而且在大量並發下,系統出現Socket的錯誤,資源消耗及其大,所以之後採用UDP協議,而TCP作為備用方案,來防止UDP的不可靠性。
3、大批量的內存創建、銷毀,以及一切有關內存的操作都會影響到系統性能
這點對小量的並發,體現的並不明顯,但是在大量並發下,這就會性能造成嚴重影響,這種內存的創建,銷毀,以及內存的COPY等會消耗掉系統50%~60%的性能。對這種情況,盡量在系統啟動時,創建好內存資源,然後再業務處理完後,回收資源,重新利用,切忌在大量業務處理時,new新的內存,處理完後,又delete內存資源,這樣對系統性能消耗及其大。
另外,對於自定的協議包處理,盡量少用涉及到內存操作的函數或者類型,比如memset,string等,這樣在打包與解包時,都會對系統性能造成影響。
Ⅲ 怎樣提高ASP伺服器的性能
1、增加帶寬;
2、優化網頁;
如果資金充許
3、增加內存
4、換更好的路由、交換機等網路設備(以上都是解決瓶頸問題)
5、更換高性能的伺服器(解決瓶子問題)。
Ⅳ 如何提高Domino郵件伺服器的性能
通過性能檢測和分析,可以知道伺服器的運行狀況,即在當前的工作負載下伺服器是否出色運行。正如網路中的瓶頸一樣,它可以幫助您找到伺服器配置中的限制因素。
通過下面十個步驟,您可以最大限度地提高Domino伺服器 的性能:
(一)了解您的配置
Domino管理員應該知道所支持的伺服器的配置。任何一個伺服器的主要元件有內存、CPU、磁碟(包括邏輯的和物理的),其它元件諸如在線緩沖內存以及磁碟控制器的數量等,也是比較重要的。
下面是一些附加的注意事項,可以使您避免發生配置相關的問題:
1)使用盡可能快的磁碟(例如10,000 RPMs)。
2)在軟體RAID上使用硬體RAID,這樣速度更快,並且可以減少CPU的負載。
3)一個充足的磁碟子系統可以減少內存需求,因為較少的臨時I/O來佔用內存。
4)對於Windows NT平台,整理磁碟碎片能充分提高性能。建議每周整理磁碟碎片一次。
5)確保伺服器即使是在最大負載時,也至少有4MB內存可用(10 到 20MB更好)。要注意的是,平台的緩存策略有可能會起阻礙作用。
6)標準的伺服器配置對於Domino伺服器不一定是最優的,重要的事情是足夠的磁碟和控制器。您可以使用硬體銷售商的NotesBench基準數據作為指導。
(二)通過物理磁碟來分配I/O
通常物理的和邏輯的磁碟結構是人們經常忽略的系統資源,是最經常過載使用的。在很多Domino伺服器上提高性能的最好辦法是通過不同的物理磁碟來分配I/O。
理想的情況是,將下面與I/O相關的文件放在不同的物理磁碟上:
1)不同平台的頁面文件
2)您的NSF文件
3)Domino R5 事務日誌
如果您能將它們放在不同的控制器上,那是最好的。這個方法是通過在匯流排、控制器、埠和磁碟上分發負載來提高I/O吞吐量。因此,最好是使用幾個小磁碟,而不是一個容量大的磁碟。特別地,您將R5 事務日誌與其它磁碟活動隔離地越開,您的伺服器性能就越好。
注意,對於某些系統,例如AS/400,操作系統能在可用的磁碟和控制器間自動優化數據分布 。
通過性能監測和分析,您可以知道伺服器的運行狀況,即在當前的工作負載下伺服器是否出色運行。正如網路中的瓶頸一樣,它可以幫助您找到伺服器配置中的限制因素。
(三)經常對性能方面的衡量數據做日誌
如果您不做性能方面衡量數據的日誌,您就不能衡量您的調整是成功或失敗。如果您經常做日誌,您不但對您所做的事情有一個更好的理解,更為額外的支出提供了詳細的文件證明。
您需要從操作系統和Domino兩方面來度量。下面是主要的衡量標准(根據平台):
1)全部的CPU使用率(以百分數表示)。如果該值大於70%或80%,則在很多平台上就會有一個紅色的標志來警告,例如Windows NT。
2)可用內存或使用率。記住,當可用內存小於4MB時,減少緩存需求。
3)磁碟序列長度(通常在序列中應該小於2項)和平均磁碟服務時間(對於NT應該小於70%)。
4)頁面文件尺寸和使用率。使用率應該正當地低一些,或值得評估您的磁碟子系統的使用率和效率。例如,對於NT平台上的Domino郵件伺服器來說,頁面使用率一般應小於150頁/秒。
5)關於郵件吞吐量、復制、Web伺服器活動、資料庫活動等方面的Domino統計和事件。
6)Domino日誌(log.nsf),很煩瑣但的確很有用(注意僅當需要時才啟用日誌,因為它會影響伺服器性能)。
注意經常收集和分析數據,在做重大配置改變之前或之後,捕獲性能方面的數據是很必要的。
(四)優化Domino R5
在自動配置和動態重新配置關鍵參數以達到最大性能方面,Domino R5做了很多工作。下面是關於如何優化Domino R5伺服器本身的一些建議:
1)正確設置mailbox的數量。多個mail.box文件可以減少存放郵件和其它郵件相關的活動對mail.box文件的爭奪。當您添加第二個 mail.box時,就可以很大地改善性能。經驗是我們使用一個mail.box支持1~200個用戶,兩個或更多的mail.box支持 200~1000個用戶,最多十個mail.box支持1000個以上的用戶。
2)對於非分區的系統,讓Domino動態設置NSF_Buffer_Pool_Size變數。對於低內存的伺服器配置,這一點特別重要,大的緩沖區會妨礙核心的內存管理。
3)對於分區的系統,您需要分配NSF_Buffer_Pool_Size,因為Domino不能自動決定每個分區中實際可用的內存。我們推薦的公式是:(系統內存/分區數量)/4。
4)基於可用內存,讓Domino根據需要來分配郵件傳輸線程(為了本地傳輸)。
5)根據需要,讓Domino路由器來分配郵件傳輸線程(為了發送到其它伺服器)。
6)使用R5事物日誌。它提供給您大批完整的數據,可以使伺服器快速啟動,將性能提高10%~20%。
適當地配置一個Domino R5伺服器運行在中檔的Windows NT機器上,每分鍾能傳輸20,000條消息(每條消息平均10K位元組)!
通過性能監測和分析,您可以知道伺服器的運行狀況,即在當前的工作負載下伺服器是否出色運行。正如網路中的瓶頸一樣,它可以幫助您找到伺服器配置中的限制因素。
(五)使用NotesBench基準數據
很多基準只是告訴您銷售商想要您知道的東西,但是NotesBench基準卻與眾不同。 NotesBench基準數據可以讓您對不同銷售商的不同硬體配置上的Domino容量做一個詳細的比較,您甚至可以用這些數據估計出總成本。仔細閱讀 NotesBench數據和由它得到的詳細報告,是一個非常好的收集信息的方法。通過它,您可以優化您的系統配置。檢測專家們使用(或未用)的磁碟結構、內核設置、補丁程序等,從他們的系統中得到最大的性能參數。
(六)從信號中分析
信號是用於處理線程的一個通信機制。本質上信號是使用握手機制來決定對資源的使用。當伺服器超負荷工作時,管理員可能會從控制台收到信號。下面是通過觀察Domino 4.6而得到的一些常見的信號,並解釋了從性能方面考慮,它們意味著什麼:
1)Collection (0x30B) 和 Collection Queue (0x309).:暗示了CPU和內存達到了瓶頸。最好的解決辦法是將管理進程活動延期到空閑的時間,優化I/O子系統。
2)DB (0x245) 和 DB Queue (0x244):暗示了資料庫緩存和磁碟I/O 達到了瓶頸。 最好的解決辦法是增加更多的內存,優化I/O字系統。啟用域級的復制也會有所幫助。
3)BTree (0x255):暗示了怎樣存儲視圖和刷新視圖索引的問題。最好的解決辦法是將刷新視圖索引延期到空閑的時間,優化I/O子系統。
(七)了解伺服器過載使用時的症狀
對伺服器來說典型的問題是速度慢或郵件傳輸失敗,延長了用戶的響應時間和查找郵件地址的時間。
為檢查郵件傳輸,您可以通過查看您的磁碟使用時間的百分比和郵件序列的長度。對於R5,您也可以檢查 mail.box 文件的數量和本地郵件傳輸線程的數量。
為了提高響應時間,應盡可能優化與I/O相關的文件在磁碟子系統中分布的方式。
如果地址搜索很慢,可以使用戶在自己的客戶機上使用輕量目錄,這樣會減少伺服器和網路的負載。您也可以檢查姓名搜索緩存(Name Lookup Cache)的點擊率,一個好 的點擊率值應該是85%。
如果問題是很慢的頁面刷新率或不響應的Web伺服器,檢查HTTP線程的數量和磁碟使用時間的百分比。設置HTTP線程的數量為1:10 (每十個用戶使用一個線程)。
如何來確定一個伺服器沒有被充分使用?對於NT,指數是CPU的使用率低於50%,磁碟訪問率低於50%,或者經常有多於200MB的可用內存。但是注意新添加的用戶所需要的資源可能不等於您當前用戶的平均資源。例如,隨著用戶數量的增加,每個用戶的內存需求會減少,因為固定的內存被分配給了更多的用戶。
(八)考慮群集
群集是Domino企業伺服器的主要特徵。群集能幫助您實現動態負載均衡,在群集中可以自動優化資源的使用。在群集中還可以實現郵件和應用的失效轉移,包括Web應用。您可以將Domino支持的任何平台上的R4和R5伺服器集合在一個群集中,也可以將分區伺服器和未分區的伺服器群集在一起。
Domino群集是增加伺服器資源的魯棒性和可靠性的最好方法,也是將R5伺服器加入到R4群集中的最安全的方法。
根據您的平台,一個低價格系統的群集能以較低的初始成本提供比一個單獨龐大的伺服器更好的可靠性。另外,群集大大減少了連接伺服器失敗的用戶數量。例如,在Windows NT平台上,如果一個系統中激活的用戶超過750個,我們推薦使用群集。
(九)考慮分區
分區能提高資源使用率和高端Domino系統的可靠性,也可以使您在維持合並利益的同時,按部門或功能來分布伺服器。一些組織甚至使用分區來創建「服務級選項」(即將一些重要的經理人員放在一個分區,其他人放在另一個分區)。
通常,系統中分區的數量不應該超過CPU的數量。AS/400系統是一個例外,它非常適合做分區。AS/400平台本身從邏輯上也將分區隔離開,所以即使一個分區壞了,其它的分區仍可以正常工作。
(十)知道何時聯合何時分布
除非您有令人信服的理由,否則選擇在分布之上聯合作為增長策略。聯合總是降低成本並提高可靠性:較少的伺服器意味著不太復雜的伺服器拓撲、較少的伺服器對伺服器之間的活動、較少的網路流通、較少的復制、伺服器之間較少的郵件傳輸。
什麼時候選擇分布伺服器而不是將它們聯合在一起?您可能有地理上的分布要求,本地的伺服器以低成本來處理本地的用戶和數據。或者您開始的拓展比較小,但是增長很快,所以添加更多的伺服器來容納新用戶,或為了更好地利用當前的投資。
Ⅳ 如何提高tomcat伺服器的性能
Tomcat性能調優方案
一、操作系統調優
對於操作系統優化來說,是盡可能的增大可使用的內存容量、提高CPU的頻率,保證文件系統的讀寫速率等。經過壓力測試驗證,在並發連接很多的情況下,CPU的處理能力越強,系統運行速度越快。。
【適用場景】 任何項目。
二、Java虛擬機調優
應該選擇SUN的JVM,在滿足項目需要的前提下,盡量選用版本較高的JVM,一般來說高版本產品在速度和效率上比低版本會有改進。
JDK1.4比JDK1.3性能提高了近10%-20%,JDK1.5比JDK1.4性能提高25%-75%。
因此對性能要求較高的情況推薦使用 JDK1.6。
【適用場景】 任何項目。
三、Apache集成Tomcat
Web伺服器專門處理HTTP請求,應用伺服器是通過很多協議為應用提供商業邏輯。雖然Tomcat也可以作web伺服器,但其處理靜態html的速度比不上Apache,且其作為web伺服器的功能遠不如Apache,因此把Apache和Tomcat集成起來,將html和Jsp的功能部分進行明確分工,讓Tomcat只處理Jsp部分,其他的由Apache,IIS等web伺服器去處理,由此大大提高Tomcat的運行效率。
如果一個項目中大量使用了靜態頁面、大量的圖片等,並有有較大的訪問量,推薦使用Apache集成Tomcat的方式來提高系統的整體性能。
Apache和Tomcat的整合有三種方式,分別是JK、http_proxy和ajp_proxy.其中JK方式是最常見的方式,JK本身有兩個版本分別是1和2,目前1最新版本是1.2.8,而版本2早已經廢棄了。http_proxy是利用Apache自帶的mod_proxy模塊使用代理技術來連接Tomcat。Ajp_proxy連接方式其實跟http_proxy方式一樣,都是由mod_proxy所提供的功能。只需要把配置中的http://換成ajp://,同時連接的是Tomcat的AJP Connector所在的埠。
相對於JK的連接方式,後兩種在配置上比較簡單的,靈活性方面也一點都不遜色。但就穩定性而言不像JK這樣久經考驗,所以建議採用JK的連接方式。
Apache+JK+Tomcat配置:
使用到的兩個配置文件分別是:httpd.conf和mod_jk.conf。其中httpd.conf是Apache伺服器的配置文件,用來載入JK模塊以及指定JK配置文件信息。mod_jk.conf是到Tomcat伺服器的連接定義文件。
【部署步驟】
1.安裝Apache伺服器
2.部署Tomcat
3.將mod_jk.so拷貝到moles目錄下面
4.修改httpd.conf和mod_jk.conf
【適用場景】 大量使用靜態頁面的應用系統。
四、Apache和Tomcat集群
對於並發要求很高的系統,我們需要採取負載均衡的方式來分擔Tomcat伺服器的壓力。負載均衡實現大概有四種:第一是通過DNS,但只能簡單的實現輪流分配,不能處理故障;第二是基於MS IIS,windows 2003 server本身就帶了負載均衡服務;第三是硬體方式,通過交換機功能或專門的負載均衡設備來實現;第四種是軟體的方式,通過一台負載均衡伺服器進行,上面安裝軟體。使用Apache Httpd Server做負載均衡器,Tomcat集群節點使用Tomcat就可以做到上述第四種方式,這種方式比較靈活,成本相對比較低,另外一個很大的優點就是可以根據應用情況和伺服器的情況做一些靈活的配置。所以推薦使用Apache+Tomcat集群來實現負載均衡。
採用Tomcat集群可以最大程度的發揮伺服器的性能,可以在配置較高的伺服器上部署多個Tomcat,也可以在多台伺服器上分別部署Tomcat,Apache和Tomcat整合的方式還是JK方式。經過驗證,系統對大用戶量使用的響應方面,Apache+3Tomccat集群> Apache+2Tomcat集群 > Apache集成Tomcat > 單個Tomcat。並且採用Apache+多Tomcat集群的部署方式時,如果一個Tomcat出現宕機,系統可以繼續使用,所以在硬體系統性能足夠優越的情況下,需要盡量發揮軟體的性能,可以採用增加Tomcat集群的方式。
Apache+Tomcat集群的方式使用到得配置文件有httpd.conf、mod_jk.conf、workers.properties。其中mod_jk.conf是對JK信息的配置,包括JK的路徑等,workers.properties配置文件是對Tomcat伺服器的連接定義文件。
Apache需要調整運行參數,這樣才能構建一個適合相應網路環境的web服務。其中可進行的優化配置如下:
1. 設置MPM(Multi Processing Moles多道處理模塊)。ThreadPerChild,這個參數用於設置每個進程的線程數,在Windows環境下默認值是64,最大值是1920,建議設置為100-500之間,伺服器性能高的話值大一些,反之小一些。MaxRequestPerChild表示每個子進程能夠處理的最大請求數。這個參數的值更大程度上取決於伺服器的內存,如果內存比較大的話可以設置為很大的參數,否則設置一個較小的值,建議值是3000.
2. 關閉DNS和名字解析 HostnameLookups off
3. 打開UseCanonicalName模塊 UseCanonicalName on
4. 關閉多餘模塊 一般來說,不需要載入的模塊有,mod_include.so、mod_autoindex.so、mod_access.so、mod_auth.so.
5. 打開KeepAlive支持
KeepAlive on, KeepAliveTimeout 15 MaxKeepAliveRequests 1000
根據實際經驗,通過Apache和Tomcat集群的方式提高系統性能的效果十分明顯,這種方式可以最大化的利用硬體資源,通過多個Tomcat的處理來分擔單Tomcat時的壓力。
【部署步驟】
1.安裝Apache伺服器
2.部署Tomcat集群,即多個相同的Tomcat。
3.將mod_jk.so拷貝到moles目錄下面
4.修改httpd.conf、mod_jk.conf和workers.properties
【適用場景】 並發用戶量及在線使用用戶數量比較高的系統。
五、Tomcat自身優化
1. JVM參數調優:-Xms<size> 表示JVM初始化堆的大小,-Xmx<size>表示JVM堆的最大值。這兩個值的大小一般根據需要進行設置。當應用程序需要的內存超出堆的最大值時虛擬機就會提示內存溢出,並且導致應用服務崩潰。因此一般建議堆的最大值設置為可用內存的最大值的80%。在catalina.bat中,設置JAVA_OPTS='-Xms256m -Xmx512m',表示初始化內存為256MB,可以使用的最大內存為512MB。
2. 禁用DNS查詢
當web應用程序向要記錄客戶端的信息時,它也會記錄客戶端的IP地址或者通過域名伺服器查找機器名轉換為IP地址。DNS查詢需要佔用網路,並且包括可能從很多很遠的伺服器或者不起作用的伺服器上去獲取對應的IP的過程,這樣會消耗一定的時間。為了消除DNS查詢對性能的影響我們可以關閉DNS查詢,方式是修改server.xml文件中的enableLookups參數值:
Tomcat4
<Connector className="org.apache.coyote.tomcat4.CoyoteConnector" port="80" minProcessors="5" maxProcessors="75" enableLookups="false" redirectPort="8443" acceptCount="100" debug="0" connectionTimeout="20000" useURIValidationHack="false" disableUploadTimeout="true" />
Tomcat5
<Connector port="80" maxThreads="150" minSpareThreads="25" maxSpareThreads="75" enableLookups="false" redirectPort="8443" acceptCount="100" debug="0" connectionTimeout="20000" disableUploadTimeout="true"/>
3. 調整線程數
通過應用程序的連接器(Connector)進行性能控制的的參數是創建的處理請求的線程數。Tomcat使用線程池加速響應速度來處理請求。在Java中線程是程序運行時的路徑,是在一個程序中與其它控制線程無關的、能夠獨立運行的代碼段。它們共享相同的地址空間。多線程幫助程序員寫出CPU最大利用率的高效程序,使空閑時間保持最低,從而接受更多的請求。
Tomcat4中可以通過修改minProcessors和maxProcessors的值來控制線程數。這些值在安裝後就已經設定為默認值並且是足夠使用的,但是隨著站點的擴容而改大這些值。minProcessors伺服器啟動時創建的處理請求的線程數應該足夠處理一個小量的負載。也就是說,如果一天內每秒僅發生5次單擊事件,並且每個請求任務處理需要1秒鍾,那麼預先設置線程數為5就足夠了。但在你的站點訪問量較大時就需要設置更大的線程數,指定為參數maxProcessors的值。maxProcessors的值也是有上限的,應防止流量不可控制(或者惡意的服務攻擊),從而導致超出了虛擬機使用內存的大小。如果要加大並發連接數,應同時加大這兩個參數。web server允許的最大連接數還受制於操作系統的內核參數設置,通常Windows是2000個左右,Linux是1000個左右。
在Tomcat5對這些參數進行了調整,請看下面屬性:
maxThreads Tomcat使用線程來處理接收的每個請求。這個值表示Tomcat可創建的最大的線程數。
acceptCount 指定當所有可以使用的處理請求的線程數都被使用時,可以放到處理隊列中的請求數,超過這個數的請求將不予處理。
connnectionTimeout 網路連接超時,單位:毫秒。設置為0表示永不超時,這樣設置有隱患的。通常可設置為30000毫秒。
minSpareThreads Tomcat初始化時創建的線程數。
maxSpareThreads 一旦創建的線程超過這個值,Tomcat就會關閉不再需要的socket線程。
最好的方式是多設置幾次並且進行測試,觀察響應時間和內存使用情況。在不同的機器、操作系統或虛擬機組合的情況下可能會不同,而且並不是所有人的web站點的流量都是一樣的,因此沒有一刀切的方案來確定線程數的值。
六、APR庫使用
Tomcat中使用APR庫,其實就是在Tomcat中使用JNI的方式來讀取文件以及進行網路傳輸。可以大大提升Tomcat對靜態文件的處理性能,同時如果你使用了HTTPS方式傳輸的話,也可以提升SSL的處理性能。
一般在Windows下,可以直接下載編譯好的二進製版本的dll庫文件來使Tomcat啟用APR,一般建議拷貝庫文件tcnative-1.dll到Tomcat的bin目錄下。而在Linux下,可以直接解壓和安裝bin目錄下的tomcat_native.tar.gz文件,編譯之前要確保apr庫已經安裝。
怎麼才能判斷Tomcat是否已經啟用了APR庫呢?方法是通過看Tomcat的啟動日誌:
如果沒有啟用APR,則啟動日誌一般有這么一條:
org.apache.coyote.http11.Http11Protocol start
如果啟用了APR,則這條日誌就會變成:
org.apache.coyote.http11.Http11AprProtocol start
tcnative-1.dll 下載地址:http://tomcat.heanet.ie/native/
調優綜述
根據以上分析,如果想要Tomcat達到最優的效果,首先要爭取使得操作系統以及網路資源達到最優,並且最好使用高版本的JDK。對於有大量靜態頁面的系統,採用Apache集成Tomcat的方式,把靜態頁面交由Apache處理,動態部分交由Tomcat處理,能極大解放Tomcat的處理能力。使用ARP庫也能極大的提高Tomcat對靜態文件的處理能力。對於並發要求較高的系統,採用Apache加Tomcat集群的方式,將負載分別分擔到多個Tomcat上,能很大的提高系統的性能,充分利用硬體資源。同時需要對Tomcat自身進行優化,包括增大內存、調節並發線程數等。
Ⅵ 單台web伺服器如何盡可能的提高網站性能
1.使用瀏覽器緩存,設置HTTP頭中Cache-Control和Expires屬性,緩存時間可以是幾天或者幾個月。
2.減少http請求,合並CSS,合並JavaScript,合並圖片,將瀏覽器一次訪問需要的JavaScript,CSS合並成一個文件。
3.啟用壓縮,在伺服器端開啟GZIP壓縮功能,可有效較少通信傳輸的數據量,文本文件的壓縮效率科大80%以上。
4.CSS放在頁面上面,JavaScript放在頁面最下面。
5.全站生成靜態HTML頁面。
5.1、網站訪問更快更穩定,極大的降低資料庫資源的消耗,減輕伺服器的負擔。
5.2、安全,理論上一個全站靜態的網站,是沒有任何漏洞可攻擊的。
5.3、更容易被搜索引擎搜索到。
6.減少Cookie傳輸,盡量減少Cookie中傳輸的數據量和傳輸的次數。
7.CDN加速,將網站緩存在CDN可極大提高網頁的打開速度。
8.網站源碼優化,這個內容比較多。
想到的也就這些了~
Ⅶ 如何對伺服器進行性能優化
我對我的windows2000伺服器是如何進行性能優化的
1:我們知道,系統剛裝完之後,會存在很多無用的文件,這些文件都在winnt下面我們就對這些文件進行del,比如*.tmp、*.bak、*.log、*.old、*.txt甚至是作為桌面背景的*.bmp文件,help這個目錄下的,基本上也沒什麼用,反正伺服器上的help我是從來不去看它的!還有winnt\temp文件,是軟體安裝的過程序中,可能生成的臨時文件,如果沒用,就刪掉吧!然後清空回收站吧!
2:啟動和故障恢復選項,右擊我的電腦,選擇屬性\高級\啟動和故障恢復,將選擇操作系統列表前面的勾直接去掉好了,寫入調試信息,選擇無!
3:瀏覽器歷史記錄和緩存,可以通過點擊瀏覽器的「工具/Internet選項/常規/Internet臨時文件/刪除文件
4:(1)運行磁碟查錯的時候,請先把運行的程序關閉,打開「我的電腦」,右擊想要整理的硬碟驅動器,選擇「屬性/工具」,在查錯一欄中點擊「開始檢查」在進行磁碟檢查之前請確認「自動修復文件系統錯誤」和「掃描並試圖恢復壞扇區」這兩項被選中。
(2)碎片整理,請把所有運行的程序關閉,特別是屏幕保護、計劃任務、實時查殺毒軟體等等可能造成磁碟存儲數據變化的程序,然後打開「我的電腦」,右擊想要整理的硬碟驅動器,選擇「屬性/工具」,在「碎片整理」中選擇「開始整理」,你可以點擊「分析」按鈕讓系統分析你的硬碟的基本情況,然後告訴你的硬碟是否需要整理。如果需要整理,那麼你只要點擊「碎片整理」按鈕即可。整理的時間依據你的這個硬碟分區有多少簇來決定――不得不承認這個過程相當乏味、枯燥而且緩慢。所以你可以找具有類似功能的軟體比如諾頓工具箱中就有磁碟整理的組件、另外象Diskeeper、Vopt等等程序整理的效果也不錯(但是同windows自帶的磁碟整理軟體的效果仍然有差距),而且速度快。
5:硬碟驅動器設置,現在的硬碟一般都是支持DMA(Direct Memory Access:直接內存存取)模式,所以確保你的DMA硬碟(不管是DMA33/66/100)只要能正確的在DMA模式下工作,就能保證你的系統工作在比較高的效率之下。啟動DMA模式――點擊「開始/設置/控制面板/系統/硬體/設備管理器」,然後點擊「IDE ATA/ATAPI控制器」,右擊Primary IDE Channel,選擇「屬性/高級設置」在「傳送模式」中選擇DMA(若可用)。依據提示重新啟動計算機,你下次打開這個界面應該能看到「當前傳輸模式」中是DMA了。
6:關閉索引服務,關閉這項功能的方法是,打開我的電腦,右擊相應的硬碟驅動器分區圖標,選擇屬性,去掉「允許索引服務編制該磁碟的索引以便快速搜索文件」選項前的對鉤,點擊「應用」,就會出現是僅僅將屬性應用於這個分區的根目錄還是連同它下面的子文件夾和文件。選擇「將更改應用於<盤符>:\,子文件夾和文件」。然後點擊確定,等待系統自己處理完成就可以了。
7:自動關閉停止響應的程序,對於停止響應的程序,可以通過修改注冊表使得系統不再通知你,而是自動關閉――不再需要用戶的干預,從而提高工作效率。具體方法是,打開注冊表編輯器,找到如下鍵值:
HKEY_CURRENT_USER\Control Panel\Desktop,把AutoEndTasks修改為1。以後如果遇到停止響應的程序,系統就會自動中止它。
8:設置虛擬內存,我們應選擇優化後台服務
9:停止Win2000中不必要的服務,以下是我停掉的服務,大家可以參考一下!
服務名 簡介
COM+ Event System 提供事件的自動發布到訂閱 COM 組件
Computer Browser 維護網路上計算機的最新列表以及提供這個列表
Network Connections 管理「網路和撥號連接」文件夾中對象,在其中您可以查看區域網和遠程連接
Plug and Play 管理設備安裝以及配置,並且通知程序關於設備更改的情況
Protected Storage 提供對敏感數據(如私鑰)的保護性存儲,以便防止未授權的服務,過程或用戶對其的非法訪問(備註:缺少了此項後可能造成在IE中輸入文字後死機)
RusAs Service 在不同賃據下啟動過程服務
Remote Procere Call (RPC) 提供終結點映射程序(endpoint mapper)以及其它 RPC 服務
Security Accounts Manager 存儲本地用戶帳戶的安全信息
Server 提供 RPC 支持、文件、列印以及命名管道共享
Task Scheler允許程序在指定時間運行
Windows Management Instrumentation Driver Extensions 與驅動程序間交換系統管理信息
Ⅷ 教你如何發揮伺服器性能監控的最大價值
linux伺服器性能監測是很重要的工作,伺服器運行應該提供最有效的系統性能。當伺服器系統性能突然低於平均應有的情況,問題可能來自在執行的進程、內存的使用率、磁碟的性能、網路流量和cpu
的壓力。在預算短缺的今天,理解如何優化系統性能比以往任何時候都重要。
要實現它的前提是,你必須充分了解自己的計算機和網路,從而找到真正的瓶頸所在。本文提供一些基礎的工具來辨別和處理一些性能問題。使用的linux
發行版本是red
hat
enterprise
linux
4,工作過程是:首先查看整個系統的狀態,然後是檢查特定的子系統。
linux伺服器進行性能監控有幾種方法,每種方法都各有其優缺點。
使用snmp等標准工具
標准及非標准工具能執行一個或多個收集、合並及傳輸階段,如rstatd或snmp工具,然而標準的rstat後台程序提供的信息是有限的,速度慢而且效率低。
內核模塊
幾個系統監控工程利用內核模塊來存取監控數據。一般情況下,這是很有效的收集系統數據的方法。然而這種方法存在的問題是,當主內核源內有其它改變時,必須保持代碼一致性。一個內核模塊可能與用戶想使用的其它內核模塊相沖突。此外,在使用監控系統之前,用戶必須獲得或申請模塊。
/proc虛擬文件系統
/proc虛擬文件系統是一個較快的、高效率執行系統監控的方法。使用/proc的主要缺點是必須保持代碼分析與/proc
文件格式改變的同步。事實表明,linux內核的改變比/proc
文件格式的改變要更頻繁,所以,用/proc虛擬文件系統比用內核模塊存在的問題要少。本文介紹的方法即基於/proc虛擬文件系統。
一、
/proc文件系統特點
linux
系統向管理員提供了非常好的方法,使他們可以在系統運行時更改內核,而不需要重新引導內核系統。這是通過
/proc
虛擬文件系統實現的。/proc
文件虛擬系統是一種內核和內核模塊用來向進程
(process)
發送信息的機制
(所以叫做
/proc)。這個偽文件系統讓你可以和內核內部數據結構進行交互,獲取
有關進程的有用信息,在運行中
(on
the
fly)
改變設置
(通過改變內核參數)。
與其他文件系統不同,/proc
存在於內存之中而不是硬碟上。不用重新啟動而去看
cmos
,就可以知道系統信息。這就是
/proc
的妙處之一。
小提示:
每個linux系統根據軟硬體不同/proc
虛擬文件系統的內容也有些差異。/proc
虛擬文件系統有三個很重要的目錄:net,scsi和sys。sys目錄是可寫的,可以通過它來訪問或修改內核的參數,而net和scsi則依賴於內核配置。
Ⅸ 如何使伺服器性能優化
先閱讀apache配置優化建議如下,再對相關參數進行調整,觀察伺服器狀況.
Apache配置優化建議:
進入/usr/local/apache2/conf/extra目錄下
Apache優化,
經過上述操作後,Apache已經能夠正常運行。但是,對於訪問量稍大的站點,Apache的這些默認配置是無法滿足需求的,我們仍需調整Apache的一些參數,使Apache能夠在大訪問量環境下發揮出更好的性能。以下我們對Apache配置文件httpd.conf中對性能影響較大的參數進行一些說明。
(1)Timeout該參數指定Apache在接收請求或發送所請求內容之前的最長等待時間(秒),若超過該時間Apache則放棄處理該請求,並釋放連接。該參數默認值為120,推薦設置為60,對於訪問量較大的網站可以設置為30或15。
(2)KeepAlive該參數控制Apache是否允許在一個連接中有多個請求,默認打開。但對於大多數論壇類型站點來說,通常設置為off以關閉該支持。
(3)MPM-prefork.c在默認情況下Apache使用Prefork(進程)工作模式,可以說這部分的參數設置是對Apache性能影響的核心和關鍵。用戶可以在配置文檔中找到以下配置段:
Ⅹ 怎樣提高Windows伺服器性能
這里有許多你只需要做簡單的操作就能對提高伺服器的性能有所幫助。所有的這些都不可能對移動頁文件到一個指定磁碟有什麼異常情況發生,盡管大多數的操作需要手動完成,但是這些所有的技巧都能夠顯著地提高伺服器的性能。
大多數討論關於優化伺服器性能的文章都會集中在使用性能監視器來尋找性能瓶頸問題。性能監視器對於如何提高伺服器性能來說,確實是一個優秀的工具。但是,使用性能監視器,是需要用戶必須了解性能監視器中產生的數據都是些什麼意思。
那麼,這里有十項能夠幫助你做提高伺服器性能的事情
1.為頁文件使用專用磁碟
這項技巧可能是最大限度的提高你伺服器性能的方法。默認情況下,Windows創建一個頁文件,將它作為虛擬內存。因為Windows會頻繁的使用這個文件。這個文件最好的存儲位置就是在一個專門磁碟上(注意:不是單獨卷)。伺服器性能做這些會確保Windows在讀取頁文件數據前,而將不需等待其他的應用使用硬碟完成。
2.保證你的硬碟定期運行磁碟碎片整理程序伺服器性能
現今的磁碟在執行連續不斷的讀取時,其實是很快的。然而,當磁碟被請求去讀取散亂存放的數據時,Windows的性能就會下降。通過運行磁碟碎片整理程序,你能夠確保文件能以順序的方式而不是雜亂無章的存放在磁碟上,從而,你的計算機將會高效地讀取文件。
3.使用NTFS文件系統
盡管對於Windows伺服器版本操作系統來說,NTFS是默認的文件系統,Windows是支持使用FAT和FAT-32文件系統的。我讀過的每一本MSCE培訓教程推薦使用NTFS文件系統是因為它比FAT和FAT-32文件系統使用中更安全。伺服器性能但是這些書籍中都沒有提及NTFS是一種基於處理(transaction-based)的文件系統。這就意味著相比較FAT和FAT-32文件系統而言,NTFS文件系統更快。
4.避免運行16-位應用
64位Windows操作系統根本不能夠運行16位應用,所以說這一項對於64位操作系統來說並不是個問題。但是,32位Windows操作系統將會運行16位應用。使用多任務處理模式的Windows更多的使用16位應用。伺服器性能討論Windows的多任務處理使用16位應用將需要單獨開篇說明,但是可以確定的說,運行16位應用會對降低性能。
5.查找內存泄漏(memory leaks)
內存泄漏很難被寫成是一個應用上的問題。通常情況下,它會為一個應用去在一個需要的基礎上請求操作系統中的內存。典型的是,當應用不再被運行時,它將會把內存釋放給操作系統。如果一個應用包括了一個內存泄漏,當它被運行時,將會向內存發出請求,但是當使用完畢後,釋放內存是失敗的。伺服器性能當下一次應用需要內存時,它將會向Windows要求的內存數比上一次要多。長此以往,Windows能夠為其他的應用提供的內存數將會越來越少。
最初,內存泄漏對系統性能的影響是可以忽略不計的,但是當這樣的泄漏變得越來越多的時候,它對系統性能的影響就會凸現出來。
盡管我曾經說過我不會在這篇文章中討論性能監控器,但是對於查找內存泄漏來說,性能監控器是最佳工具。
6.移除那些極少使用的組件
我曾經購買的每一台伺服器上都會裝上各種各樣的監控或者日誌組件。如果你能夠有計劃有規律的使用這些組件的話,在計算機上安裝這些組件算不得什麼不正確的選擇。伺服器性能但是令我吃驚的是有很多系統管理員安裝(或者從不移除)那些伺服器上的組件,並且實際上除了浪費系統資源外,它們甚至從來沒被運行過。
7.停止運行那些不使用的服務
在一篇類似的文章中,我也推薦瀏覽服務控制管理器,並關閉那些沒有被用到的服務。這樣不但能夠提高我們的伺服器性能,另外它也可以提高伺服器的安全性。計算機有一條法則描述了被執行的代碼越多,代碼中包含的不安全因素的機會就會增多。通過關閉那些不使用的服務,你做得即是減少執行代碼的大小,從而降低伺服器包含的安全漏洞被利用的機會。
8.注銷
這是另一個你能夠提高伺服器安全和性能的方法。當你不再使用控制台的時候,出於安全原因考慮,你應該進行注銷操作。伺服器性能 同時,在你登陸時,Windows將會載入你的用戶屬性,這將會消耗內存和CPU。
9.壓縮磁碟
當微軟發布MS-DOS5.0時,它們介紹了其磁碟壓縮的特色功能。當時的情況是讓硬碟或者軟盤能夠通過壓縮功能存儲更多的數據。當我試著使用磁碟壓縮技術,這時,我的計算機運行就慢了下來,我就改回使用一個沒有壓縮的磁碟,並且直到最近再沒有使用過壓縮。
現在,在正常的情況下,壓縮確實能夠提高系統性能。在一台計算機中,硬碟算得上是運行最慢的部分了。然而,如果你能夠壓縮一個文件,你就是減少了它的物理大小,這也將會減少從硬碟中讀取它的時間量。
同時,一個壓縮文件必須在它從磁碟讀取後被解壓。解壓操作通常是佔用內存,並且進程會附帶的使用一些CPU時間。如果你的伺服器運行一個磁碟加強的應用來解決大量的分散文件(不是一個資料庫),執行壓縮能夠提高系統性能。
10.調整伺服器響應
與個人計算機不同的是伺服器並不總是從伺服器的控制台那裡運行應用。那麼,最優化伺服器是將獲得優先權的應用到後台執行。
你可以通過打開伺服器的控制面板,並雙擊系統圖標。當窗口中顯示系統屬性標簽時,轉到「高級」標簽項,找到性能設置部分,並點擊設置按鈕。窗口中將會顯示性能選項屬性標簽。轉到屬性標簽中的高級選項,並確定伺服器設置為後台服務的最佳性能。