【NoSql】Redis实践篇-简单demo实现(一)

Redis是一个key-value存储系统。

Redis的出现,非常大程度补偿了memcached这类key/value存储的不足,在部分场合能够对关系数据库起到非常好的补充作用

Redis是一个key-value存储系统。和Memcached相似。它支持存储的value类型相对很多其它,包含string(字符串)、list(链表)、set(集合)、zset(sortedset--有序集合)和hash(哈希类型)。这些数据类型支持push/pop、add/remove及取交集并集和差集及更丰富的操作,并且这些操作都是原子性的。在此基础上。redis支持各种不同方式的排序。

与memcached一样,为了保证效率。数据都是缓存在内存中。差别的是redis会周期性的把更新的数据写入磁盘或者把改动操作写入追加的记录文件。并且在此基础上实现了master-slave(主从复制)。

Memcache与Redis差别

Memcache提供的数据类型少。仅仅有键值对,Redis提供的数据类型相对较多

Memcache关机就没了,数据所有存到内存其中,可是没有提供故障恢复。Redis能够将数据存储到磁盘中

redis提供主从复制,Memcache无

Memcache是多线程的(使用协议解决的),redis是单线程

Windows下Redis的安装使用

1,安装Redis

官方下载:http://redis.io/download能够依据须要下载不同版本号

windows版:https://github.com/mythz/redis-windows

下载完毕后 能够右键解压到 某个硬盘下比方E:\redis64-2.6。

2,启动Redis

进入redis文件夹后 开启服务  (注意加上redis.conf)

redis-server.exe redis.conf

这个窗体要保持开启  关闭时redis服务会自己主动关闭

注:redis会自己主动保存数据到硬盘 所以假设是第二次开启时 多了一个 DB loaded from disk

3,測试使用

另外开启一个命令行窗体 进入redis文件夹下(注意改动自己的ip)

redis-cli.exe -h 192.168.24.215 -p 6379

4,利用JAVA操作Redis

import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;  

import javax.sound.midi.Soundbank;
import java.util.*;  

public class RedisTest {
    JedisPool pool;
    Jedis jedis;
    @Before
    public void setUp() {
        pool = new JedisPool(new JedisPoolConfig(), "192.168.24.215");  

        jedis = pool.getResource();
       /*  jedis.auth("password");  */
    }  

    /**
     * Redis存储0基础的字符串
     * CRUD
     */
    @Test
    public void testBasicString(){
        //-----加入数据----------
        jedis.set("name","hejingyuan");//向key-->name中放入了value-->hejingyuan
        System.out.println(jedis.get("name"));//运行结果:hejingyuan  

        //-----改动数据-----------
        //1、在原来基础上改动
        jedis.append("name","xvshu");   //非常直观,相似map 将xvshu append到已经有的value之后
        System.out.println(jedis.get("name"));//运行结果:hejingyuanxvshu  

        //2、直接覆盖原来的数据
        jedis.set("name","何静媛");
        System.out.println(jedis.get("name"));//运行结果:何静媛  

        //删除key相应的记录
        jedis.del("name");
        System.out.println(jedis.get("name"));//运行结果:null  

        /**
         * mset相当于
         * jedis.set("name","hejingyuan");
         * jedis.set("xvshu","何静媛");
         */
        jedis.mset("name","hejingyuan","xvshu","何静媛");
        System.out.println(jedis.mget("name","xvshu"));  

    } 

}

输出结果:

hejingyuan

hejingyuanxvshu

何静媛

null

[hejingyuan, 何静媛]

结束语:

在操作过程中,Redis通过快照(snapshotting)方式默认保存到硬盘中,Redis默认会将快照文件存储在当前文件夹(可CONFIG GETdir来查看)的dump.rdb文件里,能够通过配置dir和dbfilename两个參数分别指定快照文件的存储路径和文件名称。

在我们操作Redis过程中,它也在不断的向硬盘中存储

java操作Redis的各种測试:http://flychao88.iteye.com/blog/1527163

时间: 2024-11-07 01:02:20

【NoSql】Redis实践篇-简单demo实现(一)的相关文章

springdata redis实现的简单demo

原文:springdata redis实现的简单demo 源代码下载地址:http://www.zuidaima.com/share/1550463673076736.htm 麻雀虽小,五脏俱全,无止境的索取永远不能成为高手的. 运行test下的ShopDaoTest的main函数得到如下输出:  核心是key的设计,要考虑到以后的扩展. 列表类型的key:model_name list_name page count,如用户的shop列表:user1_shop2_1_10 单个对象类型的key

九爷带你了解 带你了解 Nosql Redis ttserver Flare memcache比较

Nosql Redis ttserver Flare memcache比较 随着互联网web2.0网站的兴起,非关系型的数据库现在成了一个极其热门的新领域,非关系数据库产品的发展非常迅速.而传统的关系数据库在应付 web2.0网站,特别是超大规模和高并发的SNS类型的web2.0纯动态网站已经显得力不从心,暴露了很多难以克服的问题,例如: 1.High performance - 对数据库高并发读写的需求 web2.0网站要根据用户个性化信息来实时生成动态页面和提供动态信息,所以基本上无法使用动

Redis的简单了解以及主从复制

1.Redis的简单了解 Redis是一种高性能的分布式NoSql数据库,持久存储,高并发,数据类型丰富,通过现场申请内存空间,同时可以配置虚拟内存.五种数据类型:string(字符串,这种格式和memcache是一致的).hash(哈希).list(列表,包括队列和栈).set(集合).zset(有序集合),使用key-value对的时候,可以直接存入对象,无需进行序列化,默认的使用了.net中自己的序列化,进行处理,所以也会出现对象循环引用的问题,此时需要使用json.net序列化为字符串,

Ext简单demo示例

1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> 2 <html> 3 <head> 4 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 5 <titl

[NOSQL] Redis介绍

Redis概述 Redis是Salvatore Sanfilippo在2009年为其初创公司LLOOGG开发的,目前仍是独立项目,但VMWare赞劣了项目(作者是其雇员).它采用C语言实现,因此性能很好.采用BSD许可证,使用键值存储,和Amazon Dynamo,Cassandra,Riak,Voldemort,Memcache类似.支持丰富的数据类型,比如数组,链表,集合等,非常适合需要表达时间线的web服务,例如微博. Redis支持的数据类型有: 字符串 链表 集合 有序集合 散列表 R

Unity3d 背景、音效 播放 简单demo

仅实现功能,AudioListener在MainCamera中 using UnityEngine; using System.Collections; using System.Collections.Generic; public class MusicManger : MonoBehaviour { AudioSource _backMusicSource = null; AudioSource _SoundSource = null; //public string musicName

Android SQLite最简单demo实现(增删查改)

本来不太想写这篇博客的,但是看到网上的关于android数据库操作的博文都讲得很详细,对于像我这样的新手入门了解SQLite的基本操作有一定难度,所以我参考了网上的一些博客文章,并自己亲自摸索了一遍,希望写出这么一篇博文来记录SQLite的最基本操作,同时也希望能够对android的新手们有些帮助. 参考博客:http://www.20864.com/201247/274.html 这里只是一个示范性的demo,并没实现什么具体功能,只实现了对数据库的增删查改操作. 以下是实现demo的步骤:

基于redis 内存数据库简单使用

在ecplise中使用内存数据的客端户,前提要准备要下载两个jar包 commons-pool2-2.0.jar jedis-2.4.2.jar 前提准备做好了,那我们就开启redis的服务,打开一个命令窗口输入如下命令:redis-server  或redis-server  redis根目\redis.conf 服务器已经开启了,注意端号是6377 2.在eclipse 创建一个项目,把redist需要的包导入项目中 3.写一个Jedis工具类 public class JedisUtil 

Node.js操作Redis的简单示例

Redis是一个key-value类型的数据库,而key全部都是字符串,value可以是集合.hash.list等等. Redis是通过MULTI/DISCARD/EXEC/WATCH这4个命令来实现事务功能.对事务,我们必须知道事务安全性是一个非常重要的. 事务提供了一种"将多个命令打包,然后一次性.按顺序执行"的机制,并且在事务执行期间不会中断--意思就是在事务完成之前,客户端的其他命令都是阻塞状态. var redis = require("redis");