缓存机制 ehcache、redis
本文主要记录ehcache和redis实现缓存(redis版本号:5.0.3)
一、ehcache
1.ehcache:用来管理Java中缓存的轻量级工具,其核心通过CacheManager使用,一般使用于单机版,可以部署集群,但是不推荐,一般使用redis或者其他框架来实现分布式缓存。
2.缓存过期策略:FIFO(先进先出原则)、LRU(最近最少使用,即目前最久未被使用的优先淘汰)、LFU(最近不常用[算法类似于JVM中垃圾回收器的s0和s1区],在一段时间中使用次数最少)
3.使用场景:一般用做一级缓存[单机版],redis做二级缓存[集群版]
4.示列代码(给出核心部分)
二、redis(单机版)(以下给出核心代码,需要完整代码在GitHub上获取(链接在首页))
注意事项:1.在阿里云上购买的服务器,需要在阿里云的安全策略中开启redis的端口,默认是6379。
2.安装时需要将 bind 127.0.0.1 改成 bind 0.0.0.0表示外网访问。网上说注释掉 我用版本5.0.3 不行。
3.daemonize no 改成daemonize yes 表示后台开启。
4.requirepass 123 表示设置访问密码。
5.修改pidfile文件路径 pidfile /home/pro_install/redis/stand_alone/pid/redis_6379.pid
6.修改log路径 logfile /home/pro_install/redis/stand_alone/log/redis.log redis.log文件由redis自己建立
7.修改缓存数据路径 dir /home/pro_install/redis/stand_alone/cache_data
8.需要关闭防火墙。systemctl stop firewalld 表示临时关闭。
9.启动、停止、重启 比较简单这里不再赘述了。
授权对象:0.0.0.0/0 表示任何ip都可以访问。
三、redis(主从复制)
同步原理:
1:当一个从数据库启动时,会向主数据库发送sync命令。
2:主数据库接收到sync命令后会开始在后台保存快照(执行rdb操作),并将保存期间接收到的命令缓存起来。
3:当快照完成后,redis会将快照文件和所有缓存的命令发送给从数据库。
4:从数据库收到后,会载入快照文件并执行收到的缓存的命令。
搭建:环境为阿里云服务器,搭建一主两备一哨兵,其中端口:6380为master、6385和6386为slave、26379为哨兵监控(由于投票选举策略,搭建哨兵的数量最好为奇数)。
注意事项:1.在丛服务器中 masterauth + 主服务器的密码。
2.redis3.2版本之前采用 slaveof 指向主服务器ip,在之后用 eplicaof 指向主机的ip和端口 。
3.哨兵中sentinel monitor <master-name> <ip> <redis-port> <quorum> 即可,参数依次为: 哨兵名字,主服务器ip,主端口,投票选举数量(eg:2表示,做集群后当主服务宕机后需要几个哨兵选举丛服务器后才能竞选为主服务)。
4.其他配置项都比较简单,这里不再赘述。
四、redis(集群版) 3主3从
由于redis版本升级的问题,按照网上其他教程,可能安装不了,在这里记录下安装过,本文采用redis版本是目前最新的5.0.3。
1.集群版先不要设置密码,否者在安装卡槽时会出错。
2.安装ruby:yum install ruby
3.安装gem:gem update --system 如果报错则按下面方式安装
报错:gpg2 --keyserver hkp://pool.sks-keyservers.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3 7D2BAF1CF37B13E2069D6956105BD0E739499BDBInstalling RVM to /usr/local/rvm
gpg --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3(这个来源于某博客,忘记名字了,补充一下)
按照图示刷新配置 source /etc/profile.d/rvm.sh
4.yum install rubygems 和 gem install redis
以上是环境转变,下面搭建redis
分别建立6个保存redis数据文件夹data和6个保存pid的文件夹,如果采用端口来区分的话,可以建立6个redis.config的文件
修改redis_6390.conf
开启集群 使用rdb或者aof看个人配置了
创建集群:老版本用的是另一个启动,在目前的redis中是移除了
./redis/src/redis-cli --cluster create 127.0.0.1:6390 127.0.0.1:6391 127.0.0.1:6392 127.0.0.1:6393 127.0.0.1:6394 127.0.0.1:6395 --cluster-replicas 1
以上就搭建成功了。
注意:若先设置了密码会报一下错误
======================================
一、缓存Map(ehcache)
@Component
public class EhcacheMap<K, V> { private Map<K, V> echcache = new ConcurrentHashMap<>(); public void put(K key, V value) {
echcache.put(key, value);
} public V get(K key) {
return echcache.get(key);
} public void remove(K key) {
echcache.remove(key);
}
}
ehcache.xml(ehcache)
<?xml version="1.0" encoding="UTF-8"?>
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="http://ehcache.org/ehcache.xsd"> <diskStore path="java.io.tmpdir/ehcache-rmi-4000" /> <!-- 多台机器配置 rmiUrls=//192.168.8.32:400002/demoCache|//192.168.5.231:400003/demoCache -->
<cacheManagerPeerProviderFactory
class="net.sf.ehcache.distribution.RMICacheManagerPeerProviderFactory"
properties="peerDiscovery=manual,rmiUrls=//127.0.0.1:5000/userCache">
</cacheManagerPeerProviderFactory>
<!-- 配置 rmi 集群模式 -->
<cacheManagerPeerListenerFactory
class="net.sf.ehcache.distribution.RMICacheManagerPeerListenerFactory"
properties="hostName=127.0.0.1,port=4000,socketTimeoutMillis=120000" /> <!-- 多播方式配置 搜索某个网段上的缓存 timeToLive 0是限制在同一个服务器 1是限制在同一个子网 32是限制在同一个网站 64是限制在同一个region
128是限制在同一个大洲 255是不限制 <cacheManagerPeerProviderFactory class="net.sf.ehcache.distribution.RMICacheManagerPeerProviderFactory"
properties="peerDiscovery=automatic, multicastGroupAddress=224.1.1.1, multicastGroupPort=40000,
timeToLive=32" /> --> <!-- 默认缓存 -->
<defaultCache maxElementsInMemory="1000" eternal="true"
timeToIdleSeconds="120" timeToLiveSeconds="120" overflowToDisk="true"
diskSpoolBufferSizeMB="30" maxElementsOnDisk="10000000"
diskPersistent="true" diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU">
</defaultCache>
<!-- name: Cache的名称,必须是唯一的(ehcache会把这个cache放到HashMap里)。
maxElementsInMemory:在内存中缓存的element的最大数目。
maxElementsOnDisk:在磁盘上缓存的element的最大数目,默认值为0,表示不限制。
eternal:设定缓存的elements是否永远不过期。如果为true,则缓存的数据始终有效,如果为false那么还要根据timeToIdleSeconds,timeToLiveSeconds判断。
overflowToDisk: 如果内存中数据超过内存限制,是否要缓存到磁盘上。
-->
<cache name="userCache" maxElementsInMemory="1000" eternal="false"
timeToIdleSeconds="120" timeToLiveSeconds="120" overflowToDisk="true"
diskSpoolBufferSizeMB="30" maxElementsOnDisk="10000000"
diskPersistent="false" diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU">
<cacheEventListenerFactory
class="net.sf.ehcache.distribution.RMICacheReplicatorFactory" />
<!-- 用于在初始化缓存,以及自动设置 -->
<bootstrapCacheLoaderFactory
class="net.sf.ehcache.distribution.RMIBootstrapCacheLoaderFactory" />
</cache>
</ehcache>
controller(ehcache)
@RestController
public class EhcacheSingleVersionController { @Autowired
private UserService userService; @Autowired
private CacheManager cacheManager; @Autowired
private EhcacheMap<String, String> ehcacheMap; @RequestMapping("/clear")
public String clear() { cacheManager.getCache("userCache").clear(); return "success";
} @RequestMapping("/getUser")
public List<User> getUser(Long id) { return userService.getUser(id);
} @RequestMapping("/save")
public String save(String name, Long id) { ehcacheMap.put(id.toString(), name); return "success";
}
}
dao(ehcache)
@CacheConfig(cacheNames = "userCache")
public interface UserMapper { @Select("SELECT ID ,NAME,AGE FROM user where id=#{id}")
@Cacheable
List<User> getUser(@Param("id") Long id); }
手动修改数据库值(ehcache)
二、redis单机版
1.yml配置文件
spring:
datasource:
url: jdbc:mysql://localhost:3306/mytest?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC
username: root
password: 123456
driver-class-name: com.mysql.cj.jdbc.Driver
test-while-idle: true
test-on-borrow: true
validation-query: SELECT 1 FROM DUAL
time-between-eviction-runs-millis: 300000
min-evictable-idle-time-millis: 1800000
# 缓存配置
cache:
type: ehcache
ehcache:
config: classpath:ehcache.xml
# redis
redis:
database: 0
host: xxx
port: 6379
password: xxx
jedis:
pool:
# 连接池最大连接数(使用负值表示没有限制)
max-active: 8
# 连接池最大阻塞等待时间(使用负值表示没有限制)
max-wait: -1
# 连接池中的最大空闲连接
max-idle: 8
# 连接池中的最小空闲连接
min-idle: 0
timeout: 10000
2.redisUtil
@Component
public class RedisUtil { @Autowired
private StringRedisTemplate stringRedisTemplate; public void set(String key, Object obj, Long timeout) {
if(obj instanceof String) {
setString(key, obj);
} else if(obj instanceof Set) {
setSet(key, obj);
}
// 设置有效期
if(timeout != null) {
stringRedisTemplate.expire(key, timeout, TimeUnit.SECONDS);
}
} private void setSet(String key, Object obj) { @SuppressWarnings("unchecked")
Set<String> value = (Set<String>) obj;
for (String str : value) {
stringRedisTemplate.opsForSet().add(key, str);
}
} private void setString(String key, Object obj) { String value = (String)obj; stringRedisTemplate.opsForValue().set(key, value);;
} }
3.Controller
@RestController
public class RedisSingleVersionController { @Autowired
private RedisUtil redisUtil; @RequestMapping("/setStr")
public String setStr(String key, String value) { String result = "success"; try {
redisUtil.set(key, value, null);
} catch (Exception e) {
e.printStackTrace();
result = "error";
} return result;
} @RequestMapping("/set")
public String set(String key) { String result = "success"; try {
Set<String> value = new HashSet<String>();
value.add("t1");
value.add("t2");
value.add("t3");
redisUtil.set(key, value, null);
} catch (Exception e) {
e.printStackTrace();
result = "error";
} return result;
}
}
4.运行
缓存机制 ehcache、redis的更多相关文章
- Spring(五)Spring缓存机制与Redis的结合
一.Redis和数据库的结合 使用Redis可以优化性能,但是存在Redis的数据和数据库同步的问题. 例如,T1时刻以将 key1 保存数据到 Redis,T2时刻刷新进入数据库,但是T3时刻发生了 ...
- Spring控制Hibernate的缓存机制ehcache
首先在spring.xml中进入bean <prop key="hibernate.cache.use_second_level_cache">true</pro ...
- 缓存机制总结(JVM内置缓存机制,MyBatis和Hibernate缓存机制,Redis缓存)
一.JVM内置缓存(值存放在JVM缓存中) 我们可以先了解一下Cookie,Session,和Cache Cookie:当你在浏览网站的时候,WEB 服务器会先送一小小资料放在你的计算机上,Cooki ...
- MyBatis加强(1)~缓存机制(一级缓存、二级缓存、第三方缓存技术redis、ehcache)
一.缓存机制 使用缓存可以使应用更快地获取数据,避免频繁的数据库交互操作,尤其是在查询越多,缓存命中率越高 的情况下,缓存的作用就越明显. 1.缓存原理:Map ■ 查询时,先从缓存区查询:找到,返回 ...
- EhCache+Redis实现分布式缓存
Ehcache集群模式 由于 EhCache 是进程中的缓存系统,一旦将应用部署在集群环境中,每一个节点维护各自的缓存数据,当某个节点对缓存数据进行更新,这些更新的数据无法在其它节点中共享,这不仅会降 ...
- (37)Spring Boot集成EHCache实现缓存机制【从零开始学Spring Boot】
[本文章是否对你有用以及是否有好的建议,请留言] 写后感:博主写这么一系列文章也不容易啊,请评论支持下. 如果看过我之前(35)的文章这一篇的文章就会很简单,没有什么挑战性了. 那么我们先说说这一篇文 ...
- (35)Spring Boot集成Redis实现缓存机制【从零开始学Spring Boot】
[本文章是否对你有用以及是否有好的建议,请留言] 本文章牵涉到的技术点比较多:Spring Data JPA.Redis.Spring MVC,Spirng Cache,所以在看这篇文章的时候,需要对 ...
- Spring Boot集成EHCache实现缓存机制
SpringBoot 缓存(EhCache 2.x 篇) SpringBoot 缓存 在 Spring Boot中,通过@EnableCaching注解自动化配置合适的缓存管理器(CacheManag ...
- SpringBoot缓存篇Ⅱ --- 整合Redis以及序列化机制
一.Redis环境搭建 系统默认是使用ConcurrentMapCacheManager,然后获取和创建ConcurrentMapCache类型的缓存组件,再将数据保存在ConcurrentMap中 ...
随机推荐
- Mac ---- markdown 转 html\word\pdf
在Mac上,有一个软件,叫iA writer,是一个文字编辑器,可以进行md到word的转换,但它是收费的,RMB68元. 如果只是临时用一下,不想购买,你可以使用pandoc. 在mac下,使用方法 ...
- day19模块1
http://www.cnblogs.com/Eva-J/articles/7228075.html#_label10 collections模块: 在内置数据类型(dict.list.set.tup ...
- shell生成rsync同步脚本
test #!/bin/bash # # Rsync Install Script # Last Updated # ##### modify by Jinayf ##### ######手动修改以下 ...
- 2017-2018-2 20155309南皓芯 Exp4 恶意代码分析
实验后回答问题 (1)如果在工作中怀疑一台主机上有恶意代码,但只是猜想,所有想监控下系统一天天的到底在干些什么.请设计下你想监控的操作有哪些,用什么方法来监控. 答:我会使用sysmon工具来进行监控 ...
- scrapy 通过FormRequest模拟登录再继续
1.参考 https://doc.scrapy.org/en/latest/topics/spiders.html#scrapy.spiders.Spider.start_requests 自动提交 ...
- day18常用模块之re模块
简单认识正则表达式 正则测试工具:http://tool.chinaz.com/regex/ 元字符,单个字符匹配 . 匹配除换行符以外的任意字符 \w 匹配字母数字下划线(word) \s 匹配任意 ...
- 利用yarn capacity scheduler在EMR集群上实现大集群的多租户的集群资源隔离和quota限制
转自:https://m.aliyun.com/yunqi/articles/79700 背景 使用过hadoop的人基本都会考虑集群里面资源的调度和优先级的问题,假设你现在所在的公司有一个大hado ...
- 消息队列——ActiceMQ
1.下载apache-activemq-5.xx.x,\bin\win64目录下运行activemq.bat.之后可进入管理员界面http://localhost:8161/admin,账号密码均为a ...
- jQuery中height()不能精确计算的问题
jQuery中关于高度的计算有三个方法:outerHeight().innerHeight().height() outerHeight():获取元素集合中第一个元素的当前计算高度值,包括paddin ...
- js实现数组去重的几种方法
1.简单结构的数组,例如[1,2,3,3,4],使用es6提供的Set和Array.from Set:是一种新的数据结构,可以接收一个数组或者是类数组对象,自动去重其中的重复项目. 类数组对象:只包含 ...