上一篇我們介紹了nginx實現(xiàn)的負載均衡和動靜分離,可看這邊。
10年積累的成都網(wǎng)站制作、網(wǎng)站設(shè)計經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認識你,你也不認識我。但先網(wǎng)站設(shè)計制作后付款的網(wǎng)站建設(shè)流程,更有大竹免費網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
我們在文章的末尾說到,負載均衡需要面臨的一個問題是內(nèi)存數(shù)據(jù)的同步。例如:我有A,B兩臺服務(wù)器做了負載均衡,當(dāng)我在A服務(wù)器上執(zhí)行了登錄并且將登錄數(shù)據(jù)存入session的時候,這些session數(shù)據(jù)只存在于A服務(wù)器上,而沒有在B服務(wù)器上,假如在處理下一個請求的時候,我需要用到session的數(shù)據(jù),而不巧的是,這個請求剛好被交由B服務(wù)器來處理,這時候就會出現(xiàn)B服務(wù)器拿不到session數(shù)據(jù)的情況,從而造成錯誤。
這是一個無法避免的問題,有若干的解決方案,歸結(jié)起來都是要實現(xiàn)session等數(shù)據(jù)在各負載均衡分支中的同步,第一種想到的方案是把這些數(shù)據(jù)放在MySQL等數(shù)據(jù)庫,也就是說存在磁盤,但是我們都知道session之所以出現(xiàn)是因為它是在內(nèi)存中的,程序讀取內(nèi)存的數(shù)據(jù)要遠遠比讀取磁盤的數(shù)據(jù)快,所以我們把一些經(jīng)常用到的東西都放在session里面。
有沒有一種數(shù)據(jù)庫,是存放在內(nèi)存中的呢?這就是redis。通俗的講,它就是一個數(shù)據(jù)庫,但是這個數(shù)據(jù)庫是存在與內(nèi)存里面的,所以存取起來速度要比讀取磁盤的數(shù)據(jù)快得多。又因為它是一個數(shù)據(jù)庫,所以可以實現(xiàn)數(shù)據(jù)的同步。
我們把session數(shù)據(jù)存放在redis中,然后所有的集群分支都可以去訪問這個數(shù)據(jù)庫里面的東西,這就是全局緩存的原理。
1.第一步是安裝redis,我的服務(wù)器是windows的,下載的是免安裝版本,解壓以后就可以了,其目錄如下。一開始redis是默認不需要密碼,如果想要設(shè)置密碼,可以進入redis.windows.conf文件下找到requirepass,刪除前面的#號,在其后面便可以設(shè)置密碼。
2.從cmd進入redis的根目錄,鍵入如下指令:redis-server.exeredis.windows.conf。這樣就可以啟動redis了,如果啟動成功,則會出現(xiàn)下面畫面。當(dāng)然還可以修改conf文件,加上密碼。requirepass xxxxx
3.接下來我們就可以做一些配置工作,來實現(xiàn)session數(shù)據(jù)的全局緩存。
1)首先是添加jar包,如果你是maven項目,需要在pom.xml加入下面代碼
org.springframework.session spring-session-data-redis 1.3.1.RELEASE pom
如果不是maven項目,你需要加入下面這些jar包。
2)編寫redis.properties,代碼如下
redis_isopen:yes #主機地址 redis_hostName=xxx.xxx.xxx.xxx #端口 redis_port=6379 #密碼 redis_password=xxxxxxxx #連接超時時間 redis_timeout=200000 redis_maxIdle:300 redis_maxActive:600 redis_maxWait:100000 redis_testOnBorrow:true
基本上與我們配置數(shù)據(jù)庫的連接語句類似。
3)編寫spring-redis.xml配置文件,這個文件配置關(guān)于redis的一些基本信息。
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
4)在application.xml(spring的主配置文件)需要加入redis.properties配置文件的掃描,如下。
/WEB-INF/classes/redis.properties
5)在主配置文件中引入spring-redis.xml,如下。
6)在web.xml中,加入關(guān)于session的過濾器,只有這樣session才會被redis所操縱。
springSessionRepositoryFilter org.springframework.web.filter.DelegatingFilterProxy springSessionRepositoryFilter /*
這樣以后,我們就實現(xiàn)了redis對session的管理。
7)我們可以安裝一個redis的客戶端來查看里面的數(shù)據(jù),叫做Redis Desktop Manager。如下圖,很好用,可以看到redis數(shù)據(jù)庫中的數(shù)據(jù)。
PS.再退出的時候,需要這樣寫才不會出錯。(ssh項目)
public String yipinExit(){ Iteratorkeys=session.keySet().iterator(); while(keys.hasNext()){ String key=keys.next(); session.remove(key); } return "yipinExit"; }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。