Maison > base de données > tutoriel mysql > le corps du texte

CentOS 5.9下安装配置memcached

WBOY
Libérer: 2016-06-07 16:32:54
original
1100 Les gens l'ont consulté

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

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

一:安装memcached

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

<code class="python">tar zxf libevent-1.4.13-stable.tar.gz
cd libevent-1.4.13-stable
./configure
make && make install
</code>
Copier après la connexion

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>
Copier après la connexion

二:配置memcached

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

<code class="python">/usr/local/memcached/bin/memcached -d -m 20 -u root -l 127.0.0.1 -p 11211
</code>
Copier après la connexion

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>
Copier après la connexion

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>
Copier après la connexion

三:使用memcached

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>
Copier après la connexion

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>
Copier après la connexion

四:是时候结束了

自言自语:

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

参考资料:

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

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

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal