redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorted set --有序集合)和hash(哈希类型).这些数据类型都支持push/pop.add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的.在此基础上,redis支持各种不同方式的排序.与memcached一样,为了保证效率,数据都是缓存在内存中.区别的是redis会周期性的把更新的数
redis中我们会经常用到事务.订阅与发布.Lua脚本以及慢查询日志,接下来我们就一一对他们进行探讨学习. 4.1事务 redis通过MULTI.DISCARD.EXEC和WATCH四个命令来实现事务功能. 4.1.1 事务 事务提供了一种“将多个命令打包,一次性按顺序地执行”的机制,并且事务在执行的期间不会主动中断——服务器在执行完所有的命令之后,才会继续处理其他客户端的其他命令.如下: redis> MULTI OK redis> SET book-name "Mastering
书里给了一段代码,假如有个结构体如下: struct test { char a; int b; long c; void* d; int e; char* f } 这个结构体的大小是多少呢? 先来看一下 C 语言中不同数据类型的长度,因操作系统而异: 数据类型 bool char short int float double long long long 指针 长度(字节/64位) 1 1 2 4 4 8 8 8 8 长度(字节/32位) 1