被我们广泛用在缓存场景,一是能提高业务系统的性能,二是为数据库抵挡了高并发的流量请求,[点我 -> 解密 Redis 为什么这么快的秘密](https://mp.weixin.qq.com/s/z4VjDaDDbspFz1rIBwazIA)。把 Redis 作为缓存组件,需要防止出现以下的一些问题,否则可能会造成生产事故。- [Redis 缓存满了怎么办?](https://mp.weixin.qq.com/s/H7BN-gCvbJ2S2DT31XMzzQ)- [缓存穿透、缓存击穿、缓存雪崩如何解决?](https://mp.weixin.qq.com/s/...
为查询缓存优化你的查询大多数的 MySQL 服务器都开启了查询缓存。这是提高性最有效的方法之一,而且这是被 MySQL 的数据库引擎处理的。当有很多相同的查询被执行了多次的时候,这些查询结果会被放到一个缓存中,这样,后续的相同的查询就不用操作表而直接访问缓存结果了。这里最主要的问题是,对于程序员来说,这个事情是很容易被忽略的。因为,我们某些查询语句会让 MySQL 不使用缓存。MySQL 的查询缓存对这个函数不起作用。所以...
# 问题描述客户反馈使用缓存数据库 Redis 程序报错无法找到数据库# 问题分析每个 Redis 实例中可使用的DB数受实例类型的影响,其中:* 启用分片集群的Redis实例最多可使用 1 个 DB。* 不启用分片集群的Redis实例最多可使用 16 个 DB。# 解决方案1.查看程序中的数据库配置,数据库配置 index 为 1````undefined#采用哪个数据库spring.redis.database=1````2.使用原生客户端连接,验证问题。```bashredis-cn02co9plm7...
# 问题描述客户反馈使用缓存数据库 Redis 程序报错无法找到数据库 # 问题分析 每个 Redis 实例中可使用的DB数受实例类型的影响,其中:* 启用分片集群的Redis实例最多可使用 1 个 DB。* 不启用分片集群的Redis实例最多可使用 16 个 DB。 # 解决方案1.查看程序中的数据库配置,数据库配置 index 为 1 ```#采用哪个数据库spring.redis.database=1```2.使用原生客户端连接,验证问题。```bashredis-cn02co9plm7v1...
# 问题描述客户反馈使用缓存数据库 Redis 程序报错无法找到数据库 # 问题分析 每个 Redis 实例中可使用的DB数受实例类型的影响,其中:* 启用分片集群的Redis实例最多可使用 1 个 DB。* 不启用分片集群的Redis实例最多可使用 16 个 DB。 # 解决方案1.查看程序中的数据库配置,数据库配置 index 为 1 ```#采用哪个数据库spring.redis.database=1```2.使用原生客户端连接,验证问题。```bashredis-cn02co9plm7v1...
作为缓存数据库,Redis 通常需要执行较多的数据存取操作,这些操作会带来较大的网络带宽消耗。缓存数据库 Redis 实例规格不同,默认带宽也不同,当业务流量超过实例的默认带宽时,应用服务的数据访问性能会受到影响。本文提供了一些合理使用实例带宽的优化建议供您参考。 带宽问题影响缓存数据库 Redis 版支持带宽限流机制,当业务流量超过实例的默认带宽时,系统会对每秒超出带宽的流量做堆积处理,如果流量堆积持续时间过长,可能会导致...
本文档介绍如何在火山引擎缓存数据库 Redis 版的 Golang 客户端中集成 dns-stale-cache 插件。 前提条件您的 Golang 必须是 1.18 或更高版本。 您的 Redis 客户端使用的 go-redis SDK 必须是 v6 、v7、v8 或 v9 版本。dns-stale-cache 不支持其他版本的 go-redis SDK。 把 dns-stale-cache 插件集成到 SDK 工程不同版本的 go-redis SDK 的集成方式不同。参见以下示例代码。 go-redis SDK v6go import ( "fmt" "time" "...
火山引擎缓存数据库 Redis 版是与Redis兼容的全托管缓存和存储服务,以其超高读写性能为企业应用赋能
缓存数据库 Redis 版支持通过 Lua 脚本来处理 CAS(compare-and-swap)命令,满足 Redis 原子性操作需求,提升 Redis 性能。本文介绍通过 Redis 使用 Lua 脚本的基本语法与使用限制和建议。 Lua 脚本命令下表列举了缓存数据库 Redis 版支持的 Lua 脚本命令和功能简介。 命令 功能说明 EVAL 执行给定的脚本和参数,并返回结果。 EVALSHA 当通过 EVAL 命令执行较长的 Lua 脚本时,会占用较多带宽。为避免上述问题,您可以使用 EVALSHA 命令...
# 问题描述Jedis如何使用非Default用户连接连接缓存数据库Redis# 问题分析缓存数据库Redis提供了账号管理功能,可以创建多个账号,帮助您更加灵活地管理实例,最大限度地避免误操作,提升数据安全性。非Default用户连接需要指定用户名。# 解决方案Maven项目中增加依赖项的方式安装Jedis,在pom.xml中加入相应依赖即可:``` redis.clients jedis 3.7.0 ```Jedis使用非Default用户连接redis的时候需要指定用户名密码格式...
# 问题描述Jedis如何使用非Default用户连接连接缓存数据库Redis# 问题分析缓存数据库Redis提供了账号管理功能,可以创建多个账号,帮助您更加灵活地管理实例,最大限度地避免误操作,提升数据安全性。非Default用户连接需要指定用户名。# 解决方案Maven项目中增加依赖项的方式安装Jedis,在pom.xml中加入相应依赖即可:````undefined redis.clients jedis 3.7.0 ````Jedis使用非Default用户连接redis的时候需要指定用户名密码...
redis-cli 在连接到 Redis 时使用未加密的 TCP 连接。选项 Build_TLS=Yes 在 redis-cli 编译期间启用 SSL/TLS,支持SSL连接功能。# 解决方案### 1.编译redis-cli客户端```sh$sudo yum install gcc jemalloc-dev... 服务器上使用ssl连接缓存数据库Redis```bash[root@iv-38der6cb2agc9tvqv0qf redis-stable]# ./src/redis-cli --cacert /root/r-cngl0inipcl0h4nmtt_ca_certificate.pem --cert /root/r-cngl0inipcl0h4nmtt_certi...
在某些情况下,由于源 Redis 数据库未开放 sync 或 psync 复制权限,因此导致无法通过火山引擎数据库传输服务 DTS 迁移数据。此时,您可以通过 redis-shake 工具使用 RDB 文件,将源 Redis 数据库的全量数据离线迁移至目标 Redis 数据库中。 使用 RDB 文件迁移数据时,可以在不依赖 sync 和 psync 权限的情况下,将自建 Redis 或第三方云 Redis 数据库的数据迁移至火山引擎缓存数据库 Redis 版。关于 redis-shake 的更多信息,请参见 re...