有这么一个需求 每个部门,需要操作的数据库不同,A部门要将数据放test数据库,B 部门数据 要放在test1数据库 同一个项目 需要整合 多个数据源

上传个demo 方便自己以后回看!!!!!!!!!

https://github.com/SCchengbo/springboot-mybatis-demo.git

  1. springboot使用AOP 过滤请求:
    在pom文件中导入 aop所需要的依赖

    <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-aop</artifactId>
    </dependency>
  2. 定义切面
    package com.springboot.aop;
    
    import org.aspectj.lang.JoinPoint;
    import org.aspectj.lang.annotation.AfterReturning;
    import org.aspectj.lang.annotation.Aspect;
    import org.aspectj.lang.annotation.Before;
    import org.aspectj.lang.annotation.Pointcut;
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    import org.springframework.stereotype.Component; @Aspect
    @Component
    public class testAspect {
    private Logger logger = LoggerFactory.getLogger(getClass()); @Pointcut("execution(public * com.springboot.controller..*.*(..))")
    public void testPoint() {
    } @Before(value = "testPoint()")
    public void doBefore(JoinPoint joinPoint) throws Throwable {
    logger.info("前置通知");
    } @AfterReturning(returning = "ret", pointcut = "testPoint()")
    public void doAfterReturning(Object ret) throws Throwable {
    // 处理完请求,返回内容
    logger.info("RESPONSE : " + ret);
    }
  3.  @Pointcut("execution(public * com.springboot.controller..*.*(..))") 所有反问com.springboot.controller包下的请求 都 会被切面拦截 执行路径 http://localhost:8080/select?name=zhangsan
    2019-02-11 16:09:22.362 [http-nio-8080-exec-1] INFO  com.springboot.aop.testAspect:33 - 前置通知
    2019-02-11 16:09:22.366 [http-nio-8080-exec-1] INFO com.springboot.controller.Controller:15 - 接受到请求
    2019-02-11 16:09:22.366 [http-nio-8080-exec-1] INFO com.springboot.aop.testAspect:39 - RESPONSE : zhangsan

关于 springboot 使用@Scheduled 做定时任务:

  1. package com.springboot.scheduledtasks;
    
    import java.text.SimpleDateFormat;
    import java.util.Date; import org.springframework.scheduling.annotation.Scheduled;
    import org.springframework.stereotype.Component; @Component
    public class ScheduledTasks {
    private static final SimpleDateFormat dateFormat = new SimpleDateFormat("HH:mm:ss"); @Scheduled(fixedRate = 5000)
    public void reportCurrentTime() {
    System.out.println("任务1:" + dateFormat.format(new Date()));
    } }
  2. 在启动类上面 必须添加@EnableScheduling 注解 不然 定时任务 不起作用
    任务1:17:10:22
    任务1:17:10:27
  3. ScheduledTasks原理:

    简要介绍:spring在初始化bean后,通过“postProcessAfterInitialization”拦截到所有的用到“@Scheduled”注解的方法,并解析相应的的注解参数,放入“定时任务列表”等待后续处理;之后再“定时任务列表”中统一执行相应的定时任务(任务为顺序执行,先执行cron,之后再执行fixedRate)。

    重要代码如下:

    第一步:依次加载所有的实现Scheduled注解的类方法。

    第二步:将对应类型的定时器放入相应的“定时任务列表”中。

    第三步:执行相应的定时任务。

    参考资料:https://blog.csdn.net/gaodebao1/article/details/51789225
  4. ScheduledTasks是单线程执行任务,平常 使用定时任务 用的xxl  如果是想要实现多线程 定时任务 则要重写
    configureTasks方法
    package com.springboot.scheduledtasks;
    
    import java.util.concurrent.Executors;
    
    import org.springframework.context.annotation.Configuration;
    import org.springframework.scheduling.annotation.SchedulingConfigurer;
    import org.springframework.scheduling.config.ScheduledTaskRegistrar; @Configuration
    public class ScheduleConfig implements SchedulingConfigurer {
    @Override
    public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
    // 设定一个长度10的定时任务线程池
    taskRegistrar.setScheduler(Executors.newScheduledThreadPool(10));
    } }
  5. 测试多线程执行:
    package com.springboot.scheduledtasks;
    
    import java.text.SimpleDateFormat;
    import java.util.Date; import org.springframework.scheduling.annotation.Scheduled;
    import org.springframework.stereotype.Component; @Component
    public class ScheduledTasks {
    private static final SimpleDateFormat dateFormat = new SimpleDateFormat("HH:mm:ss"); @Scheduled(fixedRate = 5000)
    public void reportCurrentTime() {
    System.out.println("任务1:" + dateFormat.format(new Date()));
    } @Scheduled(fixedRate = 5000)
    public void reportCurrentTime1() {
    System.out.println("任务2:" + dateFormat.format(new Date()));
    for (;;) { }
    } }
  6. 结果:
    任务1:17:18:32
    任务1:17:18:37
    任务1:17:18:42
    任务1:17:18:47
    任务1:17:18:52
ScheduledTasks平常用的比较少。都是公司内部自己封装的,也有类似xxl此类的定时任务

关于springboot 中 异步方法调用,原来 项目中 希望调用一个 不阻塞的方法的时候,是新创建一个线程 来 执行 需要的逻辑。。springboot 中直接可以使用@Async 标记需要异步执行的方法就可以了
package com.springboot.util;

