3 回答

TA貢獻(xiàn)1744條經(jīng)驗(yàn) 獲得超4個(gè)贊
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 | ThinkPHP其實(shí)并不支持分布式緩存功能,這可以從官方提供的CacheMemcache.class.php文件中看到: if(empty($options)) { $options = array ( 'host' => '127.0.0.1', 'port' => 11211, 'timeout' => false, 'persistent' => false ); } $func = $options['persistent'] ? 'pconnect' : 'connect'; $this->expire = isset($options['expire'])?$options['expire']:C('DATA_CACHE_TIME'); $this->handler = new Memcache; $this->connected = $options['timeout'] === false ? $this->handler->$func($options['host'], $options['port']) : $this->handler->$func($options['host'], $options['port'], $options['timeout']);
不過不要緊,稍微修改下就行了,即
if(empty($options)) { $options = array ( 'timeout' => false, 'persistent' => false, 'servers'=>array( array('ip'=>'127.0.0.1','port'=>11211), array('ip'=>'127.0.0.1','port'=>11212), array('ip'=>'202.116.32.4','port'=>11211), ), ); } //分布式處理函數(shù) $func="addServer"; $this->expire = isset($options['expire'])?$options['expire']:C('DATA_CACHE_TIME'); $this->handler = new Memcache; if($options['timeout']===false) { foreach($options['servers'] as $server) { $this->handler->$func($server['ip'],$server['port']); } }
閑來無事,于是就在本機(jī)上啟動(dòng)了兩個(gè)MemCache服務(wù)器,順手編寫了一段簡單的監(jiān)控代碼(隔一段時(shí)間自動(dòng)刷新一次),進(jìn)行測試。如果發(fā)現(xiàn)服務(wù)器運(yùn)行不正常,則使用PhpMailer自動(dòng)發(fā)送一封Email到管理員郵箱。測試結(jié)果表明,兩臺(tái)Memcache服務(wù)器均工作正常,而另外一臺(tái)虛假的服務(wù)器當(dāng)然是無法連接到的。 |

TA貢獻(xiàn)1802條經(jīng)驗(yàn) 獲得超6個(gè)贊
所有的被發(fā)送到memcached的單個(gè)命令是完全原子的。如果您針對(duì)同一份數(shù)據(jù)同時(shí)發(fā)送了一個(gè)set命令和一個(gè)get命令,它們不會(huì)影響對(duì)方。它們將被串行化、先后執(zhí)行。即使在多線程模式,所有的命令都是原子的,除非程序有bug:)
命令序列不是原子的。如果您通過get命令獲取了一個(gè)item,修改了它,然后想把它set回memcached,我們不保證這個(gè)item沒有被其他進(jìn)程(process,未必是操作系統(tǒng)中的進(jìn)程)操作過。在并發(fā)的情況下,您也可能覆寫了一個(gè)被其他進(jìn)程set的item。
memcached
1.2.5以及更高版本,提供了gets和cas命令,它們可以解決上面的問題。如果您使用gets命令查詢某個(gè)key的item,memcached會(huì)
給您返回該item當(dāng)前值的唯一標(biāo)識(shí)。如果您覆寫了這個(gè)item并想把它寫回到memcached中,您可以通過cas命令把那個(gè)唯一標(biāo)識(shí)一起發(fā)送給
memcached。如果該item存放在memcached中的唯一標(biāo)識(shí)與您提供的一致,您的寫操作將會(huì)成功。如果另一個(gè)進(jìn)程在這期間也修改了這個(gè)
item,那么該item存放在memcached中的唯一標(biāo)識(shí)將會(huì)改變,您的寫操作就會(huì)失敗。

TA貢獻(xiàn)1871條經(jīng)驗(yàn) 獲得超8個(gè)贊
thinkphp 本身并沒有進(jìn)行高并發(fā)處理的功能
高并發(fā) 的先要知道你自己做的東西哪里并發(fā)高
thinkphp 內(nèi)置很多第三方的內(nèi)存緩存類,你只要把redis memcache memcached這些緩存安裝上,用內(nèi)存緩存可以緩解高并發(fā)。只是緩解并不能完全解決。
高并發(fā)要想說可以寫一本書了 ,不是thinkphp能解決的問題
- 3 回答
- 0 關(guān)注
- 777 瀏覽
添加回答
舉報(bào)