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组建分布式架构,由标题就能看出此内容不是一篇分享文章能说完的,所以我打算分几篇分享文章来讲解,一步一步实现分 ...
随机推荐
- 【Reporting Services 报表开发】— 交互式报表
我们知道,界面是人与系统间的对话方式,当使用者面对的是冷冰冰的界面,不但会造成使用者对于系统的热情减低,也会因为不便而产生诸多抱怨.尤其像报表时企业内几乎每日都会使用到的工具,因此,如何让使用者可以再 ...
- Android Wear(手表)开发 - 学习指南
版权声明:欢迎自由转载-非商用-非衍生-保持署名.作者:Benhero,博客地址:http://www.cnblogs.com/benhero/ Android Wear开发 - 学习指南 http: ...
- Canvas tutorial
<canvas> 是一种可以通过编写脚本(通常是JavaScript)来实现绘制图形的HTML元素.例如,它能用来绘制图形,制作组合图像或者生成简单的 (偶尔 也不简单) 动画.右边的图像 ...
- 【extjs】 extjs5 Ext.grid.Panel 搜索示例
先看效果图: 页面js: <script type="text/javascript"> /** * 日志类型 store * */ var logTypeStore ...
- 获取网页URL地址及参数等的两种方法(js和C#)
转:获取网页URL地址及参数等的两种方法(js和C#) 一 js 先看一个示例 用javascript获取url网址信息 <script type="text/javascript&q ...
- 修改tcp内核参数:somaxconn
修改somaxconn 该内核参数默认值一般是128(定义了系统中每一个端口最大的监听队列的长度),对于负载很大的服务程序来说大大的不够.一般会将它修改为2048或者更大. echo 2048 > ...
- android学习笔记15——Galley
Gallery==>画廊视图 Gallery和Spinnery父类相同——AbsSpinner,表明Garrey和Spinner都是一个列表框. 两者之间的区别是:Spinner显示的是一个垂直 ...
- PHP转换UTF-8和GB2312的URL编码(转)
目前WEB的应用中, UTF-8编码和GB2312编码是并存在的,例如百度(baidu.com)和谷歌(google.com)的URL编码分别是GB2312编码和UTF-8编码.由于编码并存引起的乱码 ...
- 关于c语言中qsort函数的一点心得
今天写c时无意间用到了排序,便想着使用c语言标准库中提供的排序函数,即qsort函数(c++stl中提供了sort函数用于排序),首先是介绍qsort函数的一些基本用法(以下内容转自: http:// ...
- SecureCRT控制台显示中文字符的设置