- 最新动态
- 功能总览
- 服务公告
- 产品介绍
- 计费说明
- 快速入门
- 用户指南
- 最佳实践
- API参考
- SDK参考
-
常见问题
- 实例类型/版本
- 实例特性
- 安全性
-
客户端和网络连接
- DCS实例支持公网访问吗?
- Redis连接失败问题排查和解决
- DCS实例是否支持跨VPC访问?
- Redis公网访问所需弹性IP是否收费?
- Redis连接时报错:“(error) NOAUTH Authentication required”。
- 客户Http的Server端关闭导致Redis访问失败
- 客户端出现概率性超时错误
- 使用Jedis连接池报错如何处理?
- 如何使用Redis-desktop-manager访问Redis实例?
- 使用SpringCloud时出现ERR Unsupported CONFIG subcommand怎么办?
- 客户端无法使用域名连接DCS缓存实例时如何处理?
- 本地环境是否可以连接缓存实例?
- 使用Redis实例的发布订阅(pubsub)有哪些注意事项?
- Redis 3.0实例公网开关被关闭是什么原因?
- 使用短连接访问Redis出现“Cannot assign requested address”错误
- 连接池选择及Jedis连接池参数配置建议
- 如何解决Lettuce 6.x版本客户端使用DCS实例兼容性问题?
- 应该选择域名还是IP地址连接Redis实例?
- 主备实例的只读地址是连接到主节点还是备节点?
-
Redis使用
- 是否支持CPU架构的变更?
- 实例是否支持变更可用区
- Redis实例能否修改VPC和子网?
- 实例是否支持自定义或修改端口?
- 实例是否支持修改访问地址?
- 实例无法删除是什么原因?
- 集群实例启动时间过长是什么原因?
- 使用redis_exporter出错怎么办?
- 什么是预留内存,如何配置预留内存?
- 创建的缓存实例为什么可使用内存比实例规格少一些?
- Redis 3.0 Proxy集群不支持redisson分布式锁的原因
- DCS Redis有没有后台管理软件?
- DCS缓存实例的数据被删除后,能否找回?
- 为什么实例实际可用内存比申请规格小而且已使用内存不为0?
- 如何查看Redis内存占用量
- Cluster集群实例容量和性能未达到瓶颈,但某个分片容量或性能已过载是什么原因?
- 访问Redis报OOM错误提示
- 不同编程语言如何使用Cluster集群客户端
- 使用Cluster的Redis集群时建议配置合理的超时时间
- 读取redis数据报超时错误
- hashtag的原理、规则及用法示例
- Redis key丢失是什么原因
- 重启实例后缓存数据会保留吗?
- 如何确认实例是单DB还是多DB
- Proxy集群开启多DB的使用限制及操作方式
- 如何创建多DB的Proxy集群实例?
- 扩容缩容与实例升级
-
数据备份/导出/迁移
- DCS实例是否兼容低版本Redis迁移到高版本
- 不同类型的操作系统间进行数据传递和操作,需要注意什么?
- 源Redis使用了多DB,能否迁移数据到集群实例?
- 源Redis迁移到集群实例中有哪些限制和注意事项?
- 在线迁移需要注意哪些?
- 在线迁移能否做到完全不中断业务?
- 在线迁移实例源端报“Disconnecting timedout slave”和“overcoming of output buffer limits”
- 如何导出Redis实例数据?
- 使用Rump工具迁移数据,命令执行后无报错,但Redis容量无变化
- 是否支持控制台导出RDB格式的Redis备份文件?
- 缓存实例备份文件如何存放?备份文件的数量是否有限制?
- Redis在线数据迁移是迁移整个实例数据么?
- AOF文件在什么情况下会被重写
- Redis迁移失败有哪些常见原因?
- 一个数据迁移能迁移到多个目标实例么?
- 怎么放通SYNC和PSYNC命令?
- 迁移或导入备份数据时,相同的Key会被覆盖吗?
- Cluster集群实例使用内置key且跨slot的Lua脚本时迁移失败
- 迁移故障处理
- 数据迁移失败问题排查
- Memcached如何迁移?
- 是否支持Memcached和Redis之间实例数据的迁移?
- 大Key/热Key分析/过期Key扫描
- Redis命令
- 监控告警
- 主备倒换
- 创建实例和权限
- Memcached使用
- 故障排除
- 视频帮助
- 文档下载
- 通用参考
链接复制成功!
Libmemcached客户端连接Memcached(PHP)
介绍使用同一VPC内弹性云服务器ECS上的PHP客户端连接Memcached实例的方法。
前提条件
- 已成功申请Memcached实例,且状态为“运行中”。
- 已创建弹性云服务器。创建弹性云服务器的方法,请参见《弹性云服务器用户指南》。
说明:
您创建的弹性云服务器必须与Memcached实例属于同一个VPC,并配置相同的安全组,以确保弹性云服务器与缓存实例的网络是连通的。
- 如果弹性云服务器与Memcached实例不在相同VPC中,可以通过建立VPC对等连接方式连通网络,具体请参考常见问题:缓存实例是否支持跨VPC访问?
- 如果弹性云服务器与Memcached实例配置了不同的安全组,可以通过设置安全组规则连通网络,具体请参考常见问题:如何选择和配置安全组?
RedHat系列
以CentOS7为例介绍PHP版本客户端的安装。Redhat、Fedora等系统也适用。
- 安装gcc-c++及make等编译组件。
yum install gcc-c++ make
- 安装sasl相关包。
yum install cyrus-sasl*
- 安装libmemcached。
由于libmemcached库需要增加sasl认证参数,因此不能直接使用yum命令安装。
wget https://launchpad.net/libmemcached/1.0/1.0.18/+download/libmemcached-1.0.18.tar.gz
tar -xvf libmemcached-1.0.18.tar.gz
cd libmemcached-1.0.18
./configure --prefix=/usr/local/libmemcached --enable-sasl
make && make install
说明:
安装libmemcached之前要完成gcc-c++、sasl相关组件的安装。否则会在编译过程中报错,报错问题解决后请执行make clean之后重新make。
- 安装php。
yum install php-devel php-common php-cli
须知:
php7.x对SASL认证存在兼容问题,建议使用php 5.6版本。如果yum源提供的php不是5.6版本,请自行在网上查找下载源。
- 安装memcached客户端。
注意运行configure配置安装时,增加开启sasl参数。
wget http://pecl.php.net/get/memcached-2.1.0.tgz
tar zxvf memcached-2.1.0.tgz
cd memcached-2.1.0
phpize
./configure --with-libmemcached-dir=/usr/local/libmemcached --enable-memcached-sasl
make && make install
- 增加php.ini配置。
使用find或者locate命令找到php.ini文件。
find / -name php.ini
编辑该文件,增加以下两行:
extension=memcached.so memcached.use_sasl = 1
图1 增加php.ini配置 - 测试连接。
新增一个memcached.php文件,增加如下内容:
<?php $connect = new Memcached; //声明一个Memcached连接 $connect->setOption(Memcached::OPT_COMPRESSION, false); //关闭压缩 $connect->setOption(Memcached::OPT_BINARY_PROTOCOL, true); //使用二进制协议 $connect->setOption(Memcached::OPT_TCP_NODELAY, true); //关闭TCP网络延迟策略 $connect->addServer('{memcached_instance_ip}', 11211); //此处填写实例ip和端口 $connect->setSaslAuthData('{username}', '{password}'); //如果实例开启免密访问,则删除或者注释此行 $connect->set("DCS", "Come on!"); echo 'DCS: ',$connect->get("DCS"); echo "\n"; $connect->quit(); ?>
保存后运行情况如下:
[root@testphpmemcached ~]# php memcached.php DCS: Come on! [root@testphpmemcached ~]#
debian系列
以Ubuntu为例,安装步骤如下:
- 安装gcc及make等编译组件。
apt install gcc make
- 安装php。
推荐使用php5.x的版本,对sasl认证兼容性较好。
按照如下步骤先添加php低版本的镜像源,然后安装php5.6以及php5.6-dev。
apt-get install -y language-pack-en-base;
LC_ALL=en_US.UTF-8;
add-apt-repository ppa:ondrej/php;
apt-get update;
apt-get install php5.6 php5.6-dev;
安装完成后,使用php -version,查看版本号为5.6,说明安装成功。
root@dcs-nodelete:/etc/apt# php -version PHP 5.6.36-1+ubuntu16.04.1+deb.sury.org+1 (cli) Copyright (c) 1997-2016 The PHP Group
说明:
如果需要卸载php,可使用如下命令:
apt install aptitude -y
aptitude purge `dpkg -l | grep php| awk '{print $2}' |tr "\n" " "`
- 安装sasl组件。
apt install libsasl2-dev cloog.ppl
- 安装libmemcached。
wget https://launchpad.net/libmemcached/1.0/1.0.18/+download/libmemcached-1.0.18.tar.gz
tar -xvf libmemcached-1.0.18.tar.gz
cd libmemcached-1.0.18
./configure --prefix=/usr/local/libmemcached
make && make install
说明:
安装libmemcached之前要完成gcc、sasl相关组件的安装。否则会在编译过程中报错,报错问题解决后请执行make clean之后重新make。
- 安装memcached客户端。
首先安装zlib组件。
apt install zlib1g.dev
安装注意运行configure配置安装时,增加开启sasl参数。
wget http://pecl.php.net/get/memcached-2.2.0.tgz;
tar zxvf memcached-2.2.0.tgz;
cd memcached-2.2.0;
phpize5.6;
./configure --with-libmemcached-dir=/usr/local/libmemcached --enable-memcached-sasl;
make && make install;
- 增加pdo.ini配置。
使用find命令找到pdo.ini文件。
find / -name pdo.ini
默认应该在/etc/php/5.6/mods-available路径下。编辑该文件,增加以下两行:
extension=memcached.so memcached.use_sasl = 1
图2 增加pdo.ini配置 - 测试连接。
新增一个memcached.php文件,增加如下内容:
<?php $connect = new Memcached; //声明一个Memcached连接 $connect->setOption(Memcached::OPT_COMPRESSION, false); //关闭压缩 $connect->setOption(Memcached::OPT_BINARY_PROTOCOL, true); //使用二进制协议 $connect->setOption(Memcached::OPT_TCP_NODELAY, true); //关闭TCP网络延迟策略 $connect->addServer('{memcached_instance_ip}', 11211); //此处填写实例ip和端口 $connect->setSaslAuthData('{username}', '{password}'); //如果实例开启免密访问,则删除或者注释此行 $connect->set("DCS", "Come on!"); echo 'DCS: ',$connect->get("DCS"); echo "\n"; $connect->quit(); ?>
保存后运行情况如下:
[root@dcs-nodelete ~]# php memcached.php DCS: Come on! [root@dcs-nodelete ~]#