一、什么是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. eclipse注解——作者,创建时间,版本

    总结: /** * @author liangyadong * @date ${date} ${time} * @version 1.0 */

  2. Windows命令行查看文件的MD5

    certutil -hashfile D:\apache-tomcat-7.0.68-windows-x64.zip  MD5certutil -hashfile D:\apache-tomcat-7 ...

  3. nova分析(8)—— nova-compute

    nova-compute是管理和配置虚拟机的入口,在所有compute机器上都需要该服务来创建和管理虚拟机. nova-compute服务的入口在 nova.cmd.compute:main ,其启动 ...

  4. MySQL错误: could not retrieve transation read-only status server

    问题描述: java代码在开始事务后,先做了一个查询,再insert,此时会报:          java.sql.SQLException: could not retrieve transati ...

  5. Python 共享和上传函数模块到PyPI

    1. register account by brower on https://pypi.python.org/pypi/ 2. register your moudle "nester& ...

  6. VT100字体

    自从接触LINUX之后,VT100是我最喜欢的终端字体,当然它也是SecureCRT的默认字体.真实文件全名,VT100.FON  总共才44KB大小. 字体安装:直接放入C:\Windows\Fon ...

  7. QueryRunner的API

    org.apache.commons.dbutils Class QueryRunner java.lang.Object org.apache.commons.dbutils.AbstractQue ...

  8. 安装配置Oracle数据库时的一些处理思路

    配置Oralce客户端或者服务器端出现问题时,可考虑如下步骤: 1 检查如下文件:client端:D:\app\Administrator\product\11.2.0\client_3\networ ...

  9. SQL语言的三个分类:DDL、DML、DCL

    DML:数据操纵语言,主要是完成数据的新增,修改,删除和查询的操作. DDL:数据定义语言,主要是用来创建或修改表.视图.存储过程以及用户等. DCL:数据控制语言,是用来设置或更改数据库用户或角色权 ...

  10. HDU 2516 取石子游戏(斐波那契博弈)

    取石子游戏 Time Limit: 2000/1000 MS(Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submissi ...