Rumah > Artikel > pangkalan data > CentOS 5.9下安装配置memcached
第一次听说memcached应该是我大三的时候吧,那时很傻很天真,听说网站用了memcached缓存后速度就会很快,具体为什么快,怎么快,就不得而知了。如今再看memcached,已经毫无当年的新鲜感。如果,让我选择,我宁愿选择新兴的redis。 一:安装memcached 1 安装
第一次听说memcached应该是我大三的时候吧,那时很傻很天真,听说网站用了memcached缓存后速度就会很快,具体为什么快,怎么快,就不得而知了。如今再看memcached,已经毫无当年的新鲜感。如果,让我选择,我宁愿选择新兴的redis。
1 安装前的准备工作,解决依赖关系啊
<code class="python">tar zxf libevent-1.4.13-stable.tar.gz cd libevent-1.4.13-stable ./configure make && make install </code>
2.安装memcached
<code class="python">tar zxf memcached-1.4.5.tar.gz cd memcached-1.4.5 ./configure --prefix=/usr/local/memcached make && make install 有时会提示找不到libevent库文件,解决办法是把/usr/local/lib加入到/etc/ld.so.conf中,过程如下: echo "/usr/local/lib" >> /etc/ld.so.conf ldconfig </code>
1 相信我,真的没啥配置的,直接加参数启动memcached
<code class="python">/usr/local/memcached/bin/memcached -d -m 20 -u root -l 127.0.0.1 -p 11211 </code>
2 参数简单介绍
<code class="python">-p <num> 设置端口号(默认不设置为: 11211) -U <num> UDP监听端口 (默认: 11211, 0 时关闭) -l <ip_addr> 绑定地址 (默认:所有都允许,无论内外网或者本机更换IP,有安全隐患,若设置为127.0.0.1就只能本机访问) -d 独立进程运行 -u <username> 绑定使用指定用于运行进程 <username> -m <num> 允许最大内存用量,单位M (默认: 64 MB) -P <file> 将PID写入文件<file>,这样可以使得后边进行快速进程终止, 需要与 -d 一起使用 </file></file></num></username></username></ip_addr></num></num></code>
3 注意,这是个坑.
<code class="python">memcached slab中item的大小默认是1M,也就是缓存的对象不能超过1M;可以使用-I参数修改,例如修改为4M /usr/local/memcached/bin/memcached -d -I 4M -m 20 -u root -l 127.0.0.1 -p 11211 当然了,他肯定会提示你这样做是不好的,内存得不到最大利用(具体看下memcached的介绍) WARNING: Setting item max size above 1MB is not recommended! Raising this limit increases the minimum memory requirements and will decrease your memory efficiency. </code>
1 作为一个运维,不知道开发是怎么使用memcached,有些说不过去吧...
请先安装php下memcached客户端,上篇博客安装lnmp时已经安装过了,具体安装参考(http://pecl.php.net/package/memcache)
<code class="python"><?php //实例化一个memcache对象 $mem=new Memcache; //链接一台memcahe服务 $mem->connect('localhost','11211'); //准备SQL语句 $sql="select * from yunbbs_users limit 1"; //设置一个键名 $key=md5($sql); $data=$mem->get($key); //第二次之后的查询 if(!$data){ try{ //连接mysql服务器 $link=mysql_connect('localhost','root','mumayi') or die("Could not connect: ".mysql_error()); //选择数据库 mysql_select_db("yunbbs") or die("Could not select databases"); //使用mysql_query()函数执行sql语句 $result=mysql_query($sql,$link) or die("Query failed:".mysql_error()); //就一条记录,直接一个数组就取出来了,不用while循环去取了 $data=mysql_fetch_array($result); //把数据存储到memcache中(第一次查询) $mem->add($key,$data); //释放$result变量 mysql_free_result($result); //释放数据库连接池 mysql_close($link); } catch(Exception $e){ echo "error"; } } $mem->close(); print_r($data); ?> 执行下试试,看下输出结果对不(必须没问题呀): [root@printserver code_segment]# /usr/local/php_fpm/bin/php php_memcached.php Array ( [0] => 1 [id] => 1 [1] => budong [name] => budong [2] => 99 [flag] => 99 [3] => 0 [avatar] => 0 [4] => 310a78f8774f512015a5079588ad7a02 [password] => 310a78f8774f512015a5079588ad7a02 [5] => [email] => [6] => [url] => [7] => 2 [articles] => 2 [8] => 4 [replies] => 4 [9] => 1369230177 [regtime] => 1369230177 [10] => 1372822269 [lastposttime] => 1372822269 [11] => 1375365466 [lastreplytime] => 1375365466 [12] => [about] => [13] => [notic] => ) </code>
2 作为一个运维,你偶尔也需要看下memcached的运行状态吧
<code class="python">请先从11211端口telnet进去,再输入stats看下memcached的详细信息 telnet 127.0.0.1 11211 stats 部分结果如下: [root@printserver ~]# telnet 127.0.0.1 11211 Trying 127.0.0.1... Connected to printserver (127.0.0.1). Escape character is '^]'. stats STAT pid 18340 STAT uptime 3853 STAT time 1384702689 STAT version 1.4.5 STAT pointer_size 64 ... </code>
自言自语:
上篇博客,现在还是马马虎虎来了个未完待续,新篇又是这样草草结束,感觉有些对不起自己。忙碌不应该是自己的借口,得逼自己一下了,连写篇博客都这么难,以后还能做什么呢?
参考资料:
memcached 官网:http://memcached.org/
memcached 最佳实践方案:http://sunbean.blog.51cto.com/972509/786174
原文地址:CentOS 5.9下安装配置memcached, 感谢原作者分享。