1.缓存数据库

缓存:将数据存储在内存中,只有当磁盘胜任不了的时候,才会启用缓存。
缺点:断电数据丢失(双电),用缓存存储数据的目的只是为了应付大并发的业务,至于数据存储及可靠性不要找他了。
 
数据库:mysql(关系型数据库,能够保证数据一致性,保证数据不丢失,但是因为功能太多,导致性能不高)====》数据仓库
缓存数据库: memcache、redis(非关系型数据库,性能极高,但是不保证数据完整)===》业务的数据提供者
 

2. 缓存数据库使用场景

2.1 作为数据库的缓存

当数据库(mysql)承受不了大并发的请求时,可以将数据缓存到内存中(缓存数据库),然后就可以解决。

2.2 会话共享

场景:只要登录了网站,以后访问这个网站任何页面都不要登录了。
为什么服务器知道你是谁?

3. 安装使用memcache

3.1 Memcached简介

Memcached是一款开源的、高性能的纯内存缓存服务软件。Mem是内存的意思,cache是缓存的意思,d是daemon的意思。
 
Memcache是项目的名字,诞生于2003年。Memcache服务分为客户端和服务端两部分,C/S架构。
-客户端软件memcache-2.25.tar.gz
-服务端软件memcached-1.4.13.tar.gz
 
http://www.cnblogs.com/Csir/p/6711305.html

3.2 Memcached原理及优点

在启动Memcached时,根据指定的内存大小参数,会被分配一个内存空间。当我们读取数据库的各类业务数据后,数据会同时放入Memcached缓存中,当下一次用户请求同样的数据,程序直接去Memcached取数据返回给用户。
优点:
①对于用户来讲,用户访问网站更快了,体验更好了。
②对网站来说,数据库压力降低了。只有当内存没有数据时才会去请求数据库。第一次写入的数据也会请求数据库。一般公司没有预热,只有当用户读取过数据库才会放到Memcached中。
③提升了网站的并发访问,减少服务器数量。
 
 
企业案例:当机房断电,如何开启web服务器、memcached缓存服务器、数据库服务器的?
开机顺序:先开启数据库,再开启缓存,然后预热缓存数据库,最后开启web服务器。如果不预热缓存数据库,当开启web后大量的访问流入MySQL,造成的结果是MySQL启动不了,一开就挂。
 
如何正确关闭网站集群服务器?从前端往后端依次关闭。
如何正确开启网站集群服务器?从后端依次往前端开启,缓存服务器要预热。
 

3.4 安装memcached

yum -y install memcached
 

3.5 启动memcached

[root@Memcached ~]# memcached -h
 
-p <num> 指定监听端口 TCP port number to listen on (default: 11211)
-l <addr> 绑定监听的网卡 interface to listen on (default: INADDR_ANY, all addresses) 
-d run as a daemon # 后台运行
-u <username> assume identity of <username> (only when run as root) #指定用户
-m <num> 分配内存大小 max memory to use for items in megabytes (default: 64 MB)
-c <num> max simultaneous connections (default: 1024) #并发访问连接数
-P <file> 指定pid文件存放路径save PID in <file>, only used with -d option
 
/etc/init.d/memcached start
 

3.6 使用

向Memcached添加数据:键值对
key1-->values1
key2-->values2
 
 
 
 # 写入数据
 [root@web01 ~]# printf "set key008 0 0 10\r\noldboy0987\r\n"|nc 127.0.0.1 11211
 STORED
 # 查询数据
 [root@web01 ~]# printf "get key008\r\n"|nc 127.0.0.1 11211
 VALUE key008 0 10
 oldboy0987
 END
 # 删除数据
 [root@web01 ~]# printf "delete key008\r\n"|nc 127.0.0.1 11211
 DELETED
 [root@web01 ~]# printf "get key008\r\n"|nc 127.0.0.1 11211
 END
 
 

3.7 服务端memcached监控

 
 printf "stats\r\n"|nc 127.0.0.1 11211
 
①监听port或进程
②可以模拟用户先set后get,比对get内容是不是set的。crond nagios zabbix
③监控命中百分比
④监控响应时间及需要的状态
 
 

4. PHP的memcache客户端

4.1 安装

tar xf memcache-2.2.5.tgz
cd memcache-2.2.5
/application/php/bin/phpize
./configure --enable-memcache --with-php-config=/application/php/bin/php-config --with-zlib-dir
make
make install
 
sed -i.ori '$a extension=memcache.so' /application/php/lib/php.ini
pkill php
/application/php/sbin/php-fpm -t
/application/php/sbin/php-fpm
/application/php/bin/php -m|grep memcache
 

4.2 生成测试页面

 
cat >>/application/nginx/html/blog/mc.php<<'EOF'
<?php
$memcache = new Memcache;
$memcache->connect('172.16.1.41', 11211) or die ("Could not connect");
$memcache->set('key20171017', 'oldboy0326');
$get_value = $memcache->get('key20171017');
echo $get_value;
?>
EOF
 
[root@web01 ~]# curl -H Host:blog.lewen.com 10.0.0.8/mc.php 
oldboy0326
 
[root@web01 conf]# curl 10.0.0.8/mc.php
oldboy0326
 
 
应用 :session共享
需要运维+开发协同
运维:准备环境
开发:用环境
 
sed -i 's#session.save_handler = files#session.save_handler = memcache#;$a session.save_path = "tcp://172.16.1.41:11211"' /application/php/lib/php.ini
 
pkill php
/application/php/sbin/php-fpm -t
/application/php/sbin/php-fpm
 
 
总结:
1.服务端、客户端安装,管理工具的使用
2.session共享配置
3.memcached 作为缓存工作过程
 
 
 
 
 

第34 memcached缓存的更多相关文章

  1. 受教了,memcache比较全面点的介绍,受益匪浅,适用memcached的业务场景有哪些?memcached的cache机制是怎样的?在设计应用时,可以通过Memcached缓存那些内容?

    基本问题 1.memcached的基本设置 1)启动Memcache的服务器端 # /usr/local/bin/memcached -d -m 10 -u root -l 192.168.0.200 ...

  2. Python项目使用memcached缓存

    前言许多Web应用都将数据保存到MySQL这样的关系型数据库管理系统中,应用服务器从中读取数据并在浏览器中显示. 但随着数据量的增大.访问的集中,就会出现数据库的负担加重.数据库响应恶化. 网站显示延 ...

  3. 从零开始学 Java - Spring 集成 Memcached 缓存配置(二)

    Memcached 客户端选择 上一篇文章 从零开始学 Java - Spring 集成 Memcached 缓存配置(一)中我们讲到这篇要谈客户端的选择,在 Java 中一般常用的有三个: Memc ...

  4. .NET跨平台之旅:基于.NET Core改写EnyimMemcached,实现Linux上访问memcached缓存

    注:支持 .NET Core 的 memcached 客户端 EnyimMemcachedCore 的 NuGet 包下载地址:https://www.nuget.org/packages/Enyim ...

  5. redis和memcached缓存

    memcached memcache开源的,高性能,高并发分布式内存缓存系统,天生支持集群 memcached下载地址: http://memcached.org/downloads python实现 ...

  6. 应对Memcached缓存失效,导致高并发查询DB的四种思路(l转)

    当Memcached缓存失效时,容易出现高并发的查询DB,导致DB压力骤然上升. 这篇blog主要是探讨如何在缓存将要失效时,及时地更新缓存,而不是如何在缓存失效之后,如何防止高并发的DB查询. 解决 ...

  7. memcached 缓存服务器

    Memcached 缓存服务器 Memcached 是高性能的分布式内存缓存服务器. 一般的使用目的是,通过缓存数据库查询结果,减少数据库访问次数,以提高动态web应用的速度.提高可扩展性. 主要特点 ...

  8. Memcached缓存瓶颈分析

    Memcached缓存瓶颈分析 获取Memcached的统计信息 Shell: # echo "stats" | nc 127.0.0.1 11211 PHP: $mc = new ...

  9. 通过spring.net中的spring.caching CacheResult实现memcached缓存

    通过spring.net中的spring.caching CacheResult实现memcached缓存1.SpringMemcachedCache.cs2.APP.config3.Program. ...

随机推荐

  1. XML和实体类之间相互转换(序列化和反序列化)

    我们需要在XML与实体类,DataTable,List之间进行转换,下面是XmlUtil类,该类来自网络并稍加修改. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 ...

  2. 关于AsyncSocket

               写篇博客,在我项目中用到了一个很重要的第三方---AsyncSocket,写下我对AsyncSocket使用心得.我的项目中是APP对硬件直接交互,APP对硬件发指令的时候不需要 ...

  3. jquery:获取checked复选框的问题

    jquery:获取checked复选框的问题 功能描述:要完成一个全选的功能,但总是获取不到复选框的被选中的个数,究其原因,是Jquery中length和checked使用不当所造成的. // 获取所 ...

  4. docker 在windows7 、8下的安装

    这里说明一下这种安装方式适合win7 win8的系统环境下安装的,当然win10也可以,但是win10有更好的方式 即安装Docker Toolbox,同时还附加安装 Docker Client fo ...

  5. 爬取WX小程序的数据

    方法一: 使用TBS工具,调试跟踪获取URL https://x5.tencent.com/tbs/guide/debug/download.html https://x5.tencent.com/t ...

  6. dubbo使用简介

    ---------------------------------------------------------------------------------------------------- ...

  7. 保持ssh连接长时间不断开的技巧

    我经常用ssh连接服务器,过段时间不用, 需要恢复一下断开的连接, 原因是NAT防火墙喜欢对空闲的会话进行超时处理,以确保它们状态表的干净和内存的低占用率,因为 长时间保持连接, 会长期占用部分系统资 ...

  8. idea导入eclipse项目的配置

    idea导入eclipse项目需要的配置 1.配置jdk,这两处选择一样就可以,也可以根据自己需求选择,上边的比下边的版本高就行 2.这里会默认和配置jdk一样 3.添加lib依赖,选择到项目的lib ...

  9. thinkphp5中使用excel导出数据表格(包涵图片)

    首先使用composer require phpoffice/phpexcel下载安装phpexcel包. 将包放入extend下面. 不附加图片的导出 /** * 导出excel(不带图片) * @ ...

  10. canvas(五)createPattern

    /** * Created by xianrongbin on 2017/3/9. * 图片填充 */ var dom = document.getElementById('clock'), ctx ...