redis打包协议说明:
格式说明如下:
*4 #表示有4个参数
$4 #表示“参数”有三个字节("HSET"字符串为4个字节)
hset #执行的命令
$8 # key有 8个字节
wolys101 #key对应的值
$6 #field对应的长度
passwd #field对应的值
$12 # value的长度
wolysopen111 #value的值
# 一条语句结束
每行默认以 \r\n 结尾
$4 #表示“参数”有三个字节("HSET"字符串为4个字节)
hset #执行的命令
$8 # key有 8个字节
wolys101 #key对应的值
$6 #field对应的长度
passwd #field对应的值
$12 # value的长度
wolysopen111 #value的值
# 一条语句结束
每行默认以 \r\n 结尾
具体应用:
举个例子是新浪微博的架构、比如用户关注关系:
在 MySQL中是 <粉丝,关注的人>这样一行一行存储的。而在 Redis中你可以存成一个set,或者zset
大体流程是由 MySQL 复制到 Redis 的
基本结构应该是:
1. 发微博-- > 进入消息队列-- > 存入MySQL-- > 复制到Redis
2. 查询 -- > 查询缓存-- > 查询Redis -- > 查询MySQL
㈡ 快速迁移 MySQL →→ Redis
① MySQL 要导出的表 david_lin
mysql> desc david_lin;
<span style="font-family:KaiTi_GB2312;font-size:12px;">+---------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+---------+-------------+------+-----+---------+-------+
| id | int(11) | NO | PRI | NULL | |
| myname | varchar(25) | NO | UNI | NULL | |
| mymoney | int(11) | NO | | 0 | |
+---------+-------------+------+-----+---------+-------+
mysql> select * from david_lin;
+----+--------+---------+
| id | myname | mymoney |
+----+--------+---------+
| 1 | david | 100000 |
| 2 | rocky | 200000 |
+----+--------+---------+</span>
② 编写导出脚本
每行数据中执行的 Redis命令如下:HSET david_lin [myname] [mymoney]
<span style="font-family:KaiTi_GB2312;font-size:12px;">[root@odd ~]# cat mysql_to_redis.sql
SELECT CONCAT(
"*4\r\n",
\'$\', LENGTH(redis_cmd), \'\r\n\',
redis_cmd, \'\r\n\',
\'$\', LENGTH(redis_key), \'\r\n\',
redis_key, \'\r\n\',
\'$\', LENGTH(hkey), \'\r\n\',
hkey, \'\r\n\',
\'$\', LENGTH(hval), \'\r\n\',
hval, \'\r\'
)
FROM (
SELECT
\'HSET\' AS redis_cmd,
\'david\' AS redis_key,
myname AS hkey,
mymoney AS hval
FROM david_lin
) AS t</span>
③ 开始导入
<span style="font-family:KaiTi_GB2312;font-size:12px;"> mysql -uroot -poracle test --skip-column-names --raw < mysql_to_redis.sql | redis-cli --pipe
All data transferred. Waiting for the last reply...
Last reply received from server.
errors: 0, replies: 0
</span>
④ 在Redis 里查询
<span style="font-family:KaiTi_GB2312;font-size:12px;">redis 127.0.0.1:6379> hgetall david
1) "david"
2) "100000"
3) "rocky"
4) "200000"</span>