今天來玩看看 memcache 看看,話說 memcache 是個非常好用的東西,可以參考官網作法 連結,其實我在前一個工作,就有老闆問我說,像公司作這麼多網站,有沒有辦法統整成一個,然後底下各種服務,只需要登入過一次就好,而不必重複登入,畢竟會讓使用者覺得很煩,所以就有了 memcache 這東西出來,底下就來介紹 FreeBSD 的安裝方式
- 安裝方法: 安裝 ports 的套件 memcache 跟 pecl-memcache
cd /usr/ports/databases/memcached; make install clean cd /usr/ports/databases/pecl-memcache; make install clean然後他會把 extension=memcache.so 寫到 /usr/local/etc/php/extensions.ini 然後你只需要重新啟動 apache 即可,還有把 memcached 服務打開 所以請下底下指令
echo "memcached_enable=\"YES\"" >> /etc/rc.conf /usr/local/etc/rc.d/memcached start /usr/local/etc/rc.d/apache22 restart
- 測試方法: 寫一個php檔案,然後在執行他,範例檔如下
connect('localhost', 11211) or die ("Could not connect"); //Connect Memcached $memcache->set('uname', 'appleboy'); $get_value = $memcache->get('uname'); // echo $get_value; print "如果你需要用 session 寫法,就如下了,這是別人寫好的範例
"; $b = $memcache->getStats(); print_r($b);exit; ?>
connect('localhost', 11211) or die ("Could not connect"); class Shared_Session { function init() { ini_set("session.gc_maxlifetime", 3600); ini_set("session.use_cookies", 1); ini_set("session.cookie_path", "/"); ini_set("session.cookie_domain", ".wu-boy.com"); session_module_name("User"); session_set_save_handler( array("Shared_Session", "open"), array("Shared_Session", "close"), array("Shared_Session", "read"), array("Shared_Session", "write"), array("Shared_Session", "destroy"), array("Shared_Session", "gc") ); } function open($save_path, $session_name) { return true; } function close() { return true; } function read($sesskey) { global $mem_cache_obj; return $mem_cache_obj->get($sesskey); } function write($sesskey, $data) { global $mem_cache_obj; $mem_cache_obj->set($sesskey, $data, 3600); return true; } function destroy($sesskey) { global $mem_cache_obj; $mem_cache_obj->delete($sesskey); $mem_cache_obj->flush_all(); return true; } function gc($maxlifetime = null) { return true; } } Shared_Session::init(); ?>這是利用 memory 存取資料,所以想必一定比妳用 database 或者是檔案存取更快了,但是如果一台機器已經用完記憶體了,所以我們必須新增另一台 memcache server了,所以新增方法如下
addServer('memcache_host', 11211); $memcache->addServer('memcache_host2', 11211); /* procedural API */ $memcache_obj = memcache_connect('memcache_host', 11211); memcache_add_server($memcache_obj, 'memcache_host2', 11211); ?>在網路上找到一篇,有人寫好的 memcache class
php-memcached-client 官網:點我 範例:
array('192.168.1.1:11211'), //memcached 服务的地址、端口,可用多个数组元素表示多个 memcached 服务 'debug' => true, //是否打开 debug 'compress_threshold' => 10240, //超过多少字节的数据时进行压缩 'persistant' => false //是否使用持久连接 ); // 创建 memcached 对象实例 $mc = new memcached($options); // 设置此脚本使用的唯一标识符 $key = 'mykey'; // 往 memcached 中写入对象 $mc->add($key, 'some random strings'); $val = $mc->get($key); echo "n".str_pad('$mc->add() ', 60, '_')."n不過大家可以把 debug mode 關掉,不然畫面會比較亂一點。 再來大家可以跟資料庫連接,然後把SQL讀出來的資料寫到 memcache中 範例:
"; var_dump($val)."
"; // 替换已写入的对象数据值 $mc->replace($key, array('some'=>'haha', 'array'=>'xxx')); $val = $mc->get($key); echo "n".str_pad('$mc->replace() ', 60, '_')."n
"; var_dump($val)."
"; // 删除 memcached 中的对象 $mc->delete($key); $val = $mc->get($key); echo "n".str_pad('$mc->delete() ', 60, '_')."n
"; var_dump($val)."
"; ?>
get($key)) ) { // 在 memcached 中未获取到缓存数据,则使用数据库查询获取记录集。 echo "n".str_pad('Read datas from MySQL.', 60, '_')."n"; $conn = mysql_connect('localhost', 'test', 'test'); mysql_select_db('test'); $result = mysql_query($sql); while ($row = mysql_fetch_object($result)) $datas[] = $row; // 将数据库中获取到的结果集数据保存到 memcached 中,以供下次访问时使用。 $mc->add($key, $datas); } else { echo "n".str_pad('Read datas from memcached.', 60, '_')."n"; } var_dump($datas); ?>reference
非mmcache!Memcached的應用:多網站伺服器 PHP 共享 Session PHP & memcached http://blog.johnpupu.tw/?p=62
See also
- 來聊聊 PHP & JavaScript & CSS 的 Coding Style
- 為什麼我選擇使用 Laravel Framework?
- OpenSSH 安全性漏洞 CVE-2016-0777 and CVE-2016-0778
- Laravel 搭配 Google, Facebook, Twitter 第三方 OAuth 認證
- 將 wordpress 強制使用 SSL 連線
- PHP 7 vs HHVM Benchmark 比較
- Laravel 50 個小技巧 + Laravel 5.2 新功能
- Laravel Homestead 支援 MySQL 5.7 和 Node 5.0
- PHP-FIG 新網站
- Laravel Homestead 支援 PHP 7