成都网站建设设计

将想法与焦点和您一起共享

Memcache服务搭建-创新互联

Memcache

创新互联公司从2013年开始,是专业互联网技术服务公司,拥有项目成都网站设计、成都做网站网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元漳州做网站,已为上家服务,为漳州各地企业和个人服务,联系电话:13518219792

Memcache的作用网上资料都讲的很好,说简单点就是减轻读取数据库的压力,原理也很简单:

被请求的数据会先到memcache里去取,如果没有就去数据库里取,顺便给memcache带一份。

每次更新数据也先更新memcache里的数据,如果没有则更新数据库,同时更新memcache。

因此需要注意的是这个数据是易失去性存储的。

模式和端口

Memcache是一个基于C/S的结构:

     服务端:使用Memcached软件

客户端:使用Memcache插件 (这个插件是结合后端语言比如php python java)

服务端口:11211(可改)

软件清单:

libevent依赖库      http://www.libevent.org/   

  memcache插件       http://pecl.php.net/package/memcache/

memcached服务        http://www.memcached.org/

  lamp环境          yum -y install httpd php php-mysql mysql-server

     操作系统                         CentOS-6.5(x86_64)

1.将上传相关软件包,安装lamp环境

      yum -y install httpd php php-mysql mysql-server      /etc/init.d/httpd start      echo "" > /var/www/html/index.php

     然后用浏览器访问查看php信息,在信息里面是找不到memcache的

Memcache服务搭建

2.安装libevent插件

  tar xf libevent-2.0.22-stable.tar.gz

  cd libevent-2.0.22-stable

     ./configure --prefix=/usr/local/libevent && make && make install

3.安装memcached服务端

Memcache服务搭建

  tar xf memcached-1.4.36.tar.gz

  cd memcached-1.4.36  ./configure --prefix=/usr/local/memcached --with-libevent=/usr/local/libevent/

  make && make install

Memcache服务搭建

  安装好后会在/usr/local/memcached/bin/目录下生成memcached

4.配置环境变量

Memcache服务搭建

  cd  /etc/profile.d/ 

  vim mem.sh  export PATH="/usr/local/memcached/bin:$PATH"  #写入profile文件开机自动导入  memcached -m 32 -p 11211 -d -c 8192 -u root   #m分出内存大小 p 端口 d 混合模式 c 大连接数  netstat -anptu | grep memcached        #查看是否启动,运行多实例更改端口即可  free -m                      #可以看到内存越来越少,因为被分配出去了  ps -aux | grep memcached            #查看进程pid是多少  kill -9 1234                   #关闭memcached服务

   pkill memcached                  #同上

Memcache服务搭建

5.memcached使用

  yum -y install nc telnet

    1)使用nc命令连接memcache

   printf "set first 0 30 5\r\nmmmmm\r\n" | nc 127.0.0.1 11211   #存数据 (字段分别为 key,标志,效期,长度,值 )  printf "get first\r\n" | nc 127.0.0.1 11211            #取数据

  2)使用telnet命令连接memcache

  telnet 127.0.0.1 11211    #然后就可以使用相关的memcached命令了

6.下面是关于memcached相关的操作命令

  

   add key1 0 30 3   #添加数据30为效期(如果写0表示永不过期) 3为大小

  set key1 0 30 3   #更新数据,不存在会自动创建

  replace key1 0 30 3 #更新数据,不存在会报错

  delete key1     #删除数据

  get key1       #获取数据

  gets key 1      #获取更多信息

  stats setting    #查看配置信息

  stats slabs     #查看slab

  stats items     #查看item

  stats size      #查看大小

7.安装memcache客户端php插件

  安装phpize命令可以为php添加新模块

  如果不知道是什么包可以使用 yum provides */phpize

Memcache服务搭建

  yum -y install php-devel

  tar xf memcache-2.2.7.tgz

  cd memcache-2.2.7  phpize          #打模块,生成configure等文件  which php-config      #查看php-config路径位置  ./configure --enable-memcache --with-php-config=/usr/bin/php-config

  make && make install

