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

Redis简单介绍以及数据类型存储

因为我们在大型互联网项目其中。用户訪问量比較大,比較多。会产生并发问题,对于此。我们该怎样解决呢。Redis横空出世,首先,我们来简单的认识一下Redis。具体介绍例如以下所看到的

        因为我们在大型互联网项目其中。用户訪问量比較大,比較多。会产生并发问题,对于此。我们该怎样解决呢。Redis横空出世,首先,我们来简单的认识一下Redis。具体介绍例如以下所看到的:

         Redis是一个开源的。使用C语言编写。面向“键/值”对类型数据的分布式NoSQL数据库系统,特点是高性能。持久存储,适应高并发的应用场景。Redis纯粹为应用而产生,她是一个高性能的Key-Value数据库,而且操作了多种语言的API性能測试将诶过表示SET操作每秒钟可达110000次。GET操作每秒81000次。当然不同的server配置性能不同,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),可是这种话,一个线程操作文件时,其它的都得等待,这种话性能非常差,另外一个解决方式。就是先将数据放在队列中,然后开启一个线程,负责从队列中取出数据,再写到文件里。

对于这块的内容小编还不是非常理解。还请各位小伙伴多多不吝赐教哦`(*∩_∩*)′!

Redis简单介绍以及数据类型存储


推荐阅读
  • 如果应用程序经常播放密集、急促而又短暂的音效(如游戏音效)那么使用MediaPlayer显得有些不太适合了。因为MediaPlayer存在如下缺点:1)延时时间较长,且资源占用率高 ... [详细]
  • Python 数据可视化实战指南
    本文详细介绍如何使用 Python 进行数据可视化,涵盖从环境搭建到具体实例的全过程。 ... [详细]
  • 两个条件,组合控制#if($query_string~*modviewthread&t(&extra(.*)))?$)#{#set$itid$1;#rewrite^ ... [详细]
  • 使用Jsoup解析并遍历HTML文档时,该库能够高效地生成一个清晰、规范的解析树,即使源HTML文档存在格式问题。Jsoup具备强大的容错能力,能够处理多种异常情况,如未闭合的标签等,确保解析结果的准确性和完整性。 ... [详细]
  • 在 LeetCode 的“有效回文串 II”问题中,给定一个非空字符串 `s`,允许删除最多一个字符。本篇深入解析了如何判断删除一个字符后,字符串是否能成为回文串,并提出了高效的优化算法。通过详细的分析和代码实现,本文提供了多种解决方案,帮助读者更好地理解和应用这一算法。 ... [详细]
  • [c++基础]STL
    cppfig15_10.cppincludeincludeusingnamespacestd;templatevoidprintVector(constvector&integer ... [详细]
  • ZooKeeper 入门指南
    本文将详细介绍ZooKeeper的工作机制、特点、数据结构以及常见的应用场景,包括统一命名服务、统一配置管理、统一集群管理、服务器动态上下线和软负载均衡。 ... [详细]
  • 自动验证时页面显示问题的解决方法
    在使用自动验证功能时,页面未能正确显示错误信息。通过使用 `dump($info->getError())` 可以帮助诊断和解决问题。 ... [详细]
  • 本文介绍了如何使用 CMD 批处理脚本进行文件操作,包括将指定目录下的 PHP 文件重命名为 HTML 文件,并将这些文件复制到另一个目录。 ... [详细]
  • 解决 Windows Server 2016 网络连接问题
    本文详细介绍了如何解决 Windows Server 2016 在使用无线网络 (WLAN) 和有线网络 (以太网) 时遇到的连接问题。包括添加必要的功能和安装正确的驱动程序。 ... [详细]
  • CentOS 7 中 iptables 过滤表实例与 NAT 表应用详解
    在 CentOS 7 系统中,iptables 的过滤表和 NAT 表具有重要的应用价值。本文通过具体实例详细介绍了如何配置 iptables 的过滤表,包括编写脚本文件 `/usr/local/sbin/iptables.sh`,并使用 `iptables -F` 清空现有规则。此外,还深入探讨了 NAT 表的配置方法,帮助读者更好地理解和应用这些网络防火墙技术。 ... [详细]
  • 在使用Eclipse进行调试时,如果遇到未解析的断点(unresolved breakpoint)并显示“未加载符号表,请使用‘file’命令加载目标文件以进行调试”的错误提示,这通常是因为调试器未能正确加载符号表。解决此问题的方法是通过GDB的`file`命令手动加载目标文件,以便调试器能够识别和解析断点。具体操作为在GDB命令行中输入 `(gdb) file `。这一步骤确保了调试环境能够正确访问和解析程序中的符号信息,从而实现有效的调试。 ... [详细]
  • 系统数据实体验证异常:多个实体验证失败的错误处理与分析
    在使用MVC和EF框架进行数据保存时,遇到了 `System.Data.Entity.Validation.DbEntityValidationException` 错误,表明存在一个或多个实体验证失败的情况。本文详细分析了该错误的成因,并提出了有效的处理方法,包括检查实体属性的约束条件、调试日志的使用以及优化数据验证逻辑,以确保数据的一致性和完整性。 ... [详细]
  • MySQL的查询执行流程涉及多个关键组件,包括连接器、查询缓存、分析器和优化器。在服务层,连接器负责建立与客户端的连接,查询缓存用于存储和检索常用查询结果,以提高性能。分析器则解析SQL语句,生成语法树,而优化器负责选择最优的查询执行计划。这一流程确保了MySQL能够高效地处理各种复杂的查询请求。 ... [详细]
  • 装饰者模式(Decorator):一种灵活的对象结构设计模式
    装饰者模式(Decorator)是一种灵活的对象结构设计模式,旨在为单个对象动态地添加功能,而无需修改原有类的结构。通过封装对象并提供额外的行为,装饰者模式比传统的继承方式更加灵活和可扩展。例如,可以在运行时为特定对象添加边框或滚动条等特性,而不会影响其他对象。这种模式特别适用于需要在不同情况下动态组合功能的场景。 ... [详细]
author-avatar
so直接离我远点儿
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有