Redis应用
一、什么是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; }
}
}
八、相当文档
九、结语
redis只是NoSQL的一种,几乎包含所有流行语言的开发包,拥有专门的组织维护,能够成为大多数开发人员首选的NoSQL数据库,肯定在性能上、安全上都做到让人满意的程度了。
不要局限于redis,可以使用其他的NoSQL数据库,通过实际应用、对比、总结才能得出好坏。
每天多学一点,量变产生质变。
Redis应用的更多相关文章
- 使用redis构建可靠分布式锁
关于分布式锁的概念,具体实现方式,直接参阅下面两个帖子,这里就不多介绍了. 分布式锁的多种实现方式 分布式锁总结 对于分布式锁的几种实现方式的优劣,这里再列举下 1. 数据库实现方式 优点:易理解 缺 ...
- Ignite性能测试以及对redis的对比
测试方法 为了对Ignite做一个基本了解,做了一个性能测试,测试方法也比较简单主要是针对client模式,因为这种方法和使用redis的方式特别像.测试方法很简单主要是下面几点: 不作参数优化,默认 ...
- mac osx 安装redis扩展
1 php -v查看php版本 2 brew search php|grep redis 搜索对应的redis ps:如果没有brew 就根据http://brew.sh安装 3 brew ins ...
- Redis/HBase/Tair比较
KV系统对比表 对比维度 Redis Redis Cluster Medis Hbase Tair 访问模式 支持Value大小 理论上不超过1GB(建议不超过1MB) 理论上可配置(默认配置1 ...
- Redis数据库
Redis是k-v型数据库的典范,设计思想及数据结构实现都值得学习. 1.数据类型 value支持五种数据类型:1.字符串(strings)2.字符串列表(lists)3.字符串集合(sets)4.有 ...
- redis 学习笔记(2)
redis-cluster 简介 redis-cluster是一个分布式.容错的redis实现,redis-cluster通过将各个单独的redis实例通过特定的协议连接到一起实现了分布式.集群化的目 ...
- redis 学习笔记(1)
redis持久化 snapshot数据快照(rdb) 这是一种定时将redis内存中的数据写入磁盘文件的一种方案,这样保留这一时刻redis中的数据镜像,用于意外回滚.redis的snapshot的格 ...
- python+uwsgi导致redis无法长链接引起性能下降问题记录
今天在部署python代码到预生产环境时,web站老是出现redis链接未初始化,无法连接到服务的提示,比对了一下开发环境与测试环境代码,完全一致,然后就是查看各种日志,排查了半天也没有查明是什么原因 ...
- nginx+iis+redis+Task.MainForm构建分布式架构 之 (redis存储分布式共享的session及共享session运作流程)
本次要分享的是利用windows+nginx+iis+redis+Task.MainForm组建分布式架构,上一篇分享文章制作是在windows上使用的nginx,一般正式发布的时候是在linux来配 ...
- windows+nginx+iis+redis+Task.MainForm构建分布式架构 之 (nginx+iis构建服务集群)
本次要分享的是利用windows+nginx+iis+redis+Task.MainForm组建分布式架构,由标题就能看出此内容不是一篇分享文章能说完的,所以我打算分几篇分享文章来讲解,一步一步实现分 ...
随机推荐
- HBase(二): c#访问HBase之股票行情Demo
上一章完成了c#访问hbase的sdk封装,接下来以一个具体Demo对sdk进行测试验证.场景:每5秒抓取指定股票列表的实时价格波动行情,数据下载后,一方面实时刷新UI界面,另一方面将数据放入到在内存 ...
- 【mysql】mysql分表和表分区详解
为什么要分表和分区? 日常开发中我们经常会遇到大表的情况,所谓的大表是指存储了百万级乃至千万级条记录的表.这样的表过于庞大,导致数据库在查询和插入的时候耗时太长,性能低下,如果涉及联合查询的情况,性能 ...
- 【shell】变量的配置文件
(1)/etc/profile 登录时,会执行.全局(公有)配置,不管是哪个用户,登录时都会读取该文件.(2)/ect/bashrc Ubuntu没有此文件,与之对应的是/ect/bash.b ...
- Python基础教程【读书笔记】 - 2016/7/4
希望通过博客园持续的更新,分享和记录Python基础知识到高级应用的点点滴滴! 第二波:第7章 更加抽象 [总览] 创建自己的对象,是Python的核心概念!Python被称为面向对象的语言.介绍如 ...
- [tty与uart]2.tty和uart的函数调用流程
以下是在include/uapi/linux/tty.h中定义了现有的线规号,如果需要定义新的,则需要在后面添加新的 /* line disciplines */ #define N_TTY 0 #d ...
- linux系统中实现mongodb3.0.5数据库自动备份
最近两天,因公司业务需要,要定期备份mongodb数据库中的数据. 查了很多资料后,发现mongodb似乎并没有自带的定时备份功能,于是只好转移目标到linux系统的定时任务上,于是学习并使用了cro ...
- Mysql分区技术
注:分区的语法可以看手册中有详细的写法和例子: show plugins; 此命令查看可有partition这个选项,有则mysql支持分区,没有的话,就可以升级一下mysql 实时监控一个命令执行情 ...
- 技巧分享——如何去除多余的CSS代码?
有时候,当你的CSS代码过多的时候,而且已经明确知道有部分CSS代码是多余的: 这时候,有什么较快的办法可以去除多余的CSS呢?? 下面分享一个实用技巧: 1.使用谷歌浏览器:Chrome .下载 2 ...
- [Vue]学习中遇到的疑点
computed:计算属性,官方api上说计算属性的结果会被缓存,除非依赖的响应式属性变化才会重新计算.但是经过测试并没有缓存.案例: computed: { now: function () { c ...
- XHTML的使用规范
一.XHTML的简介 XHTML指的是可扩展超文本标记语言 XHTML与HTML4.01几乎是相同的 XHTML是更严格更纯净的HTML版本 XHTML是以XML应用的方式定义的HTML 二.为什么使 ...