一、什么是Redis?

  Redis是一个高性能的key-value内存数据库。


二、为什么使用Redis?

  Redis是NoSQL数据库,相比传统关系型数据库,内存数据库读写更快。


三、Redis怎么获取?

  http://www.redis.cn/download.html


四、Redis环境怎么搭建?

  1、Redis通常部署在Linux上,所以部署的事和监控的事有专门的运维去做;

  2、学习时如果没有Linux环境,可以直接启动一个Windows版的Redis。


以Windows环境为例:

五、启动Redis

  1、解压 redis-2.8.zip 中的 redis-2.8\bin\release\redis-2.8.17.zip 到 D:\redis 文件夹中

  2、进入D盘命令:d:

     进入redis文件夹命令:cd redis

     启动redis命令:redis-server.exe redis.conf(当然可以用文件夹中的redis.windows.conf,ps:记得修改配置文件的maxmemory 1gb,否则启动将会报错)


六、客户端连接redis

  命令:redis-cli.exe -h 172.16.10.140(自己的ip) -h 6379

  输入info 命令可以查看redis的相关信息


如果提示 NOAUTH Authentication required. 需要输入密码  auth + 空格 + 密码

七、.Net中使用Redis

  下载相关程序包,推荐:ServiceStack.Redis

 using ServiceStack.Redis;
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Linq;
using System.Text; namespace ConApp_Redis_Test
{
class Program
{
static RedisClient redisClient = new RedisClient(ConfigurationManager.AppSettings["IPAddress"], );//redis服务IP和端口
static string totalCount = ConfigurationManager.AppSettings["TotalCount"];
static string searchCount = ConfigurationManager.AppSettings["SearchCount"]; static void Main(string[] args)
{
try
{
redisClient.Password = ConfigurationManager.AppSettings["Password"];
Console.WriteLine("准备数据中..."); int pTotalCount = int.Parse(totalCount);
int pSearchCount = int.Parse(searchCount);
DateTime dt_Write = DateTime.Now;
List<UserModel> userModelList = new List<UserModel>();
for (int i = ; i <= pTotalCount; i++)
{
UserModel userModel = new UserModel();
userModel.Id = i;
userModel.MobileNum = "".Substring(, - i.ToString().Length) + i.ToString();
userModel.OpenId = Guid.NewGuid().ToString().Replace("-", "");
userModelList.Add(userModel);
} Console.WriteLine("正在插入数据...");
if (userModelList != null && userModelList.Any())
{
for (int i = ; i < userModelList.Count; i++)
{
UserModel userModel = userModelList[i];
if ((i + ) % == )
{
Console.WriteLine("当前Id:" + userModel.Id + ",MobileNum: " + userModel.MobileNum + ",OpenId:" + userModel.OpenId);
}
redisClient.HSet("User", Encoding.UTF8.GetBytes(userModel.MobileNum), Encoding.UTF8.GetBytes("{Id: " + userModel.Id + ", MobileNum: " + userModel.MobileNum + ", OpenId: " + userModel.OpenId + "}"));
}
}
Console.ForegroundColor = ConsoleColor.Red;
Console.WriteLine("随机写入" + pTotalCount + "条数据消耗时间为: " + (DateTime.Now - dt_Write).Seconds + "秒"); ; // 清除控制台颜色
Console.ForegroundColor = ConsoleColor.White;
Random randon = new Random(); DateTime dt_Read = DateTime.Now;
for (int i = ; i <= pSearchCount; i++)
{
int index = randon.Next(, pTotalCount + );
// Console.WriteLine("随机抽选值: " + index);
string search = "".Substring(, - index.ToString().Length) + index.ToString();
// Console.WriteLine("当前搜索: " + search); //byte[] bytes_Get = redisClient.Get(search);
//Console.WriteLine(Encoding.UTF8.GetString(bytes_Get)); byte[] bytes_HGet = redisClient.HGet("User", Encoding.UTF8.GetBytes(search)); if (i % == )
{
Console.WriteLine(Encoding.UTF8.GetString(bytes_HGet));
}
}
Console.ForegroundColor = ConsoleColor.Red;
Console.WriteLine("随机读取" + pSearchCount + "条数据消耗时间为: " + (DateTime.Now - dt_Read).Milliseconds + "毫秒"); ;
}
catch (Exception)
{
Console.WriteLine("出错了...");
} Console.ReadKey(true);
}
} public class UserModel
{
public int Id { get; set; }
public string MobileNum { get; set; }
public string OpenId { get; set; }
}
}

八、相当文档

  推荐:http://www.redisfans.com/


九、结语

  redis只是NoSQL的一种,几乎包含所有流行语言的开发包,拥有专门的组织维护,能够成为大多数开发人员首选的NoSQL数据库,肯定在性能上、安全上都做到让人满意的程度了。

  不要局限于redis,可以使用其他的NoSQL数据库,通过实际应用、对比、总结才能得出好坏。

  每天多学一点,量变产生质变。