Memcache服务搭建

  安装号后模块会被安装置/usr/lib64/php/modules/memcache.so

  cd /etc/php.d/

  cp mysql.ini memcache.ini  #vim进行编辑将extension的值设置成memcache.so

  重启服务后可以看到php已经支持了memcache模块了

  Memcache服务搭建

8.后面可以结合php网站测试数据库相关

  tar xf memcache_page.tar.gz -C /var/www/html/  cd !$

Memcache服务搭建

测试页面有 mysql_connect.php 编辑一下

      Memcache服务搭建

因此需要先把mysql的用户设置一下

  /etc/init.d/mysqld  start

  mysql_secure_installation

或者自己在数据库里

  grant all on *.* to 'root'@'127.0.0.1' identified by '123456'  flush privileges

然后浏览器访问mysql_connect.php

 Memcache服务搭建

对接成功

这里可以阅读read.php和write.php了解memcache的读写原理

read.php

Memcache服务搭建

connect($memcachehost,$memcacheport) or die ("Could not connect");  #连接memcache服务器$num=$_POST["num"];$db=db1;$tb=T1;$query="select * from $tb where ID=$num";  #mysql查询语句#$key=md5($query);$key=md5($num);                  #对参数进行加密,可以看出memcache存储的值是进过加密的if(!$memcache->get($key))            #尝试先从memcache取值,如果没有去数据库取,顺便给memcache来一份{                $conn=mysql_connect("127.0.0.1","root","123456");                mysql_select_db($db);                $result=mysql_query($query);#       echo "mysql $num";
                while ($row=mysql_fetch_assoc($result))
                {                        $arr[]=$row;
                }                $f = 'mysql';                $memcache->add($key,serialize($arr),0,30);                $data = $arr ;
}else{        $f = 'memcache';        $data_mem=$memcache->get($key);        $data = unserialize($data_mem);
}echo "$f $num";echo "key is $key";echo "
";?>

Memcache服务搭建

write.php

Memcache服务搭建

connect($memcachehost,$memcacheport) or die ("Could not connect");$num=$_POST["num"];$db=db1;$tb=T1;$query="insert into $tb values($num)";#$key=md5($query);$key=md5($num);if(!$memcache->get($key))            //先尝试更新memcache,如果不存在,则再去更新数据库,同时更新存储到memcachce{                $conn=mysql_connect("127.0.0.1","root","123456");                mysql_select_db($db);                $result=mysql_query($query);                while ($row=mysql_fetch_assoc($result))
                {                        $arr[]=$row;
                }                $f = 'mysql';                $memcache->add($key,serialize($arr),0,30);        //mysql 插入成功后,插入 memcached
                $data = $arr ;#}#else{
        $f1 = 'memcache';        $data_mem=$memcache->get($key);        $data = unserialize($data_mem);
}echo "$f $f1 $num";echo "
";?>

Memcache服务搭建

 关于php memcache简单用法参见http://www.cnblogs.com/demonxian3/p/6868361.html

 上面两个php里可以看到调用了数据库的db1 和 表T1因此需要创建一下

  seq 1 999 > /tmp/sum  #创建1-999的测试数据

 连接数据库导入数据

  create database db1; create T1(id int)engine=innodb;  load data infile '/tmp/sum' into table T1;  #导入测试数据

科普一下:使用history查看历史命令,输入!+数字可以执行编号的那条命令

  !111

用浏览器来访问那个测试页面

Memcache服务搭建

   测试读取数据,从数据库里查询出id为5的值

     Memcache服务搭建

     Memcache服务搭建

后退再去取一次

    Memcache服务搭建

测试写入数据

    Memcache服务搭建

    Memcache服务搭建

最后给大家推荐一款很好用的memcache管理工具:memadmin   php写的

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


当前名称:Memcache服务搭建-创新互联
文章来源:http://chengdu.cdxwcx.cn/article/cdegoj.html