当我们想到存储在Web应用程序中,我们首先想到的通常是一个传统的数据库MySQL。这是伟大的长期存储和数据分析,但有许多短期需要一个更好的选择:memcached。这是页面请求和提高性能之间的信息存储位一个不错的选择。本文介绍我们会告诉你如何开始使用memcached PHP。
介绍
memcached是一个简单的界面让你店里的东西在存储服务器。这可以在同一台机器上运行作为Web服务器的可扩展性,但来自分布在多个服务器实例。所有你需要的是Memcached在后台运行,PHP提供了一个简单的界面和一个PECL的图书馆。基于Debian的Linux系统,这很容易:
$ sudo apt-get install memcached
$ sudo service memcached start
$ sudo pecl install memcached
$ sudo service httpd restart
复制代码
现在我们要提到有技术上的两个PHP库使用memcached。老图书馆被称为“set”和缺乏某些功能。新的“缓存”图书馆使用libmemcached和一般是首选。
PHP中的第一步是连接到服务器。连接可以持续跨越的要求,这是很好的性能。然后添加到服务器列表的需要。在这种情况下,我们将使用一个本地运行实例的默认端口:
function
get_memcached() {
$mc
=
new
Memcached('webapp');
$mc
->setOption(Memcached::OPT_CONNECT_TIMEOUT, 1000);
if
( !
$mc
->getServerList() ) {
if
( !
$mc
->addServer('localhost', 11211) ) {
error_log
('Could not add memcached server.');
return
false;
}
}
return
$mc
;
}
复制代码
现在你可以读写PHP变量与基于密钥的memcached你定义简单的功能。他们将序列化和反序列化,自动。你可以不喜欢写数据库连接或结果集的资源,但你可以将这些结果集阵列和存储这些。
数据存储
让我们说我们想存储列表的最近访问的URL的每个登录的用户。我们可以使用会话,但不工作的设备和它会尽快清除会话是消失。我们可以使用一个数据库,但这种数据的最可能我们的系统没有临界慢。使用memcached是容易的:
$user_id
= 123;
缓存
现在让我们通过缓存数据库结果真正提高您的Web应用程序。数据库查询通常是在服务器处理的最大瓶颈,从而避免重复查询在内存中缓存的结果可以提供巨大的性能增益。最简单的方法是查询只和主键的商店。通常最好是缓存的值被删除时,数据库的记录被更新,用户不会看到任何过时的价值观。
function
store_product(
$id
,
$name
,
$price
) {
$db
= get_db();
$qry
=
$db
->prepare('REPLACE INTO product (id, name, price) VALUES (:id, :name, :price)');
$qry
->bindParam(':id',
$id
);
$qry
->bindParam(':name',
$name
);
$qry
->bindParam(':price',
$price
);
$qry
->execute();复制代码
注意事项
与任何技术选择有局限性和注意事项:
一个关键的最大长度是250个字节。把你的钥匙简短。
默认的最大值的大小为1MB。这不是正确的地方来存储大的值。
仓储不是锁定阅读或在数据库中的记录可以被锁定的写作方式。要知道,任何Web请求可以在任何时间更新任何价值。
确保您有足够的RAM memcached服务器合并。
下一步
你能越做memcached:
缓存的值可以超时。这是有用的数据时,应该被缓存一段时间而不是手工删除。
简单的递增和递减的方法有利于保持快速柜台之间的请求。
memcached配置正确,你可以分享许多编程语言编写的应用程序之间的数据。
给memcached一试。在合适的情况下这是一个非常简单而有效的最大化你的Web应用程序性能的解决方案。