Springboot获取应用的上下文(记录)

本文介绍了如何在Springboot中获取ApplicationContext实例,以便于在底层代码中方便地获取配置信息和Bean。通过实现ApplicationContextAware接口创建一个ApplicationContextProvider类,或者使用PublicInstanceMgr类手动设置和获取上下文。

获取应用的上下文ApplicationContext实例非常有用,因为底层代码需要获取一些配置信息和Bean.这可以大大的增加底层的灵活性,下面代码是参照别人所写:

 

import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.stereotype.Component;

@Component
public class ApplicationContextProvider implements ApplicationContextAware
{
 /** * 上下文对象实例 */
 private static ApplicationContext applicationContext;
 
 @Override
 public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
  this.applicationContext = applicationContext;
 }
 /** * 获取applicationContext * @return */
 public static ApplicationContext getApplicationContext() {
  return applicationContext;
 }
 /** * 通过name获取 Bean. * @param name * @return */
 public static Object getBean(String name){
  return getApplicationContext().getBean(name);
 }
 /** * 通过class获取Bean. * @param clazz * @param <T> * @return */
 public static <T> T getBean(Class<T> clazz){
  return getApplicationContext().getBean(clazz);
 }
 /** * 通过name,以及Clazz返回指定的Bean * @param name * @param clazz * @param <T> * @return */
 public static <T> T getBean(String name,Class<T> clazz){
  return getApplicationContext().getBean(name, clazz);
 }
}

当然,也可以采用底层提供一个类来实现保存这个当前应用类,只是需要在应用启动函数里面记得传入当前应用类的实例到底层类:

import org.springframework.context.ApplicationContext;

public class PublicInstanceMgr {
 private static ApplicationContext _applicationContext;
 public static void SetApplicationContext(ApplicationContext appContext)
 {
  _applicationContext = appContext;
 }
 public static ApplicationContext GetCurrentAppContext()
 {
  return _applicationContext;
 }
}

 

public static void main(String[] args) throws IOException {
  ApplicationContext theCurrentApp = SpringApplication.run(GQSApplication.class, args);
  PublicInstanceMgr.SetApplicationContext(theCurrentApp);
 }

 

### Spring Boot 上下文缓存使用教程 #### 启用缓存管理 要在Spring Boot项目中启用缓存功能,需在配置类或启动类上添加`@EnableCaching`注解。此注解用于激活基于注解的缓存支持机制[^3]。 ```java import org.springframework.cache.annotation.EnableCaching; import org.springframework.context.annotation.Configuration; @Configuration @EnableCaching public class CacheConfig { } ``` #### 配置缓存管理器 对于简单的应用场景,默认情况下无需额外配置即可使用内置的简单内存缓存实现。然而,在生产环境中通常会选择更强大的缓存解决方案如Redis、Ehcache等作为后端存储介质。这里以集成Redis为例说明如何自定义CacheManager: ```java import org.springframework.context.annotation.Bean; import org.springframework.data.redis.connection.RedisConnectionFactory; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer; import org.springframework.data.redis.serializer.StringRedisSerializer; import org.springframework.cache.CacheManager; import org.springframework.cache.annotation.CachingConfigurerSupport; import org.springframework.cache.interceptor.KeyGenerator; import org.springframework.cache.annotation.EnableCaching; import org.springframework.context.annotation.Configuration; import org.springframework.data.redis.cache.RedisCacheConfiguration; import org.springframework.data.redis.cache.RedisCacheManager; import org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory; import java.time.Duration; @Configuration @EnableCaching public class RedisCacheConfig extends CachingConfigurerSupport { @Bean public KeyGenerator keyGenerator() { return (target, method, params) -> { StringBuilder sb = new StringBuilder(); sb.append(target.getClass().getName()); sb.append(method.getName()); for (Object param : params) { sb.append(param.toString()); } return sb.toString(); }; } @Bean public CacheManager cacheManager(RedisConnectionFactory redisConnectionFactory){ // 设置序列化方式为json 序列化 FastJsonRedisSerializer<Object> fastJsonRedisSerializer = new FastJsonRedisSerializer<>(Object.class); // 默认过期时间60秒 RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig() .entryTtl(Duration.ofSeconds(60)) .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer())) .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(fastJsonRedisSerializer)); RedisCacheManager rcm = RedisCacheManager.builder(redisConnectionFactory).cacheDefaults(config).build(); return rcm; } private static final int DEFAULT_EXPIRE_TIME = 60 * 60; // 单位:s /** * 自定义redisTemplate模板对象 */ @Bean(name="redisTemplate") public RedisTemplate<String,Object> redisTemplate(LettuceConnectionFactory factory){ RedisTemplate<String, Object> template = new RedisTemplate<>(); template.setConnectionFactory(factory); GenericJackson2JsonRedisSerializer genericJackson2JsonRedisSerializer = new GenericJackson2JsonRedisSerializer(); template.setKeySerializer(new StringRedisSerializer()); //key序列化 template.setValueSerializer(genericJackson2JsonRedisSerializer); //value序列化 template.afterPropertiesSet(); return template; } } ``` 上述代码片段展示了如何通过Java Config的方式创建一个带有JSON序列化的Redis `CacheManager`实例以及定制键生成策略的方法。这使得开发者能够灵活控制缓存条目的生命周期及其序列化行为[^1]。 #### 使用缓存注解简化业务逻辑 一旦完成了基础设置之后就可以利用几个核心注解来标记服务层方法从而达到自动处理缓存的目的: - **@Cacheable**: 当调用被该注解修饰的方法时,如果存在匹配条件下的缓存记录,则直接返回缓存的结果;反之则正常执行目标函数并将结果放入指定名称的空间内保存起来以便下次快速获取。 - **@CachePut**: 更新现有项而不影响其命中率统计信息。它总是会触发真实的数据持久化动作,并更新对应的缓存副本。 - **@CacheEvict**: 清除特定条件下满足要求的一个或者多个缓存实体。可以用来清理陈旧无用的信息释放资源空间。 下面给出一段示范性的Service接口定义: ```java @Service public interface BookService { @Cacheable(value = "books", unless="#result==null") List<Book> findAllBooks(); @CachePut(value = "books", key="#book.id") void updateBook(Book book); @CacheEvict(value={"books"}, allEntries=true) void clearAllBooksCache(); } ``` 以上就是有关于Spring Boot上下文中引入并运用缓存技术的大致流程概述。值得注意的是,合理规划缓存策略不仅有助于提升系统响应速度还能有效降低数据库负载压力,进而改善整体性能表现。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值