既然題目中問的是提高【服務器】并發處理能力,那么先說說關于提高單機服務器性能的方法;一臺服務器在單位時間里,能夠處理的請求越多,就說明服務器并發處理能力越強。
內存:減少內存的分配和釋放,這個本質上只為了內存分配和數據復制的時間;比如程序在啟動的時候,就申請一塊足夠大的內存,不需要再次分配;另外可以考慮內存共享。
CPU:使用多線程,提高CPU的并發度;但是線程數不可以無限制地增加,因為進程切換也是需要花費時間的;減少使用不必要的鎖,因為當一個資源被鎖住的時候,其余的進程會等待鎖的釋放;改進I/O模型,使I/O和CPU計算盡量重疊進行,減少CPU空閑和調度的時間。
網絡:根據應用的特點,合理地選擇使用長鏈接還是短鏈接;因為建立連接是很耗時的,但是如果要使用長鏈接,依然要考慮超時的問題,因為如果連接時間過長并且沒有使用,需要維持空閑連接,影響服務器性能。
提高硬件資源:說白了,就是花更多的錢,買更好的設備,比如帶寬、更大的內存、更多的CPU、SSD等等。
還有很多手段,可以提高整個項目的并發處理能力:
負載均衡、集群:一臺服務器再怎么優化,也不如十臺服務器同時工作,通過負載均衡,把請求分發到多臺服務器上進行處理;另外一個好處,當一臺服務器發生故障的時候,并不會影響整個項目的運行;
緩存:其目的就是減少服務器的計算,把數據直接返回給用戶;比如CDN、本地緩存、分布式緩存等等;
分布式:如果說集群是把相同的項目部署在多臺服務器上,那么分布式相當于把一個項目拆分成多個項目,每個子項目都可以獨立地集群化部署;分布式架構意味著可以利用更多的服務器,能過處理的并發訪問會越大。
異步:調用方不需要等待被調用方處理完成,可以先做其它的事情,所有的事情可以并發處理;異步可以通過消息隊列來實現異步;
冗余、彈性擴縮容:根據訪問量,部署更多一些的服務器;當有突發流量的時候,彈性擴容機制可以保證快速地增加機器的數量,保證系統的穩定運行;
我將持續分享Java開發、架構設計、程序員職業發展等方面的見解,希望能得到你的關注。