linux下安装memcache

    技术2022-05-19  26

    memcache一点点积累

    什么是memcache 为什么要用:

    Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像视频文件以及数据库检索的结果等。Memcachedanga的一个项目,最早是LiveJournal 服务的,最初为了加速 LiveJournal 访问速度而开发的,后来被很多大型的网站采用。

    Memcache安装的过程

    服务器端主要是安装memcache服务器端,目前的最新版本是 memcached-1.3.0 下载:http://www.danga.com/memcached/dist/memcached-1.2.2.tar.gz另外,Memcache用到了libevent这个库用于Socket的处理,所以还需要安装libeventlibevent的最新版本是libevent-1.3。(如果你的系统已经安装了libevent,可以不用安装)官网:http://www.monkey.org/~provos/libevent/下载:http://www.monkey.org/~provos/libevent-1.3.tar.gz

    wget指令直接下载这两个东西.下载回源文件后。1.先安装libevent。这个东西在配置时需要指定一个安装路径,即./configure –prefix=/usr;然后make;然后make install2.再安装memcached,只是需要在配置时需要指定libevent的安装路径即./configure –with-libevent=/usr;然后make;然后make install这样就完成了LinuxMemcache服务器端的安装。详细的方法如下:

    1.分别把memcachedlibevent下载回来,放到 /tmp 目录下:# cd /tmp# wget http://www.danga.com/memcached/dist/memcached-1.2.0.tar.gz# wget http://www.monkey.org/~provos/libevent-1.2.tar.gz

    2.先安装libevent# tar zxvf libevent-1.2.tar.gz# cd libevent-1.2# ./configure –prefix=/usr# make# make install

    3.测试libevent是否安装成功:# ls -al /usr/lib | grep libeventlrwxrwxrwx 1 root root 21 11?? 12 17:38 libevent-1.2.so.1 -> libevent-1.2.so.1.0.3-rwxr-xr-x 1 root root 263546 11?? 12 17:38 libevent-1.2.so.1.0.3-rw-r–r– 1 root root 454156 11?? 12 17:38 libevent.a-rwxr-xr-x 1 root root 811 11?? 12 17:38 libevent.lalrwxrwxrwx 1 root root 21 11?? 12 17:38 libevent.so -> libevent-1.2.so.1.0.3还不错,都安装上了。

    4.安装memcached,同时需要安装中指定libevent的安装位置:# cd /tmp# tar zxvf memcached-1.2.0.tar.gz# cd memcached-1.2.0# ./configure –with-libevent=/usr# make# make install如果中间出现报错,请仔细检查错误信息,按照错误信息来配置或者增加相应的库或者路径。安装完成后会把memcached放到 /usr/local/bin/memcached

    5.测试是否成功安装memcached# ls -al /usr/local/bin/mem*-rwxr-xr-x 1 root root 137986 11?? 12 17:39 /usr/local/bin/memcached-rwxr-xr-x 1 root root 140179 11?? 12 17:39 /usr/local/bin/memcached-debug

    安装MemcachePHP扩展1.http://pecl.php.net/package/memcache 选择相应想要下载的memcache版本。2.安装PHPmemcache扩展

    tar vxzf memcache-2.2.1.tgzcd memcache-2.2.1/usr/local/php/bin/phpize./configure --enable-memcache --with-php-config=/usr/local/php/bin/php-config --with-zlib-dir

     make install

    3.上述安装完后会有类似这样的提示:

    Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-2007xxxx/

    4.php.ini中的extension_dir = “./”修改为

    extension_dir = “/usr/local/php/lib/php/extensions/no-debug-non-zts-2007xxxx/”

    5.添加一行来载入memcache扩展:extension=memcache.so

    memcached的基本设置1.启动Memcache的服务器端:# /usr/local/bin/memcached -d -m 10 -u root -l 192.168.0.200 -p 12000 -c 256 -P /tmp/memcached.pid

    -d选项是启动一个守护进程,-m是分配给Memcache使用的内存数量,单位是MB,我这里是10MB-u是运行Memcache的用户,我这里是root-l是监听的服务器IP地址,如果有多个地址的话,我这里指定了服务器的IP地址192.168.0.200-p是设置Memcache监听的端口,我这里设置了12000,最好是1024以上的端口,-c选项是最大运行的并发连接数,默认是1024,我这里设置了256,按照你服务器的负载量来设定,-P是设置保存Memcachepid文件,我这里是保存在 /tmp/memcached.pid

    2.如果要结束Memcache进程,执行:

    # kill `cat /tmp/memcached.pid`

    也可以启动多个守护进程,不过端口不能重复。

    3.重启apacheservice httpd restart

    Memcache环境测试运行下面的php文件,如果有输出This is a test!,就表示环境搭建成功。开始领略Memcache的魅力把!< ?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;?>

    //如何检查memcached是否还在运行 ps -ef | grep memcached

    如何开机自启动

     vi /etc/rc.local

    如何查看有多少个客户端在连接

    netstat -an | grep 11211 | wc -l

    memcache已经启动了,但是php还是无法连接memcache服务器?

    system-config-securitylevel-tui

    SELinux的选项disabled掉,保存退出,再看看应该可以连上了。

    DEBUG

    LD_DEBUG=libs /usr/local/bin/memcached -vmemcache方法的一些说明

    Memcache::add — 添加一个值,如果已经存在,则返回false Memcache::set方法类似.区别是如果 Memcache::add方法的返回值为false,表示这个key已经存在,而Memcache::set方法则会直接覆写。Memcache::addServer — 添加一个可供使用的服务器地址.8个参数,除了第一个参数意外,其他都是可选的,第一个参数表示服务器的地址,第二个参数表示端口,第三个参数表示是否是一个持久连接,第四个参数表示这台服务器在所有服务器中所占的权重,第五个参数表示连接的持续时间,第六个参数表示连接重试的间隔时间,默认为15,设置为-1表示不进行重试,第七个参数用来控制服务器的在线状态,第8个参数允许设置一个回掉函数来处理错误信息。Memcache::close — 关闭一个Memcache对象Memcache::connect — 创建一个Memcache对象memcache_debug — 控制调试功能 前提是php在编译的时候使用了–enable-debug选项,否则这个函数不会有作用。Memcache::decrement — 对保存的某个key中的值进行减法操作Memcache::delete — 删除一个key.第一个参数表示key ,第二个参数可选,表示删除延迟的时间。Memcache::flush — 清除所有缓存的数据Memcache::get — 获取一个key值 有一个参数 表示keyMemcache::getExtendedStats — 获取进程池中所有进程的运行系统统计Memcache::getServerStatus — 获取运行服务器的参数Memcache::getStats — 返回服务器的一些运行统计信息 有三个参数,第一个参数表示要求返回的类型:reset, malloc, maps, cachedump, slabs, items, sizes;第二个参数和第三个参数是在第一个参数设置为“cachedump”时使用的。Memcache::getExtendedStats方法的作用是获取进程池中所有进程的运行系统统计。Memcache::getVersion — 返回运行的Memcache的版本信息Memcache::increment — 对保存的某个key中的值进行加法操作Memcache::pconnect — 创建一个Memcache的持久连接对象Memcache::replace — R对一个已有的key进行覆写操作 有四个参数,作用和方法的相同。Memcache::set — 添加一个值,如果已经存在,则覆写Memcache::setCompressThreshold — 对大于某一大小的数据进行压缩Memcache::setServerParams — 在运行时修改服务器的参数

    呵呵以上就这么多了,注意不要用php脚本执行,apache加载执行.我用的是nginx.

    实在不行可以参考这个文献,个人感觉不错http://www.indang.net/html/php-memcache-finishing.html


    最新回复(0)