为什么是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的一些对比和相关的实践。如有不足,请多多指正。

相关推荐
乌暮40 分钟前
数据库--JDBC编程
java·数据库·学习
Le1Yu1 小时前
哨兵原理、Redis分片、Redis数据结构、内存回收、缓存问题以及分布式事务相关内容(CAP、BASE、AT脏写及其解决、TCC、最大努力通知)
redis·分布式
CodeCraft Studio1 小时前
FastReport VCL发布2026.1版本:全面支持RAD Studio 13,PDF输出功能显著增强
数据库·pdf·rad studio·fastreport·报表设计器·报表开发工具·vcl
Elias不吃糖2 小时前
Qt 6以上版本都试用 连接 MySQL 数据库全流程(CMake 环境)
数据库·qt·mysql
不是二师兄的八戒2 小时前
MySQL 中 HAVING 子句的深度解析与实战指南
数据库·mysql
l1t2 小时前
Duckdb rusty_sheet插件使用心得
数据库·sql·lua·duckdb·rusty_sheet
asdfsdgss2 小时前
PostgreSQL 教程:json 与 jsonb 的数据验证机制差异及实战选择
数据库·postgresql·json
座山雕~2 小时前
MYSQL-超全基础以及用法--仅个人的速记笔记(1)
数据库·mysql
喜欢读源码的小白2 小时前
Spring Boot+MyBatis实现无限层级组织架构设计|邻接表vs闭包表性能对比|树形结构数据存储方案
java·数据库·组织结构·树级层级·无线层级