亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

thinkphp商城如何處理高并發,怎么使用memcache做緩存

thinkphp商城如何處理高并發,怎么使用memcache做緩存

眼眸繁星 2019-04-14 08:08:16
thinkphp商城如何處理高并發,怎么使用memcache做緩存
查看完整描述

3 回答

?
慕無忌1623718

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服務器均工作正常,而另外一臺虛假的服務器當然是無法連接到的。


 

查看完整回答
反對 回復 2019-04-15
?
呼啦一陣風

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中的唯一標識將會改變,您的寫操作就會失敗。



查看完整回答
反對 回復 2019-04-15
?
ITMISS

TA貢獻1871條經驗 獲得超8個贊

thinkphp 本身并沒有進行高并發處理的功能

高并發 的先要知道你自己做的東西哪里并發高

thinkphp 內置很多第三方的內存緩存類,你只要把redis memcache memcached這些緩存安裝上,用內存緩存可以緩解高并發。只是緩解并不能完全解決。
高并發要想說可以寫一本書了 ,不是thinkphp能解決的問題

查看完整回答
反對 回復 2019-04-15
  • 3 回答
  • 0 關注
  • 783 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號