Memcached功能可用需依次验证:一、phpinfo()确认扩展启用;二、命令行执行getStats()测试连接;三、完整set/get/delete流程验证;四、telnet手动协议交互;五、检查PHP错误日志定位异常。

如果您在PHP环境中配置了Memcached扩展,但不确定其是否正常工作,则可能是由于扩展未正确加载或Memcached服务未运行。以下是验证Memcached功能是否可用的多种方法:
一、检查PHP扩展是否已启用
该步骤用于确认Memcached扩展已被PHP识别并加载,是后续所有测试的前提条件。
1、创建一个PHP文件(如info.php),内容为<?php phpinfo(); ?>。
2、将该文件放入Web服务器可访问目录,通过浏览器访问该文件。
立即学习“PHP免费学习笔记(深入)”;
3、在页面中搜索memcached,确认存在“memcached support”为enabled,且显示版本信息。
4、若未找到相关条目,则说明扩展未启用,需检查php.ini中是否包含extension=memcached(Linux/macOS)或extension=php_memcached.dll(Windows),并确认扩展文件存在于extension_dir指定路径中。
二、使用命令行执行PHP脚本测试连接
该方法绕过Web服务器环境,直接验证PHP能否与本地Memcached服务建立TCP连接并执行基本操作。
1、确保Memcached服务正在运行,可通过ps aux | grep memcached(Linux/macOS)或任务管理器(Windows)确认进程存在。
2、编写测试脚本test_memcached.php,内容如下:
<?php<br>
$mem = new Memcached();<br>
$mem->addServer('127.0.0.1', 11211);<br>
var_dump($mem->getStats());<br>
?>登录后复制
3、在终端中执行php test_memcached.php。
4、若输出为包含主机、pid、uptime等字段的数组,则表明连接成功;若返回空数组或警告,则Memcached服务未响应或网络端口被阻塞。
三、执行键值存取完整流程验证
该方法模拟真实缓存使用场景,验证set、get、delete等核心功能是否协同正常。
1、新建脚本cache_test.php,写入以下代码:
<?php<br>
$mem = new Memcached();<br>
$mem->addServer('127.0.0.1', 11211);<br>
$key = 'test_key_' . time();<br>
$value = ['data' => 'hello memcached', 'ts' => time()];<br>
if ($mem->set($key, $value, 30)) {<br>
echo "SET OK\n";<br>
} else {<br>
echo "SET FAILED\n";<br>
}<br>
$result = $mem->get($key);<br>
if ($result !== false) {<br>
echo "GET OK: " . json_encode($result) . "\n";<br>
} else {<br>
echo "GET FAILED\n";<br>
}<br>
$mem->delete($key);<br>
?>登录后复制
2、在命令行中运行php cache_test.php。
3、观察输出是否包含“SET OK”和“GET OK”,且JSON内容与写入一致。
标签: php linux js json windows apache 浏览器 端口 mac ai macos win
还木有评论哦,快来抢沙发吧~