基础拾遗

基础拾遗------特性详解

基础拾遗------webservice详解

基础拾遗------redis详解

基础拾遗------反射详解

基础拾遗------委托详解

基础拾遗------接口详解

基础拾遗------泛型详解

前言

  这篇文章和以往的基础拾遗有所不同,以前的介绍的都是c#基础,今天介绍的是redis。因为项目中一只在使用,我想现在大部分项目中都会用到nosql,缓存,今天就介绍一下redis.。废话少说下面开始正题。

1.redis是什么?

  Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库

对的redis就是一个存键值对的数据库,它不仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。【我习惯于存简单的key-value(value都是写成需要数据结构的对象)】。

2.redis使用场景

  1.取最新N个数据的操作

  2.排行榜应用,取TOP N 操作

  3.需要精确设定过期时间的应用

  4.计数器应用

  由于INCR等指令本身就具有原子操作的特性,所以我们完全可以利用redis的INCR、INCRBY、DECR、DECRBY等指令来实现原子计数的 效果,假如,在某种场景下有3个
客户端同时读取了mynum的值(值为2),然后对其同时进行了加1的操作,那么,最后mynum的值一定是5。不少网站 都利用redis的这个特性来实现业务上的统计计数需求。

  5.Uniq操作,获取某段时间所有数据排重值

  6.实时系统,反垃圾系统

  7.Pub/Sub构建实时消息系统

  8.构建队列系统

  9.缓存

最多的是用做缓存。他的操作所读是mysql的10倍不止。SET操作每秒钟 110000 次,GET操作每秒钟 81000 次。

3.redis数据结构

上边已经说了redis是一种高级的key:value存储系统,其中value支持五种数据类型:

1.字符串(strings)
2.字符串列表(lists)
3.字符串集合(sets)
4.有序字符串集合(sorted sets)
5.哈希(hashes)

3.1.key

1.key不要太长,尽量不要超过1024字节,这不仅消耗内存,而且会降低查找的效率;
2.key也不要太短,太短的话,key的可读性会降低;
3.在一个项目中,key最好使用统一的命名模式,例如power_loginname

3.2.字符串(strings)

strings类型是一个很基础的数据类型,也是任何存储系统都必备的数据类型.

操作如下:

set myredis 'kmonkeywyl'
get myredis

注:在遇到非字符串类型比如int,redis会默认转为string.

3.3.字符串列表(lists)

  redis中的lists在底层实现上并不是数组,而是链表.所以插入数据快,但定位性能操作较差。

lists的常用操作包括lpush、rpush、lpush,lrange等

操作如下:

//新建一个list叫做mylist,并在列表头部插入元素"1"
lpush mylist "
//在mylist右侧插入元素"2"
rpush mylist "
//在mylist左侧插入元素"0"
lpush mylist "
//列出mylist中从编号0到编号1的元素
lrange mylist
//列出mylist中从编号0到倒数第一个元素
lrange mylist  - 

  注:上边应用场景1,2,8都用到lists就会很方便,具体应用场景(消息队列,分页,博客评论)

3.3.字符串集合(sets)

集合对于我们来说应该不陌生,就是我们初中学的那个集合,针对于集合有几个概念不知道你还熟悉不?取交集、取并集、取差,不熟悉的自己去熟悉去吧。

操作如下:

//向集合myset中加入新元素"wyl"
sadd myset "wyl"
(integer)
sadd myset "kmonkey"
(integer)
//列出集合myset中的所有元素
smembers myset
) "wyl"
) "kmonkey"
//判断元素1是否在集合myset中,返回1表示存在
sismember myset "wyl"
(integer)
//判断元素是否在集合myset中,返回0表示不存在
sismember myset "wangyanling"
(integer)
//新建一个新的集合yourset
sadd yourset "
(integer)
sadd yourset "
(integer)
smembers yourset
) "
) "
//对两个集合求并集
sunion myset yourset
) "
) "wyl"
) "
) "kmonkey"

3.4.有序字符串集合(sorted sets)

和上边的无须集合唯一的差别是有序的每个元素都有一个序号score,主要是便于排序

操作如下:

zadd myzset  baidu.com
(integer)
//向myzset中新增一个元素360.com,赋予它的序号是3
zadd myzset  .com
(integer)
//向myzset中新增一个元素google.com,赋予它的序号是2
 zadd myzset  google.com
(integer)
//列出myzset的所有元素,同时列出其序号,可以看出myzset已经是有序的了。
zrange myzset  - with scores
) "baidu.com"
) "
) "google.com"
) "
) "360.com"
) "
//只列出myzset的元素
 zrange myzset  -
) "baidu.com"
) "google.com"
) "360.com"

