高性能内存对象缓存Memcached

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了高性能内存对象缓存Memcached相关的知识,希望对你有一定的参考价值。

高性能内存对象缓存Memcached

Memcached简介

Memcached时一台开源的高性能分布式内存对象缓存系统,他将所有的数据都存储在内存中,因为在内存中会同意维护一张巨大而Hash表,所以支持任意存储类型的数据

1、学会安装Memcacahed服务

1.1安装Libevent

Libevent是一款跨平台的事件处理接口的封装,可以兼容多个操作系统的事件访问。Memcached的安装依赖于Libevent,因此需要先完成Libevent的安装。

挂载源代码包

[[email protected] ~]# mount.cifs //192.168.32.1/gongxiang /abc/
Password for [email protected]//192.168.32.1/gongxiang:  
[[email protected] ~]# cd /abc/
[[email protected] abc]# ls
all_locales-1.4.18-20090526.tar.gz   magent-0.5.tar.gz
apachenk                             memcache-2.2.7.tgz
apache.sh                            memcached-1.5.6.tar.gz
apr-1.4.6.tar.gz                     mongodb-linux-x86_64-rhel70-4.0.0.tgz
apr-1.5.0.tar.gz                     mysql
apr-util-1.4.1.tar.gz                mysql-5.5.24.tar.gz
apr-util-1.5.4.tar.gz                nginx-1.15.0.tar.gz
awstats-7.0.zip                      nginx-1.2.8.tar.gz
awstats-7.6.tar.gz                   nginx-1.6.0.tar.gz
dage.jpg                             openssl-1.0.1c.tar.gz
dage.jpg.jpg                         pcre-8.39.tar.gz
desktop.ini                          php
Discuz_X2.5_SC_UTF8.zip              php-5.4.5.tar.bz2
dnf-dnf-1.1.7-1.tar.gz               pxe.sh.txt
epel-release-latest-7.noarch.rpm     Red Hat Enterprise 6.5 x86_64.iso
game.jpg                             rhel-server-7.3-x86_64-dvd.iso
gd-2.0.35.tar.gz                     sarg-2.3.7.tar.gz
hping-2.0.0-1.rc3.2.el6.rf.i686.rpm  shell.sh.txt
httpd-2.4.2.tar.gz                   snmpd.conf.txt
httpd-2.4.33.tar.gz                  squid-4.1.tar.gz
inotify-tools-3.14.tar.gz            squirrelmail-webmail-1.4.22.tar.gz
john-1.8.0.tar.gz                    xy.jpg
john,mimapojie                       ZendGuardLoader-php-5.3-linux-glibc23-i386.tar.gz
libevent-2.1.8-stable.tar.gz         ZendOptimizer-3.3.0a-linux-glibc21-i386.tar.gz
LNMP
[[email protected] ~] tar xf libevent-2.1.8-stable.tar.gz -C /opt/
[[email protected] libevent-2.1.8-stable] ./configure -prefix/-s/loca//ibeve
[[email protected] libevent-2.1.8-stable] make && make install

1.2安装Memccached
采用源代码的方式进行Memcached的编译安装,安装时指定Libevent的安装路径

[[email protected] ~] tar xf memcached-1.5.6.tar.gz -C /opt/
[[email protected] libevent-2.1.8-stable]# cd /opt/memcached-1.5.6/
[[email protected] memcached-1.5.6]# ./configure > --prefix=/usr/local/memcached > --with-libevent=/usr/local/libevent/
[[email protected] ~] make && make install

