- 【Redis基础篇】详细讲解Redis
小林同学学JAVA
redis数据库redis服务器nosql缓存数据库javaspringboot
这篇文章让你详细了解Redis的相关知识,有代码讲解以及图片剖析,让你更轻松掌握制作不易,感觉不错,请点赞收藏哟!!!目录1redis基础1.1定义1.2SQL和NOSQL不同点1.3特征1.4Redis通用命令1.5Redis数据结构介绍1.6Redis的java客户端2Jedis快速入门2.1操作步骤2.2Jedis连接池3SpringDataRedis3.1定义3.2优势3.3API3.4操
- Redis cluster 集群TLS and Jedis使用SSL调用redis服务
潘多编程
Redis数据库redislinux
安装#安装依赖软件sudoaptupdatesudoaptinstallmakegcclibssl-devpkg-config#下载redis解压wgethttps://download.redis.io/releases/redis-6.2.6.tar.gztar-xvfredis-6.2.6.tar.gz#编译cdredis-6.2.6makeBUILD_TLS=yes#如果执行编译出错,提示
- JedisUtils 对jedis的封装 and RedisCacheManager 管理多个连接池
潘多编程
Redisredis
RedisCacheManagerimportjava.util.concurrent.ConcurrentHashMap;importorg.springframework.beans.factory.annotation.Value;importorg.springframework.stereotype.Service;importredis.clients.jedis.Jedis;impo
- jedis 与 redission 实现分布式锁
不知言愁
项目实战分布式redisjava
本文为博主原创,未经允许不得转载:1.Jedis实现分布式锁2.Redission实现分布式锁为了确保分布式锁可用,至少要保证锁的实现同时满足以下几个条件互斥性:在任意时刻只有一个客户端能持有锁不会死锁:即使有一个客户端在持有锁的期间发生崩溃而没有主动解锁,也能保证后续其它客户端能加锁容错性:只要大部分的Redis节点正常运行,客户端就可以加锁和解锁解铃还须系铃人:加锁和解锁必须是同一个客户端,客
- 在springboot项目使用redis
weixin_44953227
Javaspringbootredisjava
目录单例模式集群模式springboot框架中已经集成了redis,在1.x.x的版本时默认使用的jedis客户端,现在是2.x.x版本默认使用的lettuce客户端在properties文件配置redis客户端信息可以实现应用系统调用redis服务单例模式#Redis注意,如果项目中已经配置了spring.redis,则可以不用重复配置#使用数据库spring.redis.database=0#
- java redis常见操作
liyongjie
RedisJAVAjavaredis开发语言
本文介绍java操作Redis的常见方法采用Jedis方法操作,需要引入jedisjar包,本例子引用的是:jedis-5.2.0-beta4.jarimportjava.util.HashMap;importjava.util.Iterator;importjava.util.List;importjava.util.Map;importjava.util.Set;importredis.cli
- 使用Java连接redis的方式
l23456789o
redisjavajavaredis开发语言
除了使用SpringDataRedis,Java连接Redis还可以通过以下几种方式:1.JedisJedis是一个流行的JavaRedis客户端库,提供了简单的API来访问Redis。依赖:redis.clientsjedis4.2.3示例代码:importredis.clients.jedis.Jedis;publicclassJedisExample{publicstaticvoidmain
- 使用Jedis远程连接redis
E_3096
1.检查是否关闭linux的防火墙cent6.x关闭防火墙语句:serviceiptablesstop禁止开机启动防火墙:chkconfigiptablesoffcentos7的防火墙已经变了,关闭语句为:systemctlstopfirewalld.service禁止防火墙开机启动:systemctldisablefirewalld.service2.查看配置文件redis.confredis默
- Java 操作 Redis和redis持久化
#helloworld
开发语言数据库redis
一、Jedis我们要使用Java来操作Redis,Jedis是Redis官方推荐的java连接开发工具!使用Java操作Redis中间件!1.导入对应的依赖https://mvnrepository.com/artifact/redis.clients/jedisredis.clientsjedis3.2.02、编码测试:@SpringBootTestclassTransactionYiburen
- 集群方式下的java Redis锁 lua脚本
成长之旅
后端java
下面说一下集群方式redis下的原子锁带超时时间java代码如下:Listkeys=Collections.singletonList("test_key1");System.out.println("打印前::"+jedisCluster.get("test_key1"));//获取lua脚本这里你可以所以我是放在META-INF/scripts/redis/test.lua路径下,//获取到之
- 详解 Redis 实现数据去重
喔的嘛呀
redis数据库缓存
目录引言一.Redis去重原理1.RedisSet数据结构2.基于Set实现数据去重3.代码示例4.总结二.环境准备三.使用Jedis连接Redis四.实现数据去重功能五.测试数据去重功能六.总结言在实际的应用开发中,经常会遇到需要对数据进行去重的情况。利用Redis可以很方便地实现数据去重功能。本文将介绍如何利用Redis实现数据去重,并附上详细的代码示例。一.Redis去重原理Redis的去重
- Redis 之八:Jdeis API 的使用(Java 操作 Redis)
zp8126
Redisredisjava数据库缓存
JedisAPI使用Jedis是Redis官方推荐的Java客户端,它提供了一套丰富的API来操作Redis服务器。通过JedisAPI,开发者可以方便地在Java应用程序中执行Redis的命令来实现数据的增删查改以及各种复杂的数据结构操作。以下是一些基本的JedisAPI示例和它们对应的功能:常用操作连接RedisJedisjedis=newJedis("localhost",6379);//创
- Redis篇----第八篇
数据大魔王
java面试题套2redis数据库缓存
系列文章目录文章目录系列文章目录前言一、是否使用过Redis集群,集群的原理是什么?二、Redis集群方案什么情况下会导致整个集群不可用?三、Redis支持的Java客户端都有哪些?官方推荐用哪个?四、、Jedis与Redisson对比有什么优缺点?五、Redis如何设置密码及验证密码?前言前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站,这篇文章男
- Java使用Redis实现消息队列
谦风(主Java)(接口开发)
redisjavaredis
近期刷Java面试题刷到了“如何使用Redis实现消息队列”,解答如下:一般使用list结构作为队列,rpush生产消息,lpop消费消息。当lpop没有消息的时候,要适当sleep一会再重试。若不使用sleep,则可以用指令blpop(该指令在没有消息的时候,它会阻塞住直到消息到来)目录引入Jedis指令简介rpushblpopJava使用Redis实现消息队列引入Jedisredis.clie
- Java实现Redis延时队列
谦风(主Java)(接口开发)
redisjavaredis延时队列
“如何实现Redis延时队列”这个面试题应该也是比较常见的,解答如下:使用sortedset(有序集合),拿时间戳作为score,消息内容作为key调用zadd来生产消息,消费者用zrangebyscore指令获取N秒之前的数据轮询进行处理。目录实现思路引入Jedis指令简介zaddzremzrangeByScoreJava实现Redis延时队列实现思路Java实现Redis延时队列,首先要了解何
- maven巧妙排除父pom的依赖
高粱
项目中引入架构师搭好的父pom工程4.0.0com.xxx.xxxparent0.0.1-RELEASExxx-xxx-xxx0.0.1-RELEASEpom发现一个问题子模块如何把父pom依赖的jar包排除掉呢思前想后直接在父依赖pom直接排除呢com.zytparent1.0-SNAPSHOT..jedis尝试未果不能这样排除于是想到了这样一个方法,直接依赖覆盖搞定子类重写,定义scope为t
- Redis-mysql 缓存实战
SSPo
redisJava缓存redis数据库
本文基于Springboot,mybatisplus,mysql,redis,Jedis模拟redis缓存实现目录1.添加所需maven依赖2.设置数据库及数据表3.构建实体类4.构建工具类实现redis数据库连接池,redis的读取,写入功能5.Redis缓存实战1.添加所需maven依赖redis.clientsjedis3.6.3com.baomidoumybatis-plus-boot-s
- springboot使用redis(从配置到实战)
Python研究者
概述springboot通常整合redis,采用的是RedisTemplate的形式,除了这种形式以外,还有另外一种形式去整合,即采用spring支持的注解进行访问缓存.准备工作pom.xmlredis.clientsjedis2.7.3org.springframework.dataspring-data-redis1.7.2.RELEASEorg.springframework.bootspr
- IDEA 中使用 Jedis 操作 Redis
二境志
Redisredisjavaidea
七IDEA中使用Jedis操作RedisJedisisablazinglysmallandsaneRedisjavaclient.JediswasconceivedtobeEASYtouse.Jedis是一款可以让我们在java中操作redis数据库的工具,下载其jar包,或者引入到maven中即可,使用还是非常简单的(一)引入依赖和编码我这里创建了一个空项目,然后创建一个普通的maven模块用来
- java - idea连接redis
卿(⑉°з°)-♡心
javaintellij-idea开发语言
目录1.创建一个普通的maven工程1java连接单机redis(1)在一个项目中创建子模块.方便于整理.(2)引入redis依赖(3)测试2java通过连接池连接redis3java连接redis集群1.创建一个普通的maven工程1java连接单机redis(1)在一个项目中创建子模块.方便于整理.(2)引入redis依赖redis.clientsjedis3.8.0(3)测试publiccl
- java实战:Redis实现查找附近的人
拥抱AI
javaredis开发语言
本文将介绍如何使用Redis实现查找附近的人的功能。我们将探讨如何使用Redis的地理空间(Geospatial)索引功能,并展示一个简单的Java代码示例,该示例使用Jedis库和Redis的GEOADD命令来添加位置信息,以及使用GEORADIUS命令来查找附近的人。通过本文,可以了解到如何在Java应用程序中使用Redis实现查找附近的人的功能。一、地理空间索引概述Redis的地理空间(Ge
- java实战:基于Redis的ZSet实现秒级排行榜
拥抱AI
javaredisbootstrap
本文将介绍如何使用Redis的ZSet(有序集合)来实现一个秒级排行榜。展示如何使用Java和Jedis库来创建、更新和获取排行榜数据。通过本文,可以了解到如何在Java应用程序中使用Redis的ZSet来实现一个高性能的秒级排行榜。一、ZSet概述Redis的ZSet(SortedSet)是一种有序集合,它结合了Set和SortedList的特性,成员是唯一的,且按照成员的分数(score)进行
- 【解决】redis集群加入密码报错“Jedis does not support password protected Redis Cluster configurations“
辣个仔
问题解决方案redisredisspringboot
升级redis密码之后,运行程序报错"JedisdoesnotsupportpasswordprotectedRedisClusterconfigurations"。原因:Jedis版本原因不支持Redis密码当时我们用的Jedis版本是2.8.2(jedis-2.8.2.jar),redis版本是1.7.2(jedis-2.8.2.jar),springboot版本是1.4.0(1.4.0.RE
- MapReduce任务输出到redis中
cute泡泡
主要包括redis连接池,重写FileOutputFormat函数。redis连接池/***redis连接池*/publicclassRedisHelper{privatestaticJedisPooljedisPool;static{init();}publicsynchronizedstaticJedisgetJedis(){if(jedisPool!=null){Jedisresource=
- Redis分布式锁
辞暮尔尔-烟火年年
Redisredis分布式
Redis分布式锁是一种在分布式系统中协调多个进程对共享资源访问的机制。在Redis中实现分布式锁主要依赖于几个关键的操作原子性。在使用Redis实现分布式锁时,通常关注的是命令的原子性,以及如何确保锁的安全性和可靠性。可以使用SET命令结合NX(NoteXists,只在键不存在时设置键)和PX(毫秒级过期)选项来实现。以下是一个Java代码示例,演示如何利用Jedis客户端实现Redis分布式锁
- Jedis
niceffking
javaEE进阶Redisredisjedisjava
目录依赖下载配置SSH转发连接到redis服务器客户端的使用get/setexists/delkeysexpire/ttltype字符串命令mget/msetgetrange/setrangeappendincr/decr列表listpush/pop/lrangeblpop/brpopllen集合setsaddsismemberscardspopsintersinterstorehashhset/
- Jedis与SpringBoot整合redis
Yield & Allure
springbootredis后端
一、Jedis1、使用Java来操作RedisJedis是Redis官方推荐使用的Java连接redis的客户端。导入依赖redis.clientsjedis3.2.0com.alibabafastjson1.2.70编码测试连接数据库操作命令断开连接TestPing.javapublicclassTestPing{publicstaticvoidmain(String[]args){//1、ne
- 【Spring学习】Spring Data Redis:RedisTemplate、Repository、Cache注解
兔兔西
springredis
1,spring-data-redis官网1)特点提供了对不同Redis客户端的整合(Lettuce和Jedis)提供了RedisTemplate统一API来操作Redis支持Redis的发布订阅模型支持Redis哨兵和Redis集群支持基于Lettuce的响应式编程支持基于JDK、JSON、字符串、Spring独享的数据序列化及反序列化支持基于Redis的JDKCollection实现2,Red
- jedis分片原理剖析
小雪的笔记
Redis2.0+版本不支持服务器分片,只能通过jedis分片,3.0+以上支持hash槽的服务端分片。jedis的详细分片实现如下,其中murmurhash是当前主流的分片算法。/***机器分片的方式*注意jedis服务器影响分片的两个因素*1、权重*2、添加的顺序*@paramargs*/publicstaticvoidmain(String[]args){TreeMapnodes=newTr
- springboot redis 实现消息队列
java知路
springbootredisjava
在SpringBoot中使用Redis作为消息队列,可以通过以下步骤实现:1.添加依赖在`pom.xml`文件中添加SpringBootRedis和Jedis的依赖:```xmlorg.springframework.bootspring-boot-starter-data-redisredis.clientsjedis```2.配置Redis在`application.properties`文件
- Enum 枚举
120153216
enum枚举
原文地址:http://www.cnblogs.com/Kavlez/p/4268601.html Enumeration
于Java 1.5增加的enum type...enum type是由一组固定的常量组成的类型,比如四个季节、扑克花色。在出现enum type之前,通常用一组int常量表示枚举类型。比如这样:
public static final int APPLE_FUJI = 0
- Java8简明教程
bijian1013
javajdk1.8
Java 8已于2014年3月18日正式发布了,新版本带来了诸多改进,包括Lambda表达式、Streams、日期时间API等等。本文就带你领略Java 8的全新特性。
一.允许在接口中有默认方法实现
Java 8 允许我们使用default关键字,为接口声明添
- Oracle表维护 快速备份删除数据
cuisuqiang
oracle索引快速备份删除
我知道oracle表分区,不过那是数据库设计阶段的事情,目前是远水解不了近渴。
当前的数据库表,要求保留一个月数据,且表存在大量录入更新,不存在程序删除。
为了解决频繁查询和更新的瓶颈,我在oracle内根据需要创建了索引。但是随着数据量的增加,一个半月数据就要超千万,此时就算有索引,对高并发的查询和更新来说,让然有所拖累。
为了解决这个问题,我一般一个月会进行一次数据库维护,主要工作就是备
- java多态内存分析
麦田的设计者
java内存分析多态原理接口和抽象类
“ 时针如果可以回头,熟悉那张脸,重温嬉戏这乐园,墙壁的松脱涂鸦已经褪色才明白存在的价值归于记忆。街角小店尚存在吗?这大时代会不会牵挂,过去现在花开怎么会等待。
但有种意外不管痛不痛都有伤害,光阴远远离开,那笑声徘徊与脑海。但这一秒可笑不再可爱,当天心
- Xshell实现Windows上传文件到Linux主机
被触发
windows
经常有这样的需求,我们在Windows下载的软件包,如何上传到远程Linux主机上?还有如何从Linux主机下载软件包到Windows下;之前我的做法现在看来好笨好繁琐,不过也达到了目的,笨人有本方法嘛;
我是怎么操作的:
1、打开一台本地Linux虚拟机,使用mount 挂载Windows的共享文件夹到Linux上,然后拷贝数据到Linux虚拟机里面;(经常第一步都不顺利,无法挂载Windo
- 类的加载ClassLoader
肆无忌惮_
ClassLoader
类加载器ClassLoader是用来将java的类加载到虚拟机中,类加载器负责读取class字节文件到内存中,并将它转为Class的对象(类对象),通过此实例的 newInstance()方法就可以创建出该类的一个对象。
其中重要的方法为findClass(String name)。
如何写一个自己的类加载器呢?
首先写一个便于测试的类Student
- html5写的玫瑰花
知了ing
html5
<html>
<head>
<title>I Love You!</title>
<meta charset="utf-8" />
</head>
<body>
<canvas id="c"></canvas>
- google的ConcurrentLinkedHashmap源代码解析
矮蛋蛋
LRU
原文地址:
http://janeky.iteye.com/blog/1534352
简述
ConcurrentLinkedHashMap 是google团队提供的一个容器。它有什么用呢?其实它本身是对
ConcurrentHashMap的封装,可以用来实现一个基于LRU策略的缓存。详细介绍可以参见
http://code.google.com/p/concurrentlinke
- webservice获取访问服务的ip地址
alleni123
webservice
1. 首先注入javax.xml.ws.WebServiceContext,
@Resource
private WebServiceContext context;
2. 在方法中获取交换请求的对象。
javax.xml.ws.handler.MessageContext mc=context.getMessageContext();
com.sun.net.http
- 菜鸟的java基础提升之道——————>是否值得拥有
百合不是茶
1,c++,java是面向对象编程的语言,将万事万物都看成是对象;java做一件事情关注的是人物,java是c++继承过来的,java没有直接更改地址的权限但是可以通过引用来传值操作地址,java也没有c++中繁琐的操作,java以其优越的可移植型,平台的安全型,高效性赢得了广泛的认同,全世界越来越多的人去学习java,我也是其中的一员
java组成:
- 通过修改Linux服务自动启动指定应用程序
bijian1013
linux
Linux中修改系统服务的命令是chkconfig (check config),命令的详细解释如下: chkconfig
功能说明:检查,设置系统的各种服务。
语 法:chkconfig [ -- add][ -- del][ -- list][系统服务] 或 chkconfig [ -- level <</SPAN>
- spring拦截器的一个简单实例
bijian1013
javaspring拦截器Interceptor
Purview接口
package aop;
public interface Purview {
void checkLogin();
}
Purview接口的实现类PurviesImpl.java
package aop;
public class PurviewImpl implements Purview {
public void check
- [Velocity二]自定义Velocity指令
bit1129
velocity
什么是Velocity指令
在Velocity中,#set,#if, #foreach, #elseif, #parse等,以#开头的称之为指令,Velocity内置的这些指令可以用来做赋值,条件判断,循环控制等脚本语言必备的逻辑控制等语句,Velocity的指令是可扩展的,即用户可以根据实际的需要自定义Velocity指令
自定义指令(Directive)的一般步骤
&nbs
- 【Hive十】Programming Hive学习笔记
bit1129
programming
第二章 Getting Started
1.Hive最大的局限性是什么?一是不支持行级别的增删改(insert, delete, update)二是查询性能非常差(基于Hadoop MapReduce),不适合延迟小的交互式任务三是不支持事务2. Hive MetaStore是干什么的?Hive persists table schemas and other system metadata.
- nginx有选择性进行限制
ronin47
nginx 动静 限制
http {
limit_conn_zone $binary_remote_addr zone=addr:10m;
limit_req_zone $binary_remote_addr zone=one:10m rate=5r/s;...
server {...
location ~.*\.(gif|png|css|js|icon)$ {
- java-4.-在二元树中找出和为某一值的所有路径 .
bylijinnan
java
/*
* 0.use a TwoWayLinkedList to store the path.when the node can't be path,you should/can delete it.
* 1.curSum==exceptedSum:if the lastNode is TreeNode,printPath();delete the node otherwise
- Netty学习笔记
bylijinnan
javanetty
本文是阅读以下两篇文章时:
http://seeallhearall.blogspot.com/2012/05/netty-tutorial-part-1-introduction-to.html
http://seeallhearall.blogspot.com/2012/06/netty-tutorial-part-15-on-channel.html
我的一些笔记
===
- js获取项目路径
cngolon
js
//js获取项目根路径,如: http://localhost:8083/uimcardprj
function getRootPath(){
//获取当前网址,如: http://localhost:8083/uimcardprj/share/meun.jsp
var curWwwPath=window.document.locati
- oracle 的性能优化
cuishikuan
oracleSQL Server
在网上搜索了一些Oracle性能优化的文章,为了更加深层次的巩固[边写边记],也为了可以随时查看,所以发表这篇文章。
1.ORACLE采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他WHERE条件之前,那些可以过滤掉最大数量记录的条件必须写在WHERE子句的末尾。(这点本人曾经做过实例验证过,的确如此哦!
- Shell变量和数组使用详解
daizj
linuxshell变量数组
Shell 变量
定义变量时,变量名不加美元符号($,PHP语言中变量需要),如:
your_name="w3cschool.cc"
注意,变量名和等号之间不能有空格,这可能和你熟悉的所有编程语言都不一样。同时,变量名的命名须遵循如下规则:
首个字符必须为字母(a-z,A-Z)。
中间不能有空格,可以使用下划线(_)。
不能使用标点符号。
不能使用ba
- 编程中的一些概念,KISS、DRY、MVC、OOP、REST
dcj3sjt126com
REST
KISS、DRY、MVC、OOP、REST (1)KISS是指Keep It Simple,Stupid(摘自wikipedia),指设计时要坚持简约原则,避免不必要的复杂化。 (2)DRY是指Don't Repeat Yourself(摘自wikipedia),特指在程序设计以及计算中避免重复代码,因为这样会降低灵活性、简洁性,并且可能导致代码之间的矛盾。 (3)OOP 即Object-Orie
- [Android]设置Activity为全屏显示的两种方法
dcj3sjt126com
Activity
1. 方法1:AndroidManifest.xml 里,Activity的 android:theme 指定为" @android:style/Theme.NoTitleBar.Fullscreen" 示例: <application
- solrcloud 部署方式比较
eksliang
solrCloud
solrcloud 的部署其实有两种方式可选,那么我们在实践开发中应该怎样选择呢? 第一种:当启动solr服务器时,内嵌的启动一个Zookeeper服务器,然后将这些内嵌的Zookeeper服务器组成一个集群。 第二种:将Zookeeper服务器独立的配置一个集群,然后将solr交给Zookeeper进行管理
谈谈第一种:每启动一个solr服务器就内嵌的启动一个Zoo
- Java synchronized关键字详解
gqdy365
synchronized
转载自:http://www.cnblogs.com/mengdd/archive/2013/02/16/2913806.html
多线程的同步机制对资源进行加锁,使得在同一个时间,只有一个线程可以进行操作,同步用以解决多个线程同时访问时可能出现的问题。
同步机制可以使用synchronized关键字实现。
当synchronized关键字修饰一个方法的时候,该方法叫做同步方法。
当s
- js实现登录时记住用户名
hw1287789687
记住我记住密码cookie记住用户名记住账号
在页面中如何获取cookie值呢?
如果是JSP的话,可以通过servlet的对象request 获取cookie,可以
参考:http://hw1287789687.iteye.com/blog/2050040
如果要求登录页面是html呢?html页面中如何获取cookie呢?
直接上代码了
页面:loginInput.html
代码:
<!DOCTYPE html PUB
- 开发者必备的 Chrome 扩展
justjavac
chrome
Firebug:不用多介绍了吧https://chrome.google.com/webstore/detail/bmagokdooijbeehmkpknfglimnifench
ChromeSnifferPlus:Chrome 探测器,可以探测正在使用的开源软件或者 js 类库https://chrome.google.com/webstore/detail/chrome-sniffer-pl
- 算法机试题
李亚飞
java算法机试题
在面试机试时,遇到一个算法题,当时没能写出来,最后是同学帮忙解决的。
这道题大致意思是:输入一个数,比如4,。这时会输出:
&n
- 正确配置Linux系统ulimit值
字符串
ulimit
在Linux下面部 署应用的时候,有时候会遇上Socket/File: Can’t open so many files的问题;这个值也会影响服务器的最大并发数,其实Linux是有文件句柄限制的,而且Linux默认不是很高,一般都是1024,生产服务器用 其实很容易就达到这个数量。下面说的是,如何通过正解配置来改正这个系统默认值。因为这个问题是我配置Nginx+php5时遇到了,所以我将这篇归纳进
- hibernate调用返回游标的存储过程
Supanccy2013
javaDAOoracleHibernatejdbc
注:原创作品,转载请注明出处。
上篇博文介绍的是hibernate调用返回单值的存储过程,本片博文说的是hibernate调用返回游标的存储过程。
此此扁博文的存储过程的功能相当于是jdbc调用select 的作用。
1,创建oracle中的包,并在该包中创建的游标类型。
---创建oracle的程
- Spring 4.2新特性-更简单的Application Event
wiselyman
application
1.1 Application Event
Spring 4.1的写法请参考10点睛Spring4.1-Application Event
请对比10点睛Spring4.1-Application Event
使用一个@EventListener取代了实现ApplicationListener接口,使耦合度降低;
1.2 示例
包依赖
<p