热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Redis简介以及数据类型存储

由于我们在大型互联网项目当中,用户访问量比较大,比较多,会产生并发问题,对于此,我们该如何解决呢,Redis横空出世,首先,我们来简单的认识一下Redis,详细介绍如下所示:

        由于我们在大型互联网项目当中,用户访问量比较大,比较多,会产生并发问题,对于此,我们该如何解决呢,Redis横空出世,首先,我们来简单的认识一下Redis,详细介绍如下所示:

         Redis是一个开源的,使用C语言编写,面向“键/值”对类型数据的分布式NoSQL数据库系统,特点是高性能,持久存储,适应高并发的应用场景。Redis纯粹为应用而产生,她是一个高性能的Key-Value数据库,并且操作了多种语言的API性能测试将诶过表示SET操作每秒钟可达110000次,GET操作每秒81000次,当然不同的服务器配置性能不同,redis目前提供五种数据类型,string(字符串),list(链表),hash(哈希),set(集合)及zset(sorted set)有序集合。说到Redis,小伙伴们可能会想到Memcached,小编给小伙伴们推荐一篇文章,文中详细的描述了Redis和Memcached,有兴趣的小伙伴可以点击相关链接,进行查看哦`(*∩_∩*)′!

         在前面的介绍中,我们知道,redis目前提供五种数据类型,string(字符串)、list(链表)、hash(哈希)、set(集合)、zset(sorted set)有序集合,那么这些是如何进行存储的呢?下面小编来详细的介绍一下。

         第一步,我们需要新建一个空白项目,如下图所示:

         
         第二步,添加一个控制台应用程序,如下图所示:

         
         第三步,有三个dll文件,redis为c#开放的API,我们就是通过她来操作redis,为此,我们需要引用dll文件,点击浏览,如下图所示:

         

         第四步,找到需要引用的dll文件,如下图所示:

         

         接着,我们就来看如何对数据类型进行存储,首先我们来看String类型,String类型是最常用的一种数据类型,普通的key/value存储都可以归为此类,一个key对应一个value,string类型二进制的,Redis的string可以包含任何数据,比如jpg或者序列化的对象,我们来看具体的代码该如何编写,代码如下所示:

         

using System;using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using ServiceStack.Redis;

namespace RedisApp
{
class Program
{
static void Main(string[] args)
{
//字符串类型
var client = new RedisClient("local", 6379); //首先new一个客户端
client.Set("name", "laowang"); // 存储字符串类型
string userName = client.Get("name"); //通过get取值
Console.WriteLine(userName);
Console.ReadKey();

}
}
}

        接着,我们来看哈希表的存储,hash是一个string类型的field和value的映射表,hash特别适合存储对象,相对于讲对象的每个字段存成单个string类型,一个对象存储在hash类型中会占用更少的内存,而且可以更方便的存取整个对象。作为一个key  value存在,很多开发者自然的使用set/get方式来使用Redis,实际上这并不是最优化的使用方法,尤其在未启用VM情况下,Redis全部数据需要放入内存,节约内存尤其重要,我们来看具体的代码:

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;using ServiceStack.Redis;namespace RedisApp{    class Program    {        static void Main(string[] args)        {            //字符串类型            var client = new RedisClient("local", 6379); //首先new一个客户端            client.Set("name", "laowang");       // 存储字符串类型            string userName = client.Get("name");  //通过get取值            Console.WriteLine(userName);            Console.ReadKey();            //哈希存储结果            client.SetEntryInHash("userinfoId", "name", "zhangsan");            client.GetHashKeys("userinfoId"); //获取所有的key            client.GetHashValues("userinfoId"); //获取所有的值          }    }}
        我们再来看list类型,list是一个链表结构的,主要功能是push,pop获取一个范围的左右的值等,操作中key理解为链表名称,Redis的list类型其实就是一个每个字元素都是string类型的双向链表,我们可以通过push,pop操作从链表的头部或者尾部添加删除元素,这样list既可以作为栈,也可以作为队列,Redis list的实现为一个双向链表,既可以支持反向查找和遍历,更方便操作,不过带来了部分额外的内存开销,Redis内部的很多实现,包括发送缓冲队列等也都是用的这个数据结构,代码如下所示:

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;using ServiceStack.Redis;namespace RedisApp{    class Program    {        static void Main(string[] args)        {            //字符串类型            var client = new RedisClient("local", 6379); //首先new一个客户端            client.Set("name", "laowang");       // 存储字符串类型            string userName = client.Get("name");  //通过get取值            Console.WriteLine(userName);            Console.ReadKey();            //哈希存储结果            client.SetEntryInHash("userinfoId", "name", "zhangsan");            client.GetHashKeys("userinfoId"); //获取所有的key            client.GetHashValues("userinfoId"); //获取所有的值            //队列使用            client.EnqueueItemOnList("name1", "laowang");//入队            client.EnqueueItemOnList("name1", "laoma");//入队            int length = client.GetListCount("nama1");            for (int i = 0; i 
        Set类型
        她是string类型的无序集合,set是通过hash table实现的,添加、删除和查找,对集合我们可以取并集、交集、差集。对Set类型进行操作,如下所示:

        

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;using ServiceStack.Redis;namespace RedisApp{    class Program    {        static void Main(string[] args)        {            //字符串类型            var client = new RedisClient("local", 6379); //首先new一个客户端            client.Set("name", "laowang");       // 存储字符串类型            string userName = client.Get("name");  //通过get取值            Console.WriteLine(userName);            Console.ReadKey();            //哈希存储结果            client.SetEntryInHash("userinfoId", "name", "zhangsan");            client.GetHashKeys("userinfoId"); //获取所有的key            client.GetHashValues("userinfoId"); //获取所有的值            //队列使用            client.EnqueueItemOnList("name1", "laowang");//入队            client.EnqueueItemOnList("name1", "laoma");//入队            int length = client.GetListCount("nama1");            for (int i = 0; i  hashset = client.GetAllItemsFromSet("a3");            foreach (string str in hashset)            {                Console.WriteLine(str);            }        }    }}
       Sorted Set类型
       Sorted set是set的一个升级版本,她是在set的基础撒花姑娘增加了一个顺序的属性,这一个属性在添加修改,元素的时候可以指定,每次指定后,zset(表示有序集合)会自动重新按新的值调整顺序,可以理解为有序列的表,一列存value,一列存顺序,操作中key理解为zset的名字。Redis sorted set的使用场景与set类似,区别是set不是自动有序的,而sorted set可以通过用户额外提供一个优先级(scord)的参数来为成员排序,并且是插入有序的,即自动排序,当你需要一个有序的并且不重复的集合列表,那么可以选择sorted set数据结构,代码如下所示:

       

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;using ServiceStack.Redis;namespace RedisApp{    class Program    {        static void Main(string[] args)        {            //字符串类型            var client = new RedisClient("local", 6379); //首先new一个客户端            client.Set("name", "laowang");       // 存储字符串类型            string userName = client.Get("name");  //通过get取值            Console.WriteLine(userName);            Console.ReadKey();            //哈希存储结果            client.SetEntryInHash("userinfoId", "name", "zhangsan");            client.GetHashKeys("userinfoId"); //获取所有的key            client.GetHashValues("userinfoId"); //获取所有的值            //队列使用            client.EnqueueItemOnList("name1", "laowang");//入队            client.EnqueueItemOnList("name1", "laoma");//入队            int length = client.GetListCount("nama1");            for (int i = 0; i  hashset = client.GetAllItemsFromSet("a3");            foreach (string str in hashset)            {                Console.WriteLine(str);            }            //Sorted Set类型            client.AddItemToSortedSet("a5", "ffff");            client.AddItemToSortedSet("a5", "bbbb");            client.AddItemToSortedSet("a5", "gggg");            client.AddItemToSortedSet("a5", "cccc");            client.AddItemToSortedSet("a5", "aaaa");            System.Collections.Generic.List list = client.GetAllItemsFromSortedSet("a5");            foreach (string str in list)            {                Console.WriteLine(str);            }        }    }}
       小编寄语:该博客,小编主要简单的介绍了一下Redis和数据存储的类型,在redis中还有一个很重要的事儿,差点儿忘了,文件并发(日志处理),多线程操作同一个文件时会出现并发问题,解决的一个办法就是给文件加锁(lock),但是这样的话,一个线程操作文件时,其他的都得等待,这样的话性能非常差,另外一个解决方案,就是先将数据放在队列中,然后开启一个线程,负责从队列中取出数据,再写到文件中。对于这块的内容小编还不是很理解,还请各位小伙伴多多指教哦`(*∩_∩*)′!


推荐阅读
  • Oracle优化新常态的五大禁止及其性能隐患
    本文介绍了Oracle优化新常态中的五大禁止措施,包括禁止外键、禁止视图、禁止触发器、禁止存储过程和禁止JOB,并分析了这些禁止措施可能带来的性能隐患。文章还讨论了这些禁止措施在C/S架构和B/S架构中的不同应用情况,并提出了解决方案。 ... [详细]
  • Centos下安装memcached+memcached教程
    本文介绍了在Centos下安装memcached和使用memcached的教程,详细解释了memcached的工作原理,包括缓存数据和对象、减少数据库读取次数、提高网站速度等。同时,还对memcached的快速和高效率进行了解释,与传统的文件型数据库相比,memcached作为一个内存型数据库,具有更高的读取速度。 ... [详细]
  • 云原生应用最佳开发实践之十二原则(12factor)
    目录简介一、基准代码二、依赖三、配置四、后端配置五、构建、发布、运行六、进程七、端口绑定八、并发九、易处理十、开发与线上环境等价十一、日志十二、进程管理当 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了python面试题——数据库和缓存(46题)相关的知识,希望对你有一定的参考价值。1、列举常见的关系型数据库和非关系型都有那些? ... [详细]
  • 开发笔记:Memcached高性能内存对象缓存系统
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Memcached高性能内存对象缓存系统相关的知识,希望对你有一定的参考价值。一、Memcached概述 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 本文介绍了一种轻巧方便的工具——集算器,通过使用集算器可以将文本日志变成结构化数据,然后可以使用SQL式查询。集算器利用集算语言的优点,将日志内容结构化为数据表结构,SPL支持直接对结构化的文件进行SQL查询,不再需要安装配置第三方数据库软件。本文还详细介绍了具体的实施过程。 ... [详细]
  • 深入解析Linux下的I/O多路转接epoll技术
    本文深入解析了Linux下的I/O多路转接epoll技术,介绍了select和poll函数的问题,以及epoll函数的设计和优点。同时讲解了epoll函数的使用方法,包括epoll_create和epoll_ctl两个系统调用。 ... [详细]
  • 本文介绍了NetCore WebAPI开发的探索过程,包括新建项目、运行接口获取数据、跨平台部署等。同时还提供了客户端访问代码示例,包括Post函数、服务器post地址、api参数等。详细讲解了部署模式选择、框架依赖和独立部署的区别,以及在Windows和Linux平台上的部署方法。 ... [详细]
  • 以管理员身份打开命令行粘贴上面 ... [详细]
  • 如何搭建服务器环境php(2023年最新解答)
    导读:本篇文章编程笔记来给大家介绍有关如何搭建服务器环境php的相关内容,希望对大家有所帮助,一起来看看吧。本文目录一览:1、怎么搭建p ... [详细]
  • 数据库基本介绍
    1、数据库基本知识概念:数据库:database(DB),是一种存储数据的仓库数据库是根据数据结构组织、存储和 ... [详细]
  • 实战项目memcached+tomcat+session+nginx在工作中的应用和配置
    环境介绍:公司根据实际需要搭建一个购物网站,当用户购物时可以将不同商品,放到同一个购物车中进行同时付款。环境的搭建:外网用户IP地址:1.1.1.1主机名:fanxiaohui用户 ... [详细]
  • 对于WEB应用集群的技术实现而言,最大的难点就是如何能在集群中的多个节点之间保持数据的一致性,会话(Session)信息是这 ... [详细]
author-avatar
hy11011_847
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有