#将Memcached自带的命令建立一个软连接让系统能够识别
[[email protected] memcached-1.5.6] ln -s /usr/local/memcached/bin/* /usr/local/bin/

#其中启动Memcached时,-d选项的作用是以守护进程的方式运行Memcached服务;-m是为Memcached分配为32MB的内存,应根据企业需要进行调整: -u 指定运行的用户账号
[[email protected] memcached-1.5.6] memcached -d -m 32m -p 11211 -u root

查看端口进程有没有开启

[[email protected] memcached-1.5.6] netstat -ntap | grep memc
tcp        0      0 0.0.0.0:11211           0.0.0.0:*               LISTEN      21394/memcached     
tcp6       0      0 :::11211                :::*                    LISTEN      21394/memcached  

#关闭防火墙
[[email protected] ~] systemctl stop firewalld.service
[[email protected] ~] setenforce 0

2.1 Memcached API客户端

为了使得程序可以直接调用Memcached库和接口,
可以使用Memcached扩展组
件将Memcached添加为PHP的一个模块。此扩展使用了Libmemcached库提供的API与Memcached服务端进行交互

安装autoconf

[[email protected] ~]# yum install autoconf -y

解压Memcache安装包

[[email protected] ~]# tar zxvf /abc/memcache-2.2.7.tgz -C /opt/
package.xml
memcache-2.2.7/config.m4
memcache-2.2.7/config9.m4
memcache-2.2.7/config.w32
memcache-2.2.7/CREDITS
memcache-2.2.7/example.php
memcache-2.2.7/memcache.c
memcache-2.2.7/memcache_queue.c
memcache-2.2.7/memcache_session.c
memcache-2.2.7/memcache_standard_hash.c
memcache-2.2.7/memcache_consistent_hash.c
memcache-2.2.7/memcache.dsp
memcache-2.2.7/php_memcache.h
memcache-2.2.7/memcache_queue.h
memcache-2.2.7/README
memcache-2.2.7/memcache.php

#进入Memcache文件
[[email protected] ~] cd /opt/memcache-2.2.7/

#我们想编译安装的话要用到configure但是Memcache客户端文件里面没有configure配置文件所以就要用到php里面的configure配置模块
[[email protected] memcache-2.2.7] ls
acinclude.m4    config.h.in   CREDITS          memcache_consistent_hash.c  memcache_standard_hash.c
aclocal.m4      config.m4     example.php      memcache.dsp                missing
autom4te.cache  config.sub    install-sh       memcache.php                mkinstalldirs
build           configure     ltmain.sh        memcache_queue.c            php_memcache.h
config9.m4      configure.in  Makefile.global  memcache_queue.h            README

#直接运行php里面bin文件里面phpize配置
[[email protected] memcache-2.2.7]# /usr/local/php/bin/phpize 
Configuring for:
PHP Api Version:         20121113
Zend Module Api No:      20121212
Zend Extension Api No:   220121212
[[email protected] memcache-2.2.7]# ls
acinclude.m4    config.h.in   CREDITS          memcache_consistent_hash.c  memcache_standard_hash.c
aclocal.m4      config.m4     example.php      memcache.dsp                missing
autom4te.cache  config.sub    install-sh       memcache.php                mkinstalldirs
build           configure     ltmain.sh        memcache_queue.c            php_memcache.h
config9.m4      configure.in  Makefile.global  memcache_queue.h            README
config.guess    config.w32    memcache.c       memcache_session.c          run-tests.php

#再编译运行configure
[[email protected] memcache-2.2.7]# ./configure --enable-memcache --with-php-config=/usr/local/php/bin/php-config
[[email protected] memcache-2.2.7]# make && make install
Installing shared extensions:     /usr/local/php/lib/php/extensions/no-debug-non-zts-20121212/
#make install运行后会有一段路径显示出来如上记住如上的路径

进入php底下php.ini配置文件,搜索并修改下面一行,再新增一行(如果没有就在解压包下执行cp php.ini-development /usr/local/php5/php.ini

ln -s /usr/local/php5/bin/* /usr/local/bin/

ln -s /usr/local/php5/sbin/* /usr/local/sbin/)

用客户端连接测试

vi /usr/local/httpd/htdocs/index.php //编写测试页面,测试memcached工作是否正常

<?php
$memcache = new Memcache();
$memcache->connect(‘192.168.175.128‘,11211);
$memcache->set(‘key‘,‘Memcache test Successfull!‘,0,60);
$result = $memcache->get(‘key‘);
unset($memcache);
echo $result;
?>

http://192.168.32.152/index.php //输入客户端地址测试是否成功

以上是关于高性能内存对象缓存Memcached的主要内容,如果未能解决你的问题,请参考以下文章

高性能内存对象缓存Memcached

Memcached高性能内存对象缓存系统

在CentOS7上部署Memcached高性能内存缓存对象

在LAMP架构中安装Memcached高性能内存对象缓存应用(内含所有源码包)

高性能内存对象缓存Memcached安装及数据库操作与管理

高性能的分布式内存对象缓存系统--Memcached详解