import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Component; @Component
public class TestAsync {
@Async
public void testAsyncMethod() {
for (;;) { }
}
}
    @RequestMapping("/testAsync")
public void testAsync() {
testAsync.testAsyncMethod();
logger.info("测试异步调用");
}

一定需要在启动类中 添加@EnableAsync  注解  不然  异步方法调用 不起作用

springboot如何获取 properties文件中自定义的参数值

package com.springboot.controller;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.scheduling.annotation.Async;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody; import com.springboot.util.TestAsync; @org.springframework.stereotype.Controller
public class Controller {
private static Logger logger = LoggerFactory.getLogger(Controller.class);
@Autowired
public TestAsync testAsync;
@Value("${time}")
public int time; @RequestMapping("/getTime")
@ResponseBody
public Integer getTime() {
return time; }

使用@Value注解

 @Value("${time}") 可以获取自定义的数据信息

springboot(整合多数据源demo,aop,定时任务,异步方法调用,以及获取properties中自定义的变量值)的更多相关文章

  1. springboot整合多数据源解决分布式事务

    一.前言        springboot整合多数据源解决分布式事务.             1.多数据源采用分包策略              2.全局分布式事务管理:jta-atomikos. ...

  2. springBoot整合多数据源

    springBoot整合相关 1:springBoot整合多数据源: 应用场景:     项目需要同时连接两个不同的数据库A, B,并且它们都为主从架构,一台写库,多台读库. 工具/版本: jdk1. ...

  3. 第九章 springboot + mybatis + 多数据源 (AOP实现)

    在第八章 springboot + mybatis + 多数据源代码的基础上,做两点修改 1.ShopDao package com.xxx.firstboot.dao; import org.spr ...

  4. SpringBoot整合多数据源实现

    项目架构 1.导入相关依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifac ...

  5. springboot整合多数据源及事物

    有两种方式:一种是分包的方式.一种是加注解的方式(@DataSource(ref="")). 分包方式:项目结构图如下: 分为com.itmayiedu.test01.com.it ...

  6. SpringBoot整合Druid数据源

    关于SpringBoot数据源请参考我上一篇文章:https://www.cnblogs.com/yueshutong/p/9409295.html 一:Druid介绍 1. Druid是什么? Dr ...

  7. springboot整合Quartz实现动态配置定时任务

    前言 在我们日常的开发中,很多时候,定时任务都不是写死的,而是写到数据库中,从而实现定时任务的动态配置,下面就通过一个简单的示例,来实现这个功能. 一.新建一个springboot工程,并添加依赖 & ...

  8. 【第九章】 springboot + mybatis + 多数据源 (AOP实现)

    在第八章 springboot + mybatis + 多数据源代码的基础上,做两点修改 1.ShopDao package com.xxx.firstboot.dao; import org.spr ...

  9. spring-boot整合dubbo启动demo

    参考资料: https://docs.spring.io/spring-boot/docs/2.1.7.RELEASE/reference/html/ https://github.com/apach ...

随机推荐

  1. document.write中输出html标签用法

    输出HTML标签,只需将标签写入双引号: 示例:在网页中输出<p>革命还在继续</p> document.write("<p style='border:1px ...

  2. (24)ajax上传json格式的数据

    urs.py from django.conf.urls import urlfrom django.contrib import adminfrom app01 import viewsurlpat ...

  3. C++学习(十七)(C语言部分)之 指针

    复习 数组定义格式 类型 数组名[数组大小]数组名+下标 int arr[2][3]={{1,2,3},{4,5,6}}; int arr[][3]={1,2,3,4,5,6};//二维数组定义的时候 ...

  4. 静态布局、自适应布局、流式布局、响应式布局、弹性布局简析、BFC

    静态布局:给页面元素设置固定的宽度和高度,单位用px,当窗口缩小,会出现滚动条,拉动滚动条显示被遮挡内容.针对不同分辨率的手机端,分别写不同的样式文件.例如:浏览器窗口是1000px,那么最小的宽度是 ...

  5. WEBapi在IIS发布注意事项-发布错误

    发布报错:403.14-Forbidden Web 服务器被配置为不列出此目录的内容 解决方法: 1)打开IIS管理器 2)找到功能视图的目录浏览 3)双击进入后,点击右侧操作栏-启用

  6. SpringMVC(二)高级

    高级参数绑定 1.1. 绑定数组 1.1.1. 需求 在商品列表页面选中多个商品,然后删除. 1.1.2. 需求分析 功能要求商品列表页面中的每个商品前有一个checkbok,选中多个商品后点击删除按 ...

  7. mysql修改用户密码

    修改自己的密码(root用户,其它用户应该也差不多) 方法一: [root@localhost /]# mysqladmin -u root -p password "root" ...

  8. SolrCore Initialization Failures - Max direct memory is likely too low

    org.apache.solr.common.SolrException:org.apache.solr.common.SolrException: The max direct memory is ...

  9. 推荐一篇文章 《为什么C语言不会过时?》

    <为什么C语言不会过时?>    文章地址 : https://mp.weixin.qq.com/s?__biz=MzAxOTc0NzExNg==&mid=2665515153&a ...

  10. tomcat源码阅读之Tribes.RpcChannel

    一.RpcChannel简介: 1.RPC即远程过程调用,它的提出旨在消除通信细节.屏蔽繁杂且易错的底层网络通信操作,像调用本地服务一般地调用远程服务,让业务开发者更多关注业务开发而不必考虑网络.硬件 ...