之前有寫過ubuntu環境下搭建nginx環境,今天來談一下nginx session共享問題,查了一些資料,看了一些別人寫的文件,總結如下,實現nginx session的共享伺服器有多台,用nginx做負載均衡,這樣同乙個ip訪問同乙個頁面會被分配到不同的伺服器上,如果session不同步的話,就會出現很多問題,比如說最常見的登入狀態,下面提供了幾種方式來解決session共享的問題:
1、不使用session,換用cookie
session是存放在伺服器端的,cookie是存放在客戶端的,我們可以把使用者訪問頁面產生的session放到cookie裡面,就是以cookie為中轉站。你訪問web伺服器a,產生了session然後把它放到cookie裡面,當你的請求被分配到b伺服器時,伺服器b先判斷伺服器有沒有這個session,如果沒有,再去看看客戶端的cookie裡面有沒有這個session,如果也沒有,說明session真的不存,如果cookie裡面有,就把cookie裡面的sessoin同步到伺服器b,這樣就可以實現session的同步了。
說明:這種方法實現起來簡單,方便,也不會加大資料庫的負擔,但是如果客戶端把cookie禁掉了的話,那麼session就無從同步了,這樣會給**帶來損失;cookie的安全性不高,雖然它已經加了密,但是還是可以偽造的。
2、session存在資料庫(mysql等)中
可以配置將session儲存在資料庫中,這種方法是把存放session的表和其他資料庫表放在一起,如果mysql也做了集群了話,每個mysql節點都要有這張表,並且這張session表的資料表要實時同步。
說明:用資料庫來同步session,會加大資料庫的io,增加資料庫的負擔。而且資料庫讀寫速度較慢,不利於session的適時同步。
3、session存在memcache或者redis中
memcache可以做分布式,程式配置檔案中設定儲存方式為memcache,這樣程式自己會建立乙個session集群,將session資料儲存在memcache中。
說明:以這種方式來同步session,不會加大資料庫的負擔,並且安全性比用cookie大大的提高,把session放到記憶體裡面,比從檔案中讀取要快很多。但是memcache把記憶體分成很多種規格的儲存塊,有塊就有大小,這種方式也就決定了,memcache不能完全利用記憶體,會產生記憶體碎片,如果儲存塊不足,還會產生記憶體溢位。
4、nginx中的ip_hash技術能夠將某個ip的請求定向到同一台後端,這樣一來這個ip下的某個客戶端和某個後端就能建立起穩固的session,ip_hash是在upstream配置中定義的:
upstream nginx.example.com
server
}
ip_hash是容易理解的,但是因為僅僅能用ip這個因子來分配後端,因此ip_hash是有缺陷的,不能在一些情況下使用:
<1>nginx不是最前端的伺服器。
ip_hash要求nginx一定是最前端的伺服器,否則nginx得不到正確ip,就不能根據ip作hash。譬如使用的是squid為最前端,那麼nginx取ip時只能得到squid的伺服器ip位址,用這個位址來作分流是肯定錯亂的。
<2>nginx的後端還有其它方式的負載均衡。
假如nginx後端又有其它負載均衡,將請求又通過另外的方式分流了,那麼某個客戶端的請求肯定不能定位到同一臺session應用伺服器上。這麼算起來,nginx後端只能直接指向應用伺服器,或者再搭乙個squid,然後指向應用伺服器。最好的辦法是用 location作一次分流,將需要session的部分請求通過ip_hash分流,剩下的走其它後端去。
5、upstream_hash
為了解決ip_hash的一些問題,可以使用upstream_hash這個第三方模組,這個模組多數情況下是用作url_hash的,但是並不妨礙將它用來做session共享。
<1>fair(第三方)
按後端伺服器的響應時間來分配請求,響應時間短的優先分配。
upstream resinserver
<2>url_hash(第三方)
按訪問url的hash結果來分配請求,使每個url定向到同乙個後端伺服器,後端伺服器為快取時比較有效。
例:在upstream中加入hash語句,server語句中不能寫入weight等其他的引數,hash_method是使用的hash演算法
upstream resinserver
tips:
upstream resinserver
在需要使用負載均衡的server中增加
nginx 負載均衡 Nginx負載均衡策略
nginx提供的負載均衡策略有2種 內建策略和擴充套件策略。內建策略為輪詢 預設 加權輪詢,ip hash,第三方。upstream mysvr1 輪詢 每個請求按照時間順序逐一的分配到每乙個後台伺服器上。如果某台伺服器宕機了,將會自動的剔除宕機的服務。nginx預設就是輪詢其權重都預設為1,伺服器...
nginx負載均衡解決session問題
我們都知道,session是用於在伺服器上儲存使用者的登入資訊的,在使用負載均衡時,後端的伺服器ip不是固定的,這樣就導致了使用者重新整理網頁後登陸資訊會失效 訂單異常等一系列問題。一般有以下方法來解決這個問題 nginx ip hash 通過nginx負載均衡策略中ip hash來保持資料的持久化...
解決nginx負載均衡的session共享問題
之前有寫過ubuntu環境下搭建nginx環境,今天來談一下nginx session共享問題,查了一些資料,看了一些別人寫的文件,總結如下,實現nginx session的共享伺服器有多台,用nginx做負載均衡,這樣同乙個ip訪問同乙個頁面會被分配到不同的伺服器上,如果session不同步的話,...