使用python 结合mysql和redis进行缓存设计

基于Python操作Redis

1、 创建示例数据库表
 
  
CREATE TABLE tb_signin_rank(
id INT,
user_name VARCHAR(10) COMMENT '用户名',
signin_num INT COMMENT '签到次数',
signin_time DATETIME COMMENT '签到时间',
gold_coin INT COMMENT '金币'
);
初始化数据
 
  
INSERT INTO tb_signin_rank
VALUES(1, 'shouke', 0, NULL, 0),
(2, 'chuangke', 0, NULL, 0),
(3, 'ishouke', 0, NULL, 0),
(4, 'keshou', 0, NULL, 0),
(5, 'shouke', 0, NULL, 0);

 redis缓存键值设计
key  value
表名:主键值:列名   列值
或者如下,通过为不同列之间建立较为紧密的关联
key  value
表名:主键值:列值1:列名2   列值2

示例:把id1的人的签到次数(假设为5)存储到redis中则可如下操作:
set('tb_signin_rank:1:signin_num', 5)
 
这样做的好处是,类似数据库一样,通过主键便可获取其它值。
 
示例:把id和用户名关联
set('tb_signin_rank:shouke:id', 1)
 
这样,通过用户名就可以查询出关联的id了:uid = r.get("tb_signin_rank:%s:id" % username)
 
redis关联数据库的数据处理
 
不要求强一致实时性的读请求,都由redis处理
要求强一致实时性的读请求,由数据库处理

案例
if __name__=="__main__":
    # print ("yes")
    # c = CrazyRedis()
    # c.lpush("b","v")
    # print ("yes")
    #
    pool = redis.ConnectionPool(host=host, port=6379, db=0)
    r = redis.Redis(connection_pool=pool)
    try:
        dbconn = pymysql.connect(
            host="127.0.0.1",
            port=3306,
            user="root",
            password="123456",
            database='ooxx',
        )
    except Exception as e:
        print(u'初始化数据连接失败:%s' % e)
        sys.exit()

        # 执行签到
    try:
        print("id=====%s" % id)
        db_cursor = dbconn.cursor()
        print("id=====%s" % id)
        for id in range(1, 6):
            db_cursor.execute(
                'UPDATE tb_signin_rank SET signin_num = signin_num + 1, signin_time = NOW(), gold_coin = gold_coin + (1 + RAND()*9) WHERE id = %s',
                (id,))
            db_cursor.execute('commit')
        # 更新缓存
        print("id=====%s"%id)
        r.zincrby("tb_signin_rank:id:signin_num", id, 1)
    except Exception as e:
        print(u'执行数据库更新操作失败:%s' % e)
        db_cursor.execute('rollback')
        db_cursor.close()
        exit()

    # 展示用户签到次数
    for id in range(1, 6):
        result = r.zscore('tb_signin_rank:id:signin_num', id)
        if not result:  # 不存在缓存,从数据库读取
            print(u'----从数据库读取用户签到次数----')
            try:
                db_cursor = dbconn.cursor()
                db_cursor.execute('SELECT signin_num FROM tb_signin_rank WHERE id = %s', (id,))
                result = db_cursor.fetchone()[0]
                # 更新到缓存
                r.zadd('tb_signin_rank:id:signin_num', id, result)
            except Exception as e:
                print(u'执行数据库查询操作失败:%s' % e)
                db_cursor.close()
        else:  # 存在缓存,从缓存读取
            print(u'----从缓存读取用户签到次数----')
            result = int(result)

        print(u'sigin_num of user[id=%s]: %s' % (id, result))


    # 展示签到排行榜
    result = r.zrevrange('tb_signin_rank:id:signin_num', 0, 10)
    print(u'签到排行榜:')
    print(result)
结果打印:
    ----从缓存读取用户签到次数----
sigin_num of user[id=1]: 1
----从缓存读取用户签到次数----
sigin_num of user[id=2]: 1
----从缓存读取用户签到次数----
sigin_num of user[id=3]: 1
----从缓存读取用户签到次数----
sigin_num of user[id=4]: 1
----从缓存读取用户签到次数----
sigin_num of user[id=5]: 18
签到排行榜:
['1', '2', '3', '4', '5']

参考:http://blog.sina.com.cn/s/blog_13cc013b50102wb5w.html

你可能感兴趣的:(redis)