为什么是MC(Memcached)而不是Redis?

为什么是MC(Memcached)而不是Redis?

本文主要分享一下MC和redis作为缓存的一些比较,希望读者能够通过对比,了解二者的区别,能够在适合的场景中使用。

1: 并发模式

Redis:

​ 单线程,如果需要提升在多核心CPU上的性能,应该横向扩展多个Redis实例来适配多个核心

​ 将单个Redis实例与多线程数据存储进行比较是不公平的(官方说法)

Memcached:

多线程,默认4线程,可以配置。

2: 内存分配

Redis:

动态分配内存

Memcached:

内存预分配

3: 最佳实践

Redis:

  1. 在多核心CPU上,应该部署多个Redis实例
  2. 利用单线程处理的天生优势,可以用作分布式锁
  3. 因为可以持久化,可以当做数据库用。查询可以利用外挂索引(比如:全文检索)

Memcached:

  1. 极致的性能适用高并发场景,单个实例可以达到10wanQPS
  2. 因为内存预分配机制,所以千万不要大幅度改变缓存数据的大小
  3. 没有集群配置,如果做分布式缓存,可以在Client端扩展数据分片读取,写入。

总结

以上就是本次分享的所有内容,主要讲述一下Redis和MC的一些对比和相关的实践。如有不足,请多多指正。

相关推荐
寂寞旅行7 小时前
向量数据库Milvus的使用
数据库·milvus
闻哥7 小时前
Redis事务详解
java·数据库·spring boot·redis·缓存·面试
道亦无名7 小时前
aiPbMgrSendAck
java·网络·数据库
面向对象World10 小时前
正点原子Mini Linux 4.3寸800x480触摸屏gt115x驱动
linux·服务器·数据库
dinga1985102611 小时前
mysql之联合索引
数据库·mysql
微风中的麦穗11 小时前
【SQL Server 2019】企业级数据库系统—数据库SQL Server 2019保姆级详细图文下载安装完全指南
大数据·数据库·sqlserver·云计算·个人开发·运维必备·sqlserver2019
zjttsh12 小时前
MySQL加减间隔时间函数DATE_ADD和DATE_SUB的详解
android·数据库·mysql
顾北1212 小时前
SpringCloud 系列 04:Gateway 断言 / 过滤器 / 限流 一站式落地指南
java·开发语言·数据库
禹凕12 小时前
MYSQL——基础知识(NULL 值处理)
数据库·mysql
码云数智-大飞12 小时前
SQL Server 无法启动?常见原因及详细解决方法指南
数据库