3.5.哈希(hashes)

这就和结构数据库类似了。我是不喜欢在redis中使用hashes的。

操作如下

//建立哈希,并赋值
HMSET user: username wylpassword  age
OK
//列出哈希的内容
> HGETALL user:
) "username"
) "wyl"
) "password"
) "
) "age"
) "
//更改哈希中的某一个值
HSET user: password
(integer)
//再次列出哈希的内容
> HGETALL user:
) "username"
) "wyl"
) "password"
) "
) "age"
) "

4.redis常用指令

4.1.键值相关命令

keys * 取出当前所有的key

exists key查看key是否存在

del key删除key

expire key 设置key过期

ttl key获取key的有效时长

select 0 选择到0数据库 redis默认的数据库是0~15一共16个数据库

move key1 将当前数据库中的key移动到其他的数据库中

persist key 移除key的过期时间

random key 随机返回数据库里面的一个key

rename key2 key3 重命名key2 为key3

type key2 返回key的数据类型

4.2.服务器相关命令

ping PONG返回响应是否连接成功

echo 在命令行打印一些内容

select 0~15 编号的数据库

quit  /exit 退出客户端

dbsize 返回当前数据库中所有key的数量

info 返回redis的相关信息

config get dir/* 实时传储收到的请求

flushdb 删除当前选择数据库中的所有key

flushall 删除所有数据库中的数据库

4.3.字符串类型的操作

  set key value 存在就修改,不存在就创建

  get key 取值

  mset key1 value1 key2 value2 一次设置多个值

  mget key1 key2 :一次获取多个值

简单就这些大家可进一步去网上搜,因为太多我就部在这写了。

5.c#实例

(1)首先是redis连接服务基类。

 public abstract class BaseRedis
    {
        private IRedisClient _client;
        private string _configuration_string;

        public BaseRedis()
        {
        }

        public BaseRedis(string configuration_string)
        {
            this._configuration_string = configuration_string;
        }

        public void set_configuration_string(string configuration_string)
        {
            this._configuration_string = configuration_string;
        }

        public IRedisClient rs
        {
            get
            {
                if (string.IsNullOrWhiteSpace(this._configuration_string))
                {
                    return null;
                }
                if (this._client == null)
                {
                    this._client = new RedisClient(this._configuration_string);
                }
                return this._client;
            }
        }
    }

(2)配置文件

  其中路径可以直接写服务器ip地址。我把他写成字符串,是为了开发环境和正是环境都不用修改程序,直接做ip映射就行了。

(3)连接redis服务器

 public class DbPerfmon : RedisHelper
    {
        public DbPerfmon()
            : base()
        {
            string myredis = ConfigurationManager.AppSettings["Redis_Server_Url_Perfmon"].ToString();
            set_configuration_string(myredis);
        }

(4)简单操作

  lock (sessionLocker)
            {
                if (string.IsNullOrEmpty(synKey) || user == null)
                    return string.Empty;
                SessionObject so = null;
                using (rs)
                {
//获取redis值
                    so = rs.Get<SessionObject>(synKey);
                    if (so != null)
                    {
                        so.ResetLastTime();
                        if (!so.IsEffective())
                        {
                            so.SignType = signType;
                            so.User = user;
                        }
                    }
                    else
                    {
                        so = new SessionObject(user, signType, synKey);
                    }
                }
                DateTime dt = DateTime.Now.AddMinutes();
//添加redis
                rs.Set<SessionObject>(synKey, so);
//设置有效时长
                rs.ExpireEntryAt(synKey, dt);
                return so.Id;
            }

基础拾遗------redis详解的更多相关文章

  1. 基础拾遗------webservice详解

    基础拾遗 基础拾遗------特性详解 基础拾遗------webservice详解 基础拾遗------redis详解 基础拾遗------反射详解 基础拾遗------委托详解 基础拾遗----- ...

  2. 基础知识redis详解--【Foam番茄】

    Redis 学习方式: 上手就用 基本的理论先学习,然后将知识融汇贯通 nosql讲解 为什么要用Nosql 现在都是大数据时代 大数据一般的数据库无法进行分析处理了 至少要会Springboot+S ...

  3. Redis详解入门篇

    Redis详解入门篇 [本教程目录] 1.redis是什么2.redis的作者3.谁在使用redis4.学会安装redis5.学会启动redis6.使用redis客户端7.redis数据结构 – 简介 ...

  4. Redis详解入门篇(转载)

    Redis详解入门篇(转载) [本教程目录] 1.redis是什么2.redis的作者3.谁在使用redis4.学会安装redis5.学会启动redis6.使用redis客户端7.redis数据结构 ...

  5. Redis详解(五)——主从复制

    Redis详解(五)--主从复制 面临问题 机器故障.我们部署到一台 Redis 服务器,当发生机器故障时,需要迁移到另外一台服务器并且要保证数据是同步的.而数据是最重要的,如果你不在乎,基本上也就不 ...

  6. Spring Boot 之 Redis详解

    Redis是目前业界使用最广泛的内存数据存储. Redis支持丰富的数据结构,同时支持数据持久化. Redis还提供一些类数据库的特性,比如事务,HA,主从库. REmote DIctionary S ...

  7. Spring Data操作Redis详解

    Spring Data操作Redis详解 Redis是一种NOSQL数据库,Key-Value形式对数据进行存储,其中数据可以以内存形式存在,也可以持久化到文件系统.Spring data对Redis ...

  8. .Net使用Redis详解之ServiceStack.Redis(七) 转载https://www.cnblogs.com/knowledgesea/p/5032101.html

    .Net使用Redis详解之ServiceStack.Redis(七)   序言 本篇从.Net如何接入Reis开始,直至.Net对Redis的各种操作,为了方便学习与做为文档的查看,我做一遍注释展现 ...

  9. Hadoop基础-Idea打包详解之手动添加依赖(SequenceFile的压缩编解码器案例)

    Hadoop基础-Idea打包详解之手动添加依赖(SequenceFile的压缩编解码器案例) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.编辑配置文件(pml.xml)(我 ...

随机推荐

  1. ABP框架 - 授权

    文档目录 本节内容: 简介 关于 IPermissionChecker 定义许可 检查许可 使用 AbpAuthorize特性 AbpAuthorize特性注意事项 废止授权 使用 IPermissi ...

  2. AVL树原理及实现(C语言实现以及Java语言实现)

    欢迎探讨,如有错误敬请指正 如需转载,请注明出处http://www.cnblogs.com/nullzx/ 1. AVL定义 AVL树是一种改进版的搜索二叉树.对于一般的搜索二叉树而言,如果数据恰好 ...

  3. ASP.NET Web API与Owin OAuth:调用与用户相关的Web API

    在前一篇博文中,我们通过以 OAuth 的 Client Credential Grant 授权方式(只验证调用客户端,不验证登录用户)拿到的 Access Token ,成功调用了与用户无关的 We ...

  4. ASP.NET(IIS)出现"没有为请求类型"GET"找到 HTTP 处理程序"

    pasting 环       境:windows 2003 IIS6.0 程序支持:ASP.NET .NET版本:2.0.4.0 问    题:之前服务器上各大网站运行良好,今天突然出现:" ...

  5. 分布式系统理论进阶 - Paxos

    引言 <分布式系统理论基础 - 一致性.2PC和3PC>一文介绍了一致性.达成一致性需要面临的各种问题以及2PC.3PC模型,Paxos协议在节点宕机恢复.消息无序或丢失.网络分化的场景下 ...

  6. 分布式服务协调员zookeeper - 应用场景和监控

    zookeeper在分布式系统中作为协调员的角色,可应用于Leader选举.分布式锁.配置管理等服务的实现.以下我们从zookeeper提供的API.应用场景和监控三方面学习和了解zookeeper( ...

  7. 【分布式】Zookeeper使用--Java API

    一.前言 上一篇博客我们通过命令行来操作Zookeper的客户端和服务端并进行相应的操作,这篇主要介绍如何通过API(JAVA)来操作Zookeeper. 二.开发环境配置 首先打开Zookeeper ...

  8. 自己动手,实现一种类似List<T>的数据结构(二)

    前言: 首先,小匹夫要祝各位看官圣诞快乐,新年愉快-.上一篇文章<自己动手,实现一种类似List<T>的数据结构(一)> 介绍了一下不依靠List<T>实现的各种接 ...

  9. C#使用Jquery zTree实现树状结构显示_异步数据加载

    JQuery-Ztree下载地址:https://github.com/zTree/zTree_v3 JQuery-Ztree数结构演示页面:  http://www.treejs.cn/v3/dem ...

  10. svn 提交代码报错

    svn 提交代码报错 最近新安装了TortoiseSvn 1.92,在上传代码,其中有新增加的文件,出现如下错误: 解决方法: 1.用vs生成patch文件 2.生成的patch文件中讲nonexis ...