IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Redis入门 -> 正文阅读

[大数据]Redis入门

Redis是什么东西?

Redis(Remote Dictionary Server ),即远程字典服务。

是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。

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

Redis干什么

1,内存存储。

2,高效率。

3,订阅系统

4,地图信息系统

5,计时器等。

特性

1.数据类型多

2.持久化 RDB和AOF支持

3.集群(主从复制集群、哨兵集群)等

环境搭建

windows已经停止更新,所以不进行讲解

linux安装

1.linux准备,注意需要java环境以及网路环境,确保外界能ping通虚拟机。

2.去官网下载安装包https://redis.io/

3.解压安装包,将解压后的文件放在opt目录下,方便以后复制调用

4.安装基本环境

yum install gcc-c+
要到redis目录下安装
make

make install

5.将文件复制一份到 /usr/local/bin/kconfig 下

6.修改配置文件

bing 127.0.0.1——> bing 192.168.244.128(虚拟机ip地址)

deamonize no ——>?deamonize yes(是否后台启动)

7.测试redis?

8补充一下redis基本知识

redis一共有16个数据库所以他能实现高可用和高并发的任务,其次他查询代码为轮流制度

其次现在redis-cli已经代替了集群启动指令

测试高并发可以用自带的redis-benchmar测试

# 测试:100个并发连接 100000请求
redis-benchmark -h localhost -p 6379 -c 100 -n 100000

联动springboot

1.理解原理

ps springboot 2.x后,原有jedis吧内lettuce替换

jedis:采用的直连,多个线程操作的话,是不安全的。如果要避免不安全,使用jedis pool连接池!更像BIO模式

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

给自己科普一下 Tomcat有三种模式 BIO, NIO, APR

  • BIO: 同步并阻塞,服务器实现模式为一个连接一个线程,即客户端有连接请求时服务器端就需要启动一个线程进行处理,如果这个连接不做任何事情会造成不必要的线程开销,当然可以通过线程池机制改善。
  • NIO:同步非阻塞,服务器实现模式为一个请求一个线程,即客户端发送的连接请求都会注册到多路复用器上,多路复用器轮询到连接有I/O请求时才启动一个线程进行处理。
  • AIO:异步非阻塞,服务器实现模式为一个有效请求一个线程,客户端的I/O请求都是由OS先完成了再通知服务器应用去启动线程进行处理

学习springboot自动配置原理是,整合一个组件并进行配置一定会有一个自动配置类xxxAutoConfiguration,并且在spring.factories中也一定能找到这个类的完全限定名。Redis也有外。

同时还存在一个RedisProperties类

?

之前我们说SpringBoot2.x后默认使用Lettuce来替换Jedis,现在我们就能来验证了。

先看Jedis:

可以看见两个默认类是标红不存在的。

再看Lettuce:

?

没有标记可以正常使用。

最后看reids配置类:

?只有两个简单的Bean类

RedisTemplate和StringRedisTemplate

导入依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

2.配置redis

在application.yml中添加相对应代码

spring:
  redis:
    host: 192.168.xx.xx
    password: 123456
    port: 6379

3.使用Redis Template

@SpringBootTest
class Redis02SpringbootApplicationTests {

    @Autowired
    private RedisTemplate redisTemplate;

    @Test
    void contextLoads() {

        // redisTemplate 操作不同的数据类型,api和我们的指令是一样的
        // opsForValue 操作字符串 类似String
        // opsForList 操作List 类似List
        // opsForHah

        // 除了基本的操作,我们常用的方法都可以直接通过redisTemplate操作,比如事务和基本的CRUD

        // 获取连接对象
        //RedisConnection connection = redisTemplate.getConnectionFactory().getConnection();
        //connection.flushDb();
        //connection.flushAll();

        redisTemplate.opsForValue().set("mykey","kuangshen");
        System.out.println(redisTemplate.opsForValue().get("mykey"));
    }
}

4.测试结果

注如果出现乱码就对了,到现在位置还没有将存储对象进行序列化操作。

5.定制Redis Template的模板:

@Configuration
public class RedisConfig {

   @Bean
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) throws UnknownHostException {
        // 将template 泛型设置为 <String, Object>
        RedisTemplate<String, Object> template = new RedisTemplate();
        // 连接工厂,不必修改
        template.setConnectionFactory(redisConnectionFactory);
        /*
         * 序列化设置
         */
        // key、hash的key 采用 String序列化方式
        template.setKeySerializer(RedisSerializer.string());
        template.setHashKeySerializer(RedisSerializer.string());
        // value、hash的value 采用 Jackson 序列化方式
        template.setValueSerializer(RedisSerializer.json());
        template.setHashValueSerializer(RedisSerializer.json());
        template.afterPropertiesSet();
        
        return template;
    }
}

可以解决序列化问题。

集群搭建(2台主机下3分服务)

?1.创建一个集群文件并复制一个redis.conf?

mkdir redis_cluster 
cp redis.conf redis_cluster/7001

2.改变一下配置

pidfile  /var/run/redis_7000.pid       //pidfile文件对应7000,7001,7002
cluster-enabled  yes                   //开启集群  把注释#去掉
cluster-config-file  nodes_7000.conf   //集群的配置  配置文件首次启动自动生成 7000,7001,7002
cluster-node-timeout  15000            //请求超时  默认15秒,可自行设置
appendonly  yes                       //aof日志开启  有需要就开启,它会每次写操作都记录一条日志

3.复制两份并改为相对应的端口号

4.运行报错一气呵成

5.修复问题,好像是缺少一个slots文件

redis-cli --cluster reshard 192.168.xx.xx:6380 -a 123456

redis-cli --cluster fix 192.168.xx.xx:6379 -a 123456?

#输入yes
yes

6.再次运行?

redis-cli --cluster create 192.168.xx.xx:6379?192.168.xx.xx:6380?192.168.xx.xx:6381?--cluster-replicas 1

7.好的他告诉我还得搭建3最起码要6个 去另一台主机上搭建三个分机子

8.重复2.3步骤

9.编写一个启动脚本

vim start-all.sh

chmod +x start-all.sh

脚本内容

启动脚本

sudo ./start-all.sh

9.5查看redis服务是否全部开启

netstat -tlnp | grep redis

10.安装ruby

sudo apt-get install ruby-full

11. 启动集群指令


sudo redis-cli --cluster create 192.168.244.129:6379 192.168.244.129:6380 192.168.244.129:6381 192.168.244.133:6382 192.168.244.133:6383 192.168.244.133:6384  --cluster-replicas 1

12.启动后显示

129.6379 133.6382?129.6380 为主节点

下面是槽点位置

打yes后自动分配

?13.连接?注意必须要打-c??注意必须要打-c??注意必须要打-c? 还有一件事连接到主服务器上

sudo redis-cli -h 192.168.244.129 -p 6379 -c
#c的意思是自动分配到相对应的端口上

总结 一定要关闭防火墙 或者去开放对应端口

其次关闭ubt后再开 三次出现无法找到另一个虚拟机上的端口

sudo iptables -F 此代码

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-01-24 10:57:59  更:2022-01-24 10:59:22 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 14:53:27-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码