zoukankan      html  css  js  c++  java
  • Redis数据库的安装与基本应用

    一:了解NoSQL

    1:介绍:Nosql的全称是Not Only Sql,这个概念早起就有人提出,在09年的时候比较火。Nosql指的是非关系型数据库,而我们常用的都是关系型数据库。就像我们常用的mysql,sqlserver一样,这些数据库一般用来存储重要信息,应对普通的业务是没有问题的。但是,随着互联网的高速发展,传统的关系型数据库在应付超大规模,超大流量以及高并发的时候力不从心。而就在这个时候,Nosql得到的告诉的发展。

    2:NOSQl与关系型数据库的区别:

    (1)存储方式:关系型数据库是表格式的,因此存储在表的行和列中。他们之间很容易关联协作存储,提取数据很方便。而Nosql数据库则与其相反,他是大块的组合在一起。通常存储在数据集中,就像文档、键值对或者图结构。Redis就是以键值对方式存储。

    (2)存储结构:关系型数据库预定义结构带来了可靠性和稳定性,但是修改这些数据比较困难。而Nosql数据库基于动态结构,使用与非结构化数据。因为Nosql数据库是动态结构,可以很容易适应数据类型和结构的变化。

    (3)性能:关系型数据库维护了数据稳定性和一致性,而NoSQL存储面对海量数据的时候效率相比关系型数据库非常高。

    (4)略

    3:NoSql的四大分类

    1.键值(Key-Value)存储,如Redis(优势:快速查询 劣势:存储数据缺少结构化)

    2.列存储,如HBase(优势:快速查询,扩展性强 劣势:功能相对局限)

    3.文档数据库,如mongoDB(优势:数据结构要求不严格 劣势:查询性能不高,确实统一查询的语法)

    4.图形数据库,如InfoGrid(优势:利用图结构相关算法 劣势:需要对整个图做计算才能得到结果,不容易做分布式的集群方案)

    二:Redis学习

    1:简介:NoSQL(not only sql)数据库的一种,主要以键值(Key-Value)的形式来存储数据,支持的键值数据类型有

    1 字符串类型String、

    2 列表类型list、

    3 有序集合类型zset、

    4 散列类型hash、

    5 集合类型set,

    应用场景有缓存、排行榜、任务队列、网站访问统计、数据过期处理、分布式集群架构中的session分离。

    2:安装:

    2.1Linux下,解压安装,后台启动·······操作很简单,都是和其他软件安装基本一致。

    2.2其实我们大部分的开发还是在window下的,在window下开发一定要用Redis来模拟测试,在window下安装更加简单

        2.2.1首先:官网下载window的安装包      https://github.com/MicrosoftArchive/redis/releases

        

    2.2.2 将压缩包解压到你想要安装的文件夹【D:Redis】

      按住Shift+右键,在此窗口打开命令行输入指令【redis-server redis.windows.conf】启动服务,显示如图

      然后再开一个命令行窗口,还是在该目录下Shift+右键,然后输入如下指令【redis-cli.exe -h 127.0.0.1 -p 6379】【注意:在此过程中服务的命令行窗口不能关】

    设置键值对 【set myKey abc】

    取出键值对 【get myKey】如图,成功

     

    三:使用Jedis操作Redis

    1 简介:Jedis是Redis官方首选的JAVA客户端开发包

    Jedis源码工程地址:

    2:使用:想要使用Jedis必须加载jar包或者添加maven依赖。在pom.xml中添加如下语句
    1 <dependency>
    2     <groupId>redis.clients</groupId>
    3     <artifactId>jedis</artifactId>
    4     <version>2.9.0</version>
    5     <type>jar</type>
    6     <scope>compile</scope>
    7 </dependency>

    Jedis当然也支持连接池,连接池的好处我就不再缀述,我就说说怎么用:

    首先将配置参数抽取出来写成redis.properties文件。例如:

     1 #*****************jedis连接参数设置*********************
     2 #redis服务器ip
     3 redis.ip=xxx.xxx.xxx.xxx
     4 #redis服务器端口号
     5 redis.port=6379
     6 #redis访问密码
     7 redis.passWord=123456
     8 #与服务器建立连接的超时时间
     9 redis.timeout=3000
    10 #************************jedis池参数设置*******************
    11 #jedis的最大活跃连接数
    12 jedis.pool.maxActive=100
    13 #jedis最大空闲连接数
    14 jedis.pool.maxIdle=50
    15 #jedis池没有连接对象返回时,等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。
    16 #如果超过等待时间,则直接抛出JedisConnectionException
    17 jedis.pool.maxWait=1500
    18 #从池中获取连接的时候,是否进行有效检查
    19 jedis.pool.testOnBorrow=true
    20 #归还连接的时候,是否进行有效检查
    21 jedis.pool.testOnReturn=true

    书写Redis连接池工具类RedisPoolUtil,网上有其他版本的方式,其实实现的本质都是一样的

     1 import java.util.Properties;
     2 import redis.clients.jedis.Jedis;
     3 import redis.clients.jedis.JedisPool;
     4 import redis.clients.jedis.JedisPoolConfig;
     5  
     6 /**
     7  * Redis连接池工具类
     8  */
     9 public class RedisPoolUtil {
    10     private static JedisPool jedisPool = null;
    11     private static String redisConfigFile = "redis.properties";
    12     //把redis连接对象放到本地线程中
    13     private static ThreadLocal<Jedis> local=new ThreadLocal<Jedis>();
    14     
    15     //不允许通过new创建该类的实例
    16     private RedisPoolUtil() {
    17     }
    18  
    19     /**
    20      * 初始化Redis连接池
    21      */
    22     public static void initialPool() {
    23         try {
    24             Properties props = new Properties();
    25             //加载连接池配置文件
    26             props.load(RedisPoolUtil.class.getClassLoader().getResourceAsStream(redisConfigFile));
    27             // 创建jedis池配置实例
    28             JedisPoolConfig config = new JedisPoolConfig();
    29             // 设置池配置项值
    30             config.setMaxTotal(Integer.valueOf(props.getProperty("jedis.pool.maxActive")));
    31             config.setMaxIdle(Integer.valueOf(props.getProperty("jedis.pool.maxIdle")));
    32             config.setMaxWaitMillis(Long.valueOf(props.getProperty("jedis.pool.maxWait")));
    33             config.setTestOnBorrow(Boolean.valueOf(props.getProperty("jedis.pool.testOnBorrow")));
    34             config.setTestOnReturn(Boolean.valueOf(props.getProperty("jedis.pool.testOnReturn")));
    35             // 根据配置实例化jedis池
    36             jedisPool = new JedisPool(config, props.getProperty("redis.ip"),
    37                     Integer.valueOf(props.getProperty("redis.port")),
    38                     Integer.valueOf(props.getProperty("redis.timeout")),
    39                     props.getProperty("redis.passWord"));
    40             System.out.println("线程池被成功初始化");
    41         } catch (Exception e) {
    42             e.printStackTrace();
    43         }
    44     }
    45     
    46     /**
    47      * 获得连接
    48      * @return Jedis
    49      */
    50     public static Jedis getConn() { 
    51         //Redis对象
    52         Jedis jedis =local.get();
    53         if(jedis==null){
    54             if (jedisPool == null) {    
    55                 initialPool();  
    56             }
    57             jedis = jedisPool.getResource();
    58             local.set(jedis);
    59         }
    60         return jedis;  
    61     }
    62     
    63     //归还连接
    64     public static void closeConn(){
    65         //从本地线程中获取
    66         Jedis jedis =local.get();
    67         if(jedis!=null){
    68             jedis.close();
    69         }
    70         local.set(null);
    71     }
    72     
    73     //关闭池
    74     public static void closePool(){
    75         if(jedisPool!=null){
    76             jedisPool.close();
    77         }
    78     }
    79 }

     最后Test方法测试使用上述方法即可。

    注意::::可能会连接超时失败,其实是防火墙的问题,到时候打开防火墙口,然后重启防火墙就OK了。

    四:Redis的持久化方式

    为了能够高速查询,Redis将数据几乎都在内存中,但缺点显而易见,如何将Redis的数据持久化下来呢!官方提供了两种方法:

    1:RDB:在指定时间间隔内生成数据集的时间点快照,但要是在指定时间间隔没到就断电了,那就JJ了啊!

    2:AOF:以日志的方式记录下每一步写操作指令,并在服务器启动时,通过执行这些命令来还原数据库。但是体积比较大,速度慢。

    3:一般将两种联合起来使用,其实一般在redis.conf中都已配置好,但是你想改也没人拦得住你啊!

    五:其他操作

    1:Redis其实共可有16个数据库,由0到15编号,默认选择0号,用seclect关键字选择

    2:数据库肯定少不了事务操作

    开启事务:multi

    回滚:discard

    提交:exec

  • 相关阅读:
    http
    Hive与HBase的区别与联系
    超好用python库(Pathlib)
    JS中every()和some()的用法
    kubectl create 和 kubectl apply区别
    Servlet/Tomcat/ Spring 之间的关系
    Android Fragment详解
    vue路由钩子拦截器beforeEach和afterEach及页面路由变化路由监听
    Vue + Webpack 将路由文件分拆为多个文件分别管理
    VUE中常用的几种import(模块、文件)引入方式
  • 原文地址:https://www.cnblogs.com/nullering/p/9332589.html
Copyright © 2011-2022 走看看