Memory Cache — 使用内存作为数据的缓冲,加快数据的读取,减少DB服务器的负担。
在无数的大型网站中,Memory Cache起着至关重要的作用,往往这些大型网站会用上百台Memory Cache服务器。
而在中小型的项目中,适当使用Memory Cache(性能与成本之间的妥协)也是非常有必要的。
之前写过一篇文章《自己动手,写一个简单PHP框架 (番外2)》,介绍了Adodb在查询数据时使用HD作为缓冲,虽然这样也能对性能起到一定提升作用,但会使磁盘I/O增加,磁盘的性能往往随着I/O递增呈现指数级下降,所以在有条件的情况下使用Memory Cache是明智之举。
1. 安装第三方软件库
wget http://dag.wieers.com/rpm/packages/rpmforge-release/rpmforge-release-0.5.2-2.rf.src.rpm
rpm -ivh rpmforge-release-0.5.2-2.rf.src.rpm
2. 查找Memcached
yum search memcached
3. 安装Memcached
yum -y install memcached
4. 验证安装
memcached -h
应该会输出一些帮助信息
5. 将memcache加入启动列表
chkconfig –level 2345 memcached on
6. 配置Memcache
vi /etc/sysconfig/memcached
文件中内容如下
PORT=”11211″ 端口
USER=”root” 使用的用户名
MAXCONN=”1024″ 同时最大连接数
CACHESIZE=”64″ 使用的内存大小
OPTIONS=”" 附加参数
7. 查看memcache状态
memcached-tool [Memcache Server IP]:[Memcache Server Port] stats
如:memcached-tool 127.0.0.1:11211 stats
=====至此,我们将Memcache服务配置完毕,接着我们配置PHP的扩展,以便在程序中来调用=====
PHP共有2种Memcache扩展,一个叫Memcache(2002年发布),另一个叫Memcached(2008年发布)
Memcached比较新,它依赖于limemcached库才能运行,不过它能完成基于Memcache服务的几乎所有功能,比如:Memcached::getResultCode ,它能返回上一次操作Memcache的结果,而Memcache则没有这个功能
Memcache(没有d)不依赖任何库就能运行,安装相对简单,同时也能完成Memcache服务的大部分主要功能。
下面分别介绍2者的安装方式。
8. 安装PHP的Memcache扩展
wget http://pecl.php.net/get/memcache-2.2.6.tgz
tar vxzf memcache-2.2.6.tgz
cd memcache-2.2.6
/usr/bin/phpize (如果不知道phpize在什么位置,可以用find / -name phpize查找)
./configure –enable-memcache –with-php-config=/usr/bin/php-config –with-zlib-dir
make
make install
记录下安装成功后的提示,类似于:
Installing shared extensions: /usr/lib/php/modules/
把这个地址记录下来
增加扩展extension配置文件
查看是否存在 /etc/php.d/memcache.ini 这个文件,如果不存在,我们就自己建立一个
vi /etc/php.d/memcache.ini
增加1行
extension=memcache.so
最后验证一下是否安装完成
php -m|grep memcache
应该会显示memcache
如果出现类似的错误:PHP Warning: Module ‘memcache’ already loaded in Unknown on line 0
那可以把php.ini新增加的extension=/usr/lib/php/modules/memcache.so注释掉
9. PHP的Memcached扩展安装
首先确认一下json头文件是否正确配置
ls /usr/include/php/ext/json/php_json.h (这是默认路径,如果安装php是指定了其他路径,则查看其他路径)
如果文件不存在,那我们需要先配置json头文件;如果已经存在,那就不需要下面这步操作了
确认一下json的版本,我们在phpinfo()中可以查看,
wget wget http://pecl.php.net/get/json-1.2.1.tgz (确认下载了正确的版本)
tar xzvf json-1.2.1.tgz
mkdir -R /usr/include/php/ext/json/
cp json-1.2.1/php_json.h /usr/include/php/ext/json/
安装libmemached
wget http://launchpad.net/libmemcached/1.0/0.50a/+download/libmemcached-0.50.tar.gz (不要下载0.51版,它无法完成编译)
tar -xzvf libmemcached-0.50.tar.gz
cd libmemcached-0.50.tar.gz
./configure –prefix=/usr/local/libmemcached –with-memcached
make
make install
再安装Memcached扩展
wget http://pecl.php.net/get/memcached-1.0.2.tgz
tar xzvf memcached-1.0.2.tgz
cd memcached-1.0.2
./configure –enable-memcached –with-php-config=/usr/bin/php-config –with-zlib-dir –with-libmemcached-dir=/usr/local/libmemcached –prefix=/usr/local/phpmemcached
make
make install
记录下安装成功后的提示,类似于:
Installing shared extensions: /usr/lib/php/modules/
增加扩展extension配置文件
vi /etc/php.d/memcached.ini
增加1行
extension=memcached.so
最后验证一下是否安装完成
php -m|grep memcached
应该会显示memcached
如果在添加扩展so文件时,直接修改php.ini,那么可能会出现下面的错误:
/usr/lib/php/modules/memcached.so: undefined symbol: php_json_encode in Unknown on line 0
这个错误是因为在 memcached.so 加载之前必须加载 json.so ,而json.so是在/etc/php.d/json.ini中加载,这样会导致json.so在memcached.so之后加载;可以删除/etc/php.d/json.ini文件,而在php.ini中直接添加extensino=json.so来解决
=====PHP中配置MemCache就是这些======
10. 配置selinux
selinux是一套linux的安全系统,它指定了应用程序可以访问的磁盘文件、网络端口等等。
如果装有selinux,那么默认的selinux会阻止memcache程序访问11211端口,所以必须对selinux进行配置才行。
方法1: 临时降低selinux运行级别,以便我们进行测试
命令:setenforce [Enforcing | Permissive]
Enforcing表示不允许违反策略的操作
Permissive表示允许违反策略的操作,但会记录下来
我们使用 setenforce Permissive
方法2: 修改selinux配置文件,关闭selinux
编辑 /etc/selinux/config 文件,将 SELINUX=enforcing 改为 SELINUX=disabled
方法3: 修改selinux的http策略,使得httpd进程可以访问网络,这样也就可以使用memcache了
命令:setsebool -P httpd_can_network_connect true
参数P的意思是保持设置的有效性,这样在重启之后这个设置依然有效,不会改变
11. 查看selinux状态
sestatus -bv
12. 配置防火墙
如果Memcache和Web服务器不是同一台服务器,那么或许还需要配置iptables
登录Memcache服务器,并取得root权限
vi /etc/sysconfig/iptables
-A RH-Firewall-1-INPUT -p tcp -s Web服务器1的IP地址 –dport 11211 -j ACCEPT
-A RH-Firewall-1-INPUT -p tcp -s Web服务器2的IP地址 –dport 11211 -j ACCEPT
……
:wq
/etc/init.d/iptables restart
附:在Windows开发环境中,也能使用Memcached
1. 到 http://splinedancer.com/memcached-win32/ 下载memcache,如果无法打开链接,可在本文最后下载;
2. 解压后在运行框内执行以下命令:
e:\memcached\memcached.exe -d install
e:\memcached\memcached.exe -d start
3. 然后将 php_memcache.dll(在本文最后下载) 复制到 system32 和 PHP安装目录下的ext文件夹内;
4. 在php.ini文件中增加 extension=php_memcache.dll;
5. 重启Apache
分享到:
相关推荐
还在测试,这几天完善一下
.NET Core 2.0 迁移小技巧之 MemoryCache 问题修复解决的方法 .NET Core 2.0 中的 MemoryCache 问题修复解决方法是指在 .NET Core 2.0 迁移过程中,如何解决 MemoryCache 相关代码不再起作用的问题。MemoryCache 是...
.NET Core中的MemoryCache是一种用于在应用程序内存中存储数据的缓存机制,以提高数据访问速度和应用程序性能。MemoryCache属于.NET Core的内置缓存机制之一,广泛应用于各种需要快速数据存取的场景。本篇文章主要...
"通过MemoryCache加载图片"这个话题主要探讨了如何利用内存缓存来优化图片加载过程,从而提高用户体验并减少系统资源的消耗。 MemoryCache,顾名思义,是将数据存储在内存中的一种缓存机制。在Android中,内存缓存...
JavaScript_MemoryCache是一个创新性的实验项目,其目标是利用JavaScript技术将用户的本地桌面环境转变为一个具备人工智能代理功能的平台。这个项目的核心理念是利用JavaScript的跨平台特性,结合AI算法,为用户提供...
Go-memorycache示例Golang内存缓存管理器,键/值数据存储如何安装? 去获取github.com/maxchagin/go-memorycache-example如何使用? 包装需要进口 import (memorycache "github....
.NET Core MemoryCache 是一个内存缓存系统,可用于在应用程序中存储和检索数据,以提高应用程序性能。该系统提供了多种缓存策略和灵活性,能够适应不同的应用场景。通过使用缓存域的概念,它还解决了缓存依赖问题,...
在讨论x86架构下的缓存(Cache Memory)时,首先我们需要理解什么是缓存以及它为何重要。缓存是一类快速存储设备,它位于处理器和主存(主内存)之间。缓存的主要功能是存储处理器经常使用的指令和数据。由于CPU执行...
ASP.NET应用程序的两层缓存策略是提高应用性能的关键技术之一,主要涉及到内存中的`MemoryCache`和分布式缓存服务`Redis`。本文将详细探讨这两种缓存机制以及如何在C#开发环境中结合使用它们。 首先,我们来了解`...
Cache是一个绝大多数项目会用到的一个技术,这篇文章主要介绍了.NET Core系列之MemoryCache 初识,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
内存系统分为几个层次,包括高速缓存(Cache)、动态随机存取存储器(DRAM)和磁盘存储。每层都有其独特的特性和功能,并且在整个存储体系中扮演着各自的角色。 缓存是计算机内存系统中最接近CPU的部分,它用于临时...
.NET Core系列之MemoryCache缓存选项详细介绍了.NET Core环境下MemoryCache缓存的使用方法和内部机制,特别是针对MemoryCacheOptions类中的多个属性进行了深入讲解。MemoryCache是.NET Core推出的一种内存缓存技术,...
在.NET Framework中,MemoryCache是System.Runtime.Caching命名空间下的一个类,用于提供应用程序的内存缓存服务。然而,当你将项目迁移到.NET Core 2.0时,会发现System.Runtime.Caching命名空间不再被支持,因此...
使用`MemoryCache`类是`System.Runtime.Caching`的主要方式,可以通过实例化`MemoryCache.Default`或创建自定义的`MemoryCache`实例来存取数据。`MemoryCache`提供了丰富的API,如设置过期时间、添加移除缓存项、...
本文主要探讨了缓存内存(Cache Memory)的相关知识,内容涵盖了缓存的基本概念、工作原理、组成结构、替换算法、指令缓存、一致性与一致性问题、层次结构、数据预取等多个方面。由于文件内容是扫描后的文字,可能...
cache = MemoryCache ( String , Int32 ).new cache.write( " bla " , 1 ) p cache.read( " bla " ) # => 1 cache.fetch( " haha " ) { 2 } p cache.read( " haha " ) # => 2 cache.write( " expired1 " , 1 , ...
"利用MemoryCache和AOP进行昂贵的呼叫"这个主题聚焦于两种技术:System.Runtime.Caching.MemoryCache和面向切面编程(AOP)。这两种技术结合使用,可以有效地缓存计算昂贵或数据库查询结果,避免重复执行这些操作,...
本主题将深入探讨三个关键层次的存储器:Cache、DRAM(动态随机存取内存)和磁盘。 首先,Cache是存储器系统中的最快部分,它的主要任务是减少CPU与主存之间的通信延迟。Cache的工作原理基于局部性原理,即程序运行...