如何在PHP环境中使用Memcached?Memcached安装与配置全攻略

答案:在PHP中使用Memcached需先安装并启动Memcached服务器,再安装PHP的memcached扩展。通过配置服务器参数如端口、内存和监听地址,并在PHP中使用Memcached类的addServer、set、get等方法,可实现高效的数据缓存,提升应用性能。

如何在php环境中使用memcached?memcached安装与配置全攻略

要在PHP环境中使用Memcached,核心在于两个步骤:首先是安装并运行Memcached服务器端,它负责实际的数据存储;其次是安装并启用PHP的Memcached扩展,让PHP应用能够与这个服务器进行通信。正确配置这两者后,你就能在PHP代码中利用Memcached实现高性能的数据缓存,显著提升应用的响应速度和数据库负载能力。

Memcached是一个非常高效的分布式内存对象缓存系统,对于PHP应用来说,它简直是性能优化的利器。我记得刚开始接触Web开发时,网站总是因为数据库查询频繁而卡顿,直到引入Memcached,那种性能飞跃的感觉,简直是打开了新世界的大门。它主要通过将数据库查询结果、计算密集型操作的结果或会话数据等存储在内存中,来减少对数据库或文件系统的访问,从而加快数据检索速度。

Memcached服务器端如何安装与启动?

Memcached服务器的安装,其实比很多人想象的要简单,但不同系统略有差异。我个人最常用的是在Linux环境,因为大多数生产服务器都跑Linux。

Debian/Ubuntu系统上,你只需要:

立即学习PHP免费学习笔记(深入)”;

sudo apt update
sudo apt install memcached
登录后复制

CentOS/RHEL系统上,则是:

sudo yum install epel-release
sudo yum install memcached
登录后复制

安装完成后,Memcached服务通常会自动启动。不过,我们还需要检查并可能调整一下它的配置。Memcached的配置文件通常在

/etc/memcached.conf
登录后复制

(Debian/Ubuntu)或

/etc/sysconfig/memcached
登录后复制

(CentOS/RHEL)。

几个关键配置项值得注意:

  • -p 11211
    登录后复制

    :这是Memcached监听的默认端口。如果你有特殊需求,可以改,但一般没必要。

  • -m 64
    登录后复制

    :分配给Memcached的内存大小,单位是MB。默认64MB可能不够用,根据你的应用需求,我通常会调到256MB甚至更高,但别给太多,毕竟是内存。

  • -l 127.0.0.1
    登录后复制

    :Memcached监听的IP地址。默认监听本地回环地址,这意味着只有本机应用能访问。如果你的PHP应用和Memcached服务器不在同一台机器上,你需要把它改成服务器的实际IP地址,或者

    0.0.0.0
    登录后复制

    (监听所有接口),但后者安全性较低,生产环境要谨慎。

修改配置后,记得重启Memcached服务让改动生效:

sudo systemctl restart memcached # 或 sudo service memcached restart
登录后复制

你也可以用

ps aux | grep memcached
登录后复制

来确认它是否在运行。

PHP Memcached扩展的安装与配置

PHP要和Memcached服务器通信,需要安装一个客户端扩展。这里有两个选择:

memcache
登录后复制

(老版本,功能相对简单)和

memcached
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制

(新版本,功能更强大,支持二进制协议,推荐使用)。我强烈建议安装

memcached
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制

扩展。

安装

memcached
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制

扩展最常见的方式是通过

pecl
登录后复制

或系统包管理器。

通过pecl安装(这需要你的PHP开发环境安装了

php-dev
登录后复制

php-devel
登录后复制

包):

sudo pecl install memcached
登录后复制

安装过程中可能会问你

libmemcached
登录后复制

的路径,通常直接回车使用默认值即可。

通过系统包管理器安装(更推荐,因为它处理了依赖关系):
Debian/Ubuntu上:

sudo apt install php-memcached
登录后复制

CentOS/RHEL上:

sudo yum install php-pecl-memcached
登录后复制

注意,如果你有多个PHP版本,可能需要指定版本,例如

php7.4-memcached
登录后复制

安装完成后,你需要确保这个扩展在

php.ini
登录后复制
登录后复制

中被启用。通常,安装脚本会自动在

php.ini
登录后复制
登录后复制

或对应的

conf.d
登录后复制

目录下添加一行:

extension=memcached.so
登录后复制

如果没看到,手动添加进去。

别忘了重启你的Web服务器(如Apache或Nginx)以及PHP-FPM服务(如果使用FPM),让PHP加载新的扩展:

sudo systemctl restart apache2 # 或 sudo systemctl restart nginx
sudo systemctl restart php7.4-fpm # 根据你的PHP版本调整
登录后复制

最后,你可以创建一个简单的

info.php
登录后复制

文件,内容是

<?php phpinfo(); ?>
登录后复制

,访问它,搜索“memcached”,如果能找到相关信息,就说明扩展安装成功了。

在PHP代码中如何实际操作Memcached?

扩展安装好了,Memcached服务器也跑着,现在就到了在代码里大展身手的时候了。PHP的

memcached
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制

类提供了非常直观的API来操作缓存。

首先,你需要创建一个

memcached
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制

实例并连接到Memcached服务器:

<?php
$memcached = new Memcached();
// 添加Memcached服务器,参数依次是:主机名/IP, 端口
// 也可以添加多个服务器,Memcached会进行分布式存储
$memcached->addServer('127.0.0.1', 11211);

// 检查是否连接成功,或者在操作时捕获异常
if (!$memcached->getStats()) {
    echo "无法连接到Memcached服务器!/n";
    // 这里可以进行错误处理,比如回退到数据库查询
    exit;
}

// 1. 存储数据 (set)
$key = 'my_data_key';
$value = ['name' => 'John Doe', 'age' => 30, 'city' => 'New York'];
$expiration = 3600; // 数据在缓存中保留3600秒 (1小时)

if ($memcached->set($key, $value, $expiration)) {
    echo "数据已成功存储到Memcached。/n";
} else {
    echo "存储数据失败!/n";
}

// 2. 获取数据 (get)
$cachedValue = $memcached->get($key);

if ($cachedValue !== false) {
    echo "从Memcached获取到数据:/n";
    print_r($cachedValue);
} else {
    echo "Memcached中没有找到键为 '{$key}' 的数据。/n";
    // 如果缓存中没有,通常会从数据库或其他源获取,然后存入缓存
    // $value = fetchDataFromDatabase();
    // $memcached->set($key, $value, $expiration);
}

// 3. 删除数据 (delete)
// 假设我们想删除这个键
// if ($memcached->delete($key)) {
//     echo "键 '{$key}' 已从Memcached中删除。/n";
// } else {
//     echo "删除键 '{$key}' 失败或不存在。/n";
// }

// 4. 增加/减少数值 (increment/decrement) - 仅适用于数值类型
$counterKey = 'page_views';
// 初始化计数器,如果不存在则设为0,然后增加1
$memcached->add($counterKey, 0); // 确保键存在,如果存在则不操作
$newCount = $memcached->increment($counterKey);
echo "页面浏览量增加到:{$newCount}/n";

$newCount = $memcached->decrement($counterKey);
echo "页面浏览量减少到:{$newCount}/n";

// 5. 清空所有缓存 (flush) - 谨慎使用,会清空所有数据!
// $memcached->flush();
// echo "Memcached中所有数据已清空。/n";

// 实际应用场景:缓存数据库查询结果
function getArticleFromCacheOrDB(Memcached $memcached, $articleId) {
    $cacheKey = "article:{$articleId}";
    $article = $memcached->get($cacheKey);

    if ($article === false) {
        echo "从数据库加载文章 {$articleId}.../n";
        // 模拟从数据库加载数据
        sleep(1); // 模拟数据库查询耗时
        $article = [
            'id' => $articleId,
            'title' => "文章标题 {$articleId}",
            'content' => "这是文章 {$articleId} 的详细内容。",
            'author' => '匿名作者'
        ];
        // 存入缓存,设置过期时间为5分钟
        $memcached->set($cacheKey, $article, 300);
    } else {
        echo "从Memcached加载文章 {$articleId}.../n";
    }
    return $article;
}

echo "/n--- 演示缓存 --- /n";
$article1 = getArticleFromCacheOrDB($memcached, 101);
print_r($article1);

$article2 = getArticleFromCacheOrDB($memcached, 102);
print_r($article2);

// 再次获取文章101,这次应该从缓存中获取
$article1Cached = getArticleFromCacheOrDB($memcached, 101);
print_r($article1Cached);

?>
登录后复制

这个示例涵盖了

memcached
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制
登录后复制

类最常用的几个方法。我个人在使用时,最常遇到的问题就是忘记设置合适的过期时间,导致数据要么很快失效,要么一直占据缓存空间。合理规划过期时间,以及在缓存失效时如何优雅地回源获取数据,是实际应用中需要深思熟虑的地方。另外,

addServer
登录后复制

方法可以多次调用,将多个Memcached服务器加入到池中,实现分布式缓存,这在大型应用中非常有用,但配置起来也稍微复杂一些,涉及到一致性哈希等概念。对于初学者,单点部署是很好的开始。

以上就是如何在PHP环境中使用Memcached?Memcached安装与配置全攻略的详细内容,更多请关注php中文网其它相关文章!

https://www.php.cn/faq/1474421.html

发表回复

Your email address will not be published. Required fields are marked *