配置文件

# Note on units: when memory size is needed, it is possible to specify
# it in the usual form of 1k 5GB 4M and so forth:
#
# 1k => 1000 bytes
# 1kb => 1024 bytes
# 1m => 1000000 bytes
# 1mb => 1024*1024 bytes
# 1g => 1000000000 bytes
# 1gb => 1024*1024*1024 bytes
#
# units are case insensitive so 1GB 1Gb 1gB are all the same.

配置文件不区分大小写

# include .\path\to\local.conf
# include c:\path\to\other.conf

可以导入其他配置文件

网络

  • bind 127.0.0.1#绑定的ip
  • protected-mode yes #保护模式
  • port 6379#默认端口

通用配置GENERAL

  • daemonize yes #以守护进程的方式运行  默认为no 我们要自己变成yes
  • pidfile /var/run/redis_6379.pid #如果以后台的方式进行,我们就需要指定一个pid文件
  • # Specify the server verbosity level.日志级别
    # This can be one of:
    # debug (a lot of information, useful for development/testing)
    # verbose (many rarely useful info, but not a mess like the debug level)
    # notice (moderately verbose, what you want in production probably)
    # warning (only very important / critical messages are logged)
    loglevel notice
  • logfile ""#日志的文件位置
  • databases 16#数据库数量,默认16个
  • always-show-logo yes#打印logo

快照SNAPSHOTTING

在规定的事件执行了多少次操作,则会持久化文件.rdb .aof

#持久化规则
save 900 1
#如果900秒内,如果至少有一个key进行了修改,我们及时进行持久化
save 300 10
#如果300秒内,如果至少有一个10key进行了修改,我们及时进行持久化
save 60 10000

Redis是内存数据库 ,如果没有持久化,那么数据断电小时

  • stop-writes-on-bgsave-error yes #持久化出错,是否还要需要继续工作
  • rdbcompression yes#是否压缩rdb文件,消耗cpu资源
  • rdbchecksum yes#保存rdb文件时,进行检查校验
  • dir ./#rdb 文件保存的目录

复制REPLICATION (主从复制)

安全SECURITY

设置密码:

config set requirepass "123456"
auth 123456

客户端CLIENTS

  • 默认最大的客户端数:

  • maxclients 10000
  • maxmemory <bates>#最大内存设置
  • # maxmemory-policy noeviction#内存达到上线的处理策略

APPEND ONLY MODE AOF

  • appendonly no #默认是不开启的默认是rdb方式持久化的,在大部分情况下,rdb完全够用
  • appendfilename "appendonly.aof"#持久化的文件名字
  • # appendfsync always #每次修改都会sync 消耗性能
    appendfsync everysec #每秒执行一次sync 可能会丢失这一秒的值
    # appendfsync no #不执行sync 这个时候操作系统自己同步数据,速度最快

RDB

什么是RDB

RDB持久化,是Redis可以将数据库状态保存到一个RDB文件中,并可以通过该RDB文件生成RDB文件的时候的数据库状态。RDB文件是一个经过压缩的二进制文件。

Jedis

我们要使用java来操作Redis

什么是Jedis

1.配置环境

<dependencies>
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.76</version>
</dependency>
</dependencies>

2.编码测试:

  • 连接数据库
  • 操作命令
  • 断开连接

基本代码

package com.Test;

import redis.clients.jedis.Jedis;

import java.util.Set;

public class TestPing {
public static void main(String[] args) {
//1.new 一个Jedis对象
Jedis jedis = new Jedis("127.0.0.1",6379);
//之前的指令很重要
System.out.println(jedis.ping());
//常用api
jedis.flushDB();//清空数据
jedis.exists("name");//某个键值是否存在
jedis.set("name","hjz");//新增键值对
Set<String> keys = jedis.keys("*");//系统中所有键值
jedis.del("name");//删除键
jedis.exists("name");//判断是否存在
jedis.type("name");//判断键的存储类型
jedis.randomKey();//随机返回一个key的空间
jedis.rename("name","username");//重命名
jedis.get("username");//取出username
jedis.select(0);//按照索引查询
jedis.flushDB();//删除选择数据库的值
jedis.dbSize();//返回当前数据库的key的数目
jedis.flushAll();//删除所有数据库的所有key
}
}Spring Boot整合Redis

String类型

package com.Test;

import redis.clients.jedis.Jedis;

import java.util.concurrent.TimeUnit;

public class TestString {
public static void main(String[] args) {
//1.new 一个Jedis对象
Jedis jedis = new Jedis("127.0.0.1",6379);
jedis.set("key1","value1");//添加数据
jedis.set("key2","value2");//添加数据
jedis.set("key3","value3");//添加数据
jedis.del("key1");//删除key1
jedis.get("key2");//得到key2
jedis.set("key3","end");//修改key3
jedis.append("key3","aaa");//在key3后加值
jedis.mset("key01","value1","key02","value02");//增加多个键值对
jedis.mget("key01","key02");//获得多个键值对
jedis.del("key01","key02");//删除多个键值对
//分布式锁的-新增键值对放置覆盖原来的值
jedis.setnx("key1","value1");
jedis.setnx("key2","value2");
jedis.setnx("key3","value3");
jedis.get("key1");
//设置过期时间
jedis.setex("key4",5,"value4");
jedis.get("key4");
//睡觉
try{
TimeUnit.SECONDS.sleep(3);
}catch (InterruptedException e){
e.printStackTrace();
}
//获得原来的值,更新为新值
jedis.getSet("key2","key2Get2");
jedis.get("key2");
jedis.getrange("key2",2,4);//获得key2的字符串 }
}

List类型

事务

package com.Test;

import com.alibaba.fastjson.JSONObject;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.Transaction; public class TestShiwu {
public static void main(String[] args) {
//1.new 一个Jedis对象
Jedis jedis = new Jedis("127.0.0.1",6379);
//事务
JSONObject jsonObject = new JSONObject();
jsonObject.put("hello","world");
jsonObject.put("name","hjz");
//开启事务
Transaction muil =jedis.multi();
String result = jsonObject.toJSONString();
try{
muil.set("user1",result);
muil.set("user2",result);
int i=1/0;//代码抛出异常,执行失败
muil.exec();//执行事务
}catch (Exception e){
//放弃事务
muil.discard();
e.printStackTrace();
}finally {
System.out.println(jedis.get("user1"));
jedis.close();//关闭连接
} }
}

spring boot操作数据:sprig-data jpa jdbc mongodb redis

Spring Data也是Spring Boot起名的项目

jedis:采用的是直连,多线程是不安全的,如果想要避免是不安全的,使用jedis pool 连接池!BIO

lettuce:采用netty 实例可以多个线程中共享,不存在线程不安全的情况,可以减少线程的数量,更像NIO模式

源码分析

//
// Source code recreated from a .class file by IntelliJ IDEA
// (powered by Fernflower decompiler)
//
@AutoConfiguration
@ConditionalOnClass({RedisOperations.class})
@EnableConfigurationProperties({RedisProperties.class})
@Import({LettuceConnectionConfiguration.class, JedisConnectionConfiguration.class})
public class RedisAutoConfiguration {
public RedisAutoConfiguration() {
} @Bean
@ConditionalOnMissingBean(
name = {"redisTemplate"}
)
@ConditionalOnSingleCandidate(RedisConnectionFactory.class)//不纯在才生效
public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
//默认的RedisTempalte没有过多的设置,redis都是需要序列化的
RedisTemplate<Object, Object> template = new RedisTemplate();
template.setConnectionFactory(redisConnectionFactory);
return template;
} @Bean
@ConditionalOnMissingBean//由于String类型最常使用单独提出来一个
@ConditionalOnSingleCandidate(RedisConnectionFactory.class)
public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory redisConnectionFactory) {
return new StringRedisTemplate(redisConnectionFactory);
}
}

整合测试

配置文件、RDB、Jedis的更多相关文章

  1. redis基础:redis下载安装与配置,redis数据类型使用,redis常用指令,jedis使用,RDB和AOF持久化

    知识点梳理 课堂讲义 课程计划 1. REDIS 入 门 (了解) (操作)   2. 数据类型 (重点) (操作) (理解) 3. 常用指令   (操作)   4. Jedis (重点) (操作) ...

  2. redis使用总结(二)(jedis使用)

    Jedis使用(Jedis中的API和redis的指令基本相同) 1.创建maven工程,在pom文件中导入jedis的坐标 <dependency> <groupId>red ...

  3. [转载] 基于Redis实现分布式消息队列

    转载自http://www.linuxidc.com/Linux/2015-05/117661.htm 1.为什么需要消息队列?当系统中出现“生产“和“消费“的速度或稳定性等因素不一致的时候,就需要消 ...

  4. Redis 基础知识点总结

    关系型数据库 VS 非关系型数据库(NoSQL) 关系型数据库 我们过去使用的 mysql.Oracle 都属于关系型数据库.关系型数据库的特点是数据表之间可以存在联系,表内每列数据也存在关联,同时支 ...

  5. spring-data-redis --简单的用spring-data-redis

    spring-data-redis序列化策略 spring-data-redis提供了多种serializer策略,这对使用jedis的开发者而言,实在是非常便捷.sdr提供了4种内置的seriali ...

  6. redis持久化机制【十三】

    一.Redis提供了哪些持久化机制: redis的高性能是因为其所有数据都存在了内存中 ,为了使redis在重启之后数据仍然不丢失,需要将数据同步到硬盘中,这一过程就是持久化. redis支持两种方式 ...

  7. javaweb学习笔记(三)

    一.javaweb高级(Filter和Listener)的简单介绍 1.过滤器Filter (https://www.cnblogs.com/vanl/p/5742501.html) ①定义 Filt ...

  8. 4、解析配置文件 redis.conf、Redis持久化RDB、Redis的主从复制

    1.Units单位 配置大小单位,开头定义了一些基本的度量单位,只支持bytes,不支持bit 对大小写不敏感 2.INCLUDES包含 和我们的Struts2配置文件类似,可以通过includes包 ...

  9. edis.clients.jedis.exceptions.JedisDataException: MISCONF Redis is configured to save RDB snapshots,

    edis.clients.jedis.exceptions.JedisDataException: MISCONF Redis is configured to save RDB snapshots ...

  10. redis.clients.jedis.exceptions.JedisDataException: MISCONF Redis is configured to save RDB snapshots

    最近在学习Redis ,在写test测试的时候碰到这个报错: redis.clients.jedis.exceptions.JedisDataException: MISCONF Redis is c ...

随机推荐

  1. JavaScript入门①-基础知识筑基

    01.JavaScript基础知识 JavaScript(缩写:JS)是一种具有面向对象能力的.解释型的程序语言,基于对象和事件驱动,具有相对安全性的客户端脚本语言.JavaScript是一门完备的 ...

  2. Iris_data_analysis

    SVM调用实例--鸢尾花 任务描述: 构建一个模型,根据鸢尾花的花萼和花瓣大小将其分为三种不同的品种. 数据集: 每一行数据由4个特征值及1个目标值组成,4个特征值分别为:萼片长度.萼片宽度.花瓣长度 ...

  3. http 缓存 笔记

    http 缓存,有时候静态资源没更新的情况下,不需要每次都去服务器获取,减少资源的请求. Http 报文中与缓存相关的首部字段 1. 通用首部字段(就是请求报文和响应报文都能用上的字段) 2. 请求首 ...

  4. PHP-表单传值

    一.传值引入 了解传值必须要先知道为什么需要传值? 传值的主要作用是为了实现用户数据的定制化,用户与服务端的互交 二.传值的方式 虽然 http协议中有很多数据传输的方式,但在PHP中只有 POST ...

  5. angr_ctf——从0学习angr(三):Hook与路径爆炸

    路径爆炸 之前说过,angr在处理分支时,采取统统收集的策略,因此每当遇见一个分支,angr的路径数量就会乘2,这是一种指数增长,也就是所说的路径爆炸. 以下是路径爆炸的一个例子: char buff ...

  6. 《MySQL必知必会》之快速入门游标和触发器

    第二十四章 使用游标 本章将介绍什么是游标以及如何使用游标 游标 之前的select语句检索出来的数据,没有办法得到第一行或者下一行 有时,需要在检索出来的行中前进或后退一行或多行.这就是使用游标的原 ...

  7. Python 大数据量文本文件高效解析方案代码实现

    大数据量文本文件高效解析方案代码实现 测试环境 Python 3.6.2 Win 10 内存 8G,CPU I5 1.6 GHz 背景描述 这个作品来源于一个日志解析工具的开发,这个开发过程中遇到的一 ...

  8. 定制.NET 6.0的Middleware中间件

    大家好,我是张飞洪,感谢您的阅读,我会不定期和你分享学习心得,希望我的文章能成为你成长路上的垫脚石,让我们一起精进. 在本文中,我们将学习中间件,以及如何使用它进一步定制应用程序.我们将快速学习中间件 ...

  9. ClickHouse数据副本引擎

    我的gitee地址:https://gitee.com/ddxygq/bigdata-technical-pai ,相关文章都放到这个仓库里了. 只有 MergeTree 系列里的表可支持副本: Re ...

  10. [MySQL] 索引的使用、SQL语句优化策略

    目录 索引 什么是索引 索引的创建与删除 创建索引 删除索引 索引的使用 使用explain分析SQL语句 最佳左前缀 索引覆盖 避免对索引列进行额外运算 SQL语句优化 小表驱动大表 索引 什么是索 ...