3 回答

TA貢獻1744條經驗 獲得超4個贊
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其實并不支持分布式緩存功能,這可以從官方提供的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), ), ); } //分布式處理函數 $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']); } }
閑來無事,于是就在本機上啟動了兩個MemCache服務器,順手編寫了一段簡單的監控代碼(隔一段時間自動刷新一次),進行測試。如果發現服務器運行不正常,則使用PhpMailer自動發送一封Email到管理員郵箱。測試結果表明,兩臺Memcache服務器均工作正常,而另外一臺虛假的服務器當然是無法連接到的。 |

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

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