Redis应用的更多相关文章

  1. 使用redis构建可靠分布式锁

    关于分布式锁的概念,具体实现方式,直接参阅下面两个帖子,这里就不多介绍了. 分布式锁的多种实现方式 分布式锁总结 对于分布式锁的几种实现方式的优劣,这里再列举下 1. 数据库实现方式 优点:易理解 缺 ...

  2. Ignite性能测试以及对redis的对比

    测试方法 为了对Ignite做一个基本了解,做了一个性能测试,测试方法也比较简单主要是针对client模式,因为这种方法和使用redis的方式特别像.测试方法很简单主要是下面几点: 不作参数优化,默认 ...

  3. mac osx 安装redis扩展

    1 php -v查看php版本 2 brew search php|grep redis 搜索对应的redis   ps:如果没有brew 就根据http://brew.sh安装 3 brew ins ...

  4. Redis/HBase/Tair比较

    KV系统对比表 对比维度 Redis Redis Cluster Medis Hbase Tair 访问模式    支持Value大小 理论上不超过1GB(建议不超过1MB) 理论上可配置(默认配置1 ...

  5. Redis数据库

    Redis是k-v型数据库的典范,设计思想及数据结构实现都值得学习. 1.数据类型 value支持五种数据类型:1.字符串(strings)2.字符串列表(lists)3.字符串集合(sets)4.有 ...

  6. redis 学习笔记(2)

    redis-cluster 简介 redis-cluster是一个分布式.容错的redis实现,redis-cluster通过将各个单独的redis实例通过特定的协议连接到一起实现了分布式.集群化的目 ...

  7. redis 学习笔记(1)

    redis持久化 snapshot数据快照(rdb) 这是一种定时将redis内存中的数据写入磁盘文件的一种方案,这样保留这一时刻redis中的数据镜像,用于意外回滚.redis的snapshot的格 ...

  8. python+uwsgi导致redis无法长链接引起性能下降问题记录

    今天在部署python代码到预生产环境时,web站老是出现redis链接未初始化,无法连接到服务的提示,比对了一下开发环境与测试环境代码,完全一致,然后就是查看各种日志,排查了半天也没有查明是什么原因 ...

  9. nginx+iis+redis+Task.MainForm构建分布式架构 之 (redis存储分布式共享的session及共享session运作流程)

    本次要分享的是利用windows+nginx+iis+redis+Task.MainForm组建分布式架构,上一篇分享文章制作是在windows上使用的nginx,一般正式发布的时候是在linux来配 ...

  10. windows+nginx+iis+redis+Task.MainForm构建分布式架构 之 (nginx+iis构建服务集群)

    本次要分享的是利用windows+nginx+iis+redis+Task.MainForm组建分布式架构,由标题就能看出此内容不是一篇分享文章能说完的,所以我打算分几篇分享文章来讲解,一步一步实现分 ...

随机推荐

  1. mvn 命令

    mvn eclipse:eclipse  用mvn把文件转化成eclipse支持的文件 mvn install   打包jar,放到本地仓库 ,在打包的时候还会执行单元测试,不需要的话运行(不需要打入 ...

  2. Hadoop学习地址

    hortonworks: http://zh.hortonworks.com/hdp/downloads/ http://zh.hortonworks.com/hadoop-tutorial/supe ...

  3. 51nod 1056

    n<=10000000000 然后欧拉函数的前缀和可以用莫比乌斯函数的前缀和快速求,注意各种取模 #include<cstdio> typedef long long i64; ,P ...

  4. select,epool,pool解释

    内容主要来自搜狗实验室技术交流文档, 编写链接数巨大的高负载服务器程序时,经典的多线程模式和select模式都不再适合了.应该采用epool/kqueue/dev_pool来捕获IO事件. ----- ...

  5. PHP加密解密类

    <?php class Mypass { static function encrypt($data, $key){ $key = md5($key); $x = 0; $len = strle ...

  6. [CSS]置换和非置换元素

    转自:http://blog.doyoe.com 先进一个题外话 在面试一个 重构(各大公司的叫法可能不太一样)时,我喜欢从一个点开始问,然后一直延展下去成为一条线,甚至是一个面,直到问到不会的地方, ...

  7. AP_AP系列 - 相关设定的简述(概念)

    2014-07-08 Created By BaoXinjian

  8. hdu 5698 瞬间移动(排列组合)

    这题刚看完,想了想,没思路,就题解了 = = 但不得不说,找到这个题解真的很强大,链接:http://blog.csdn.net/qwb492859377/article/details/514781 ...

  9. [物理学与PDEs]第4章习题参考解答

    [物理学与PDEs]第4章习题1 反应力学方程组形式的化约 - 动量方程与未燃流体质量平衡方程 [物理学与PDEs]第4章习题2 反应力学方程组形式的化约 - 能量守恒方程 [物理学与PDEs]第4章 ...

  10. Java中类的加载、连接和初始化

    Java中类的加载.连接和初始化 类的加载.连接和初始化 先介绍一下JVM和类 JVM和类: 当我们调用Java命令运行某个Java程序时,该命令将会启动一个Java虚拟机进程,不管该Java程序有多 ...