1、memcached
(1)windows下memcached的下载与安装
下载地址:http://jehiah.cz/projects/memcached-win32/
下文引用部分摘自:http://jackyoo8.iteye.com/blog/195857
1. 下载memcache的windows稳定版,解压放某个盘下面,比如在c:\memcached
2在终端(也即cmd命令界面)下输入 ‘c:\memcached\memcached.exe -d install’ 安装
3 再输入: ‘c:\memcached\memcached.exe -d start’ 启动。NOTE: 以后memcached将作为windows的一个服务每次开机时自动启动。这样服务器端已经安装完毕了/
4.下载php_memcache.dll,请自己查找对应的php版本的文件
5. 在C:\winnt\php.ini 加入一行 ‘extension=php_memcache.dll’
6.重新启动Apache,然后查看一下phpinfo,如果有memcache,那么就说明安装成功!
memcached的基本设置:
Java代码
1. -p 监听的端口
2. -l 连接的IP地址, 默认是本机e
3. -d start 启动memcached服务
4. -d restart 重起memcached服务
5. -d stop|shutdown 关闭正在运行的memcached服务
6. -d install 安装memcached服务PHPChina
7. -d uninstall 卸载memcached服务
8. -u 以的身份运行 (仅在以root运行的时候有效)
9. -m 最大内存使用,单位MB。默认64MB
10. -M 内存耗尽时返回错误,而不是删除项
11. -c 最大同时连接数,默认是1024
12. -f 块大小增长因子,默认是1.25PHPChina
13. -n 最小分配空间,key+value+flags默认是48
14. -h 显示帮助
-p 监听的端口
-l 连接的IP地址, 默认是本机e
-d start 启动memcached服务
-d restart 重起memcached服务
-d stop|shutdown 关闭正在运行的memcached服务
-d install 安装memcached服务PHPChina
-d uninstall 卸载memcached服务
-u 以的身份运行 (仅在以root运行的时候有效)
-m 最大内存使用,单位MB。默认64MB
-M 内存耗尽时返回错误,而不是删除项
-c 最大同时连接数,默认是1024
-f 块大小增长因子,默认是1.25PHPChina
-n 最小分配空间,key+value+flags默认是48
-h 显示帮助
Memcache环境测试:
运行下面的php文件,如果有输出This is a test!,就表示环境搭建成功。开始领略Memcache的魅力把!
Java代码
1. < ?php
2. $mem = new Memcache;
3. $mem->connect(”127.0.0.1″, 11211);
4. $mem->set(’key’, ‘This is a test!’, 0, 60);
5. $val = $mem->get(’key’);
6. echo $val;
7. ?>
< ?php
$mem = new Memcache;
$mem->connect(”127.0.0.1″, 11211);
$mem->set(’key’, ‘This is a test!’, 0, 60);
$val = $mem->get(’key’);
echo $val;
?>
想使用windows下可以配置的memcached,可以参考下面的链接。
http://www.iteye.com/topic/24505
memcache_client的下载地址:
(2)rails环境配置
下文摘自:http://thegiive.iteye.com/blog/79543
這篇介紹如何將 Memcached 跟 Rails 做一個結合,先介紹一下 Memcached 這個著名的套件。Memcached 是一個分散式的 Memory Object 架構,最早是 Life Journal Team 為了加快速度而開發的套件。 他可以啟動許多 Deamon 來將所有其他 Client 的 Object 都集合起來,並且做到多機器同步化的工作。他最大的優點是在於不需要考慮資料 ACID,所以速度方面相當的快。
當然,我們可以使用 Database 去做到一模一樣的事情,但是其實 Database 在 ACID 上面已經付出太多 Overhaed。如果今天需要操作的東西,是一些像是 Cache ,Session 之類真的不見就算了的東西 的話,你可以考慮使用效率比 Database 快的 Memcached。目前已經有相當多的網站 使 用 Memcached 的技術,可說是相當成熟。並且在 Web Server 使用考量上,Web Server 通常使用資源是高 CPU 低 Memory ,而 Memcached 是低 CPU 高 Memory 的使用方式,兩者可以結合彼此優缺點,讓 Web Server 跟 Memcached 跑在同一台機器上面來避免浪費資源使用率。
以 Ruby on Rails 來看,Memcached 可以用在
- ActionController::Caching::Fragments
- CGI::Session::MemCacheStore
- cached_model for caching ActiveRecord objects
這三個用途。
我 目前使用他都是在 Session Store 這個部分,他可以將 Multi Backend Application Server 的 Session 存放放在同一處,當然可以提高Rails Scaling 的部分。而在實做上面,Memcache 沒有設定檔。要在 Master 啟動一個 2G Memory,listen 在 1.2.3.4 ,port 11211 的 Memcache Deamon 是這樣啟動的
# ./memcached -d -m 2048 -l 1.2.3.4 -p 11211Ruby 要使用 Memcached 是非常的簡單,只要用 Gem 安裝 Ruby 的 Memcached Client 即可。
這裡有兩個選擇,一個是出現在很多書上面的 ruby memcache ,也是比較老牌的選擇。
gem i ruby-memcache但是現在還有更新的選擇, Robotcoop 所開發的 Ruby Memcached Client AP
# gem install memcache-client
要 選擇其實是很容易的,因為兩者的 API 實做都一模一樣,應該說 memcached-client 遵照 ruby-memcached 的 API,但是 memcached-client 效能比 ruby-memcached 來得好,所以請用 memcached-client 吧。
要在 Rails 上面使用 Memcached 來當作 Session Handler 也相當的簡單,將 session store 設為 memcached 即可。你可以在 enviroment.rb 加入
require 'memcache' memcache_options = { :compression => false, :debug => false, :namespace => "app-#{RAILS_ENV}", :readonly => false, :urlencode => false } memcache_servers = [ 'localhost:11211' ] Rails::Initializer.run do |config| .... config.action_controller.session_store = :mem_cache_store config.action_controller.cache_store = :mem_cache_store, memcache_servers, memcache_options end ... cache_params = *([memcache_servers, memcache_options].flatten) CACHE = MemCache.new *cache_params ActionController::CgiRequest::DEFAULT_SESSION_OPTIONS.merge!({ 'cache' => CACHE })
其實 Rails 對於 Scale 的準備還算是相當的完整,很多地方都有相當簡單方便的實做。
延伸閱讀
- Memcached 官方網頁
- Rails Wiki:Memcached
- Rails Wiki:HowtoChangeSessionStore
不只介紹 Ruby Memcached,還介紹 ActiveRecordStore 等用法 - 使用memcached进行内存缓存
iveJournal.com使用了memcached在前端进行缓存,取得了良好的效果,而像wikipedia,sourceforge等也采用了或即将采用memcached作为缓存工具。memcached可以大规模网站应用发挥巨大的作用。
- dev.robotcoop.com / Libraries
不只有 Ruby Memcached API ,還介紹一些其他的 MongileFS API - Ruby Memcached API
2、timed_fragment_cache
git上的通通不能用了,有个尸体:http://github.com/rlivsey/timed_fragment_cache/tree/master
想找能用的,需要从这个网址下载:http://www.ruzee.com/blog/2008/07/timed_fragment_cache-on-rails-21/ 注意找到“Download version 0.2 ”下载即可。
使用方法:
controller中,
when_fragment_expired 'homepage_lines', 30.minutes.from_now do
view中,
<% cache('homepage_lines') do -%>
参照以上内容,就可以实现windows平台下基于时间过期策略的片断缓存。
最后,提供一个rails中的各种缓存方案的链接。
真实世界中的 Rails: Rails 中的缓存:
http://www.ibm.com/developerworks/cn/web/wa-rails1/
memcached完全剖析:
http://blog.youkuaiyun.com/starxu85/archive/2008/09/30/3002436.aspx
全文完
------------------------