当前位置:Gxlcms > mysql > CentOS5.9下安装配置memcached

CentOS5.9下安装配置memcached

时间:2021-07-01 10:21:17 帮助过:30人阅读

第一次听说memcached应该是我大三的时候吧,那时很傻很天真,听说网站用了memcached缓存后速度就会很快,具体为什么快,怎么快,就不得而知了。如今再看memcached,已经毫无当年的新鲜感。如果,让我选择,我宁愿选择新兴的redis。 一:安装memcached 1 安装

第一次听说memcached应该是我大三的时候吧,那时很傻很天真,听说网站用了memcached缓存后速度就会很快,具体为什么快,怎么快,就不得而知了。如今再看memcached,已经毫无当年的新鲜感。如果,让我选择,我宁愿选择新兴的redis。

一:安装memcached

1 安装前的准备工作,解决依赖关系啊

tar zxf libevent-1.4.13-stable.tar.gz
cd libevent-1.4.13-stable
./configure
make && make install

2.安装memcached

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

二:配置memcached

1 相信我,真的没啥配置的,直接加参数启动memcached

/usr/local/memcached/bin/memcached -d -m 20 -u root -l 127.0.0.1 -p 11211

2 参数简单介绍

-p  设置端口号(默认不设置为: 11211) 
-U  UDP监听端口 (默认: 11211, 0 时关闭) 
-l  绑定地址 (默认:所有都允许,无论内外网或者本机更换IP,有安全隐患,若设置为127.0.0.1就只能本机访问) 
-d 独立进程运行
-u  绑定使用指定用于运行进程  
-m  允许最大内存用量,单位M (默认: 64 MB) 
-P  将PID写入文件,这样可以使得后边进行快速进程终止, 需要与 -d 一起使用

3 注意,这是个坑.

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.

三:使用memcached

1 作为一个运维,不知道开发是怎么使用memcached,有些说不过去吧...

请先安装php下memcached客户端,上篇博客安装lnmp时已经安装过了,具体安装参考(http://pecl.php.com/package/memcache)

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] => )

2 作为一个运维,你偶尔也需要看下memcached的运行状态吧

请先从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
...

四:是时候结束了

自言自语:

上篇博客,现在还是马马虎虎来了个未完待续,新篇又是这样草草结束,感觉有些对不起自己。忙碌不应该是自己的借口,得逼自己一下了,连写篇博客都这么难,以后还能做什么呢?

参考资料:

memcached 官网:http://memcached.org/

memcached 最佳实践方案:http://sunbean.blog.51cto.com/972509/786174

人气教程排行