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后再次开机 每次都出现无法找到另一个虚拟机上的端口
其报错代码为 机子已经发现6379这个问题 切值为空
两种解决
其一 sudo iptables -F 此代码
其二 其实服务已经启动了 直接redis-cli连接便可