SpringBoot定时任务打成jar 引入到新的项目中后并自动执行

一、springBoot开发定时任务

①:连接数据库实现新增功能

1. 引入依赖

<dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional>
</dependency>
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope>
</dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId>
</dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jdbc</artifactId>
</dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.26</version>
</dependency><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>2.3.0</version>
</dependency>

2. 配置yaml

server:port: 19000             # ????????spring:application:name: djyp-stater         # ???????datasource:url: jdbc:mysql://ip地址:3306/djyp?characterEncoding=UTF-8&serverTimezone=Asia/Shanghaiusername: rootpassword: 密码driver-class-name: com.mysql.cj.jdbc.Driver

3. 创建实体类

@Entity
@Table (name = "log", schema = "djyp", catalog = "")
public class LogEntity {@GeneratedValue (strategy = GenerationType.IDENTITY)@Id@Column (name = "id")private long id;@Basic@Column (name = "create_time")private Date createTime;@Basic@Column (name = "status")private Integer status;public long getId () {return id;}public void setId (long id) {this.id = id;}public Date getCreateTime () {return createTime;}public void setCreateTime (Date createTime) {this.createTime = createTime;}public Integer getStatus () {return status;}public void setStatus (Integer status) {this.status = status;}@Overridepublic boolean equals (Object o) {if (this == o) return true;if (o == null || getClass() != o.getClass()) return false;LogEntity logEntity = (LogEntity) o;return id == logEntity.id && Objects.equals(createTime, logEntity.createTime) && Objects.equals(status, logEntity.status);}@Overridepublic int hashCode () {return Objects.hash(id, createTime, status);}
}

4. 创建mapper执行SQL

@Mapper
public interface LogMapper{@Insert("insert into log(create_time) values (#{date})")int add (@Param("date") Date date);
}

②:配置logback日志

image.png

1. 引入依赖 配置yml

<!-- 引入日志框架 -->
<dependency><groupId>ch.qos.logback</groupId><artifactId>logback-classic</artifactId>
</dependency>
logging:level:com.example: infopattern:console: "%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n"

2. 创建日志配置类

import ch.qos.logback.classic.Level;
import ch.qos.logback.classic.spi.ILoggingEvent;
import ch.qos.logback.core.pattern.color.ANSIConstants;
import ch.qos.logback.core.pattern.color.ForegroundCompositeConverterBase;public class LogbackColorful extends ForegroundCompositeConverterBase<ILoggingEvent> {@Overrideprotected String getForegroundColorCode(ILoggingEvent event) {Level level = event.getLevel();switch (level.toInt()) {//ERROR等级为红色case Level.ERROR_INT:return ANSIConstants.RED_FG;//WARN等级为黄色case Level.WARN_INT:return ANSIConstants.YELLOW_FG;//INFO等级为蓝色case Level.INFO_INT:return ANSIConstants.BLUE_FG;//DEBUG等级为绿色case Level.DEBUG_INT:return ANSIConstants.GREEN_FG;//其他为默认颜色default:return ANSIConstants.DEFAULT_FG;}}
}

3. 配置xml文件(logback-spring.xml)

<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="60 seconds" debug="false"><!--自定义颜色配置 此处converterClass引用的是日志颜色类的路径, 此匹配的是第二种控制台色彩输出方式--><conversionRule conversionWord="customcolor" converterClass="com.sanss.djyp.config.LogbackColorful"/><appender name="consoleLog" class="ch.qos.logback.core.ConsoleAppender"><encoder><pattern>%red(%d{HH:mm:ss.SSS}) %green([%thread]) %customcolor(%-5level) %customcolor(%logger) - %msg%n</pattern></encoder></appender><appender name="fileInfoLog" class="ch.qos.logback.core.rolling.RollingFileAppender"><filter class="ch.qos.logback.classic.filter.LevelFilter"><level>DEBUG</level><onMatch>DENY</onMatch><onMismatch>ACCEPT</onMismatch></filter><encoder><pattern> %date{yyyy-MM-dd HH:mm:ss.SSS} %-5level[%thread]%logger{56}.%method:%L -%msg%n</pattern></encoder><!--滚动策略--><rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"><!--路径--><fileNamePattern>logs/logbackInfo.%d.log</fileNamePattern></rollingPolicy></appender><appender name="fileErrorLog" class="ch.qos.logback.core.rolling.RollingFileAppender"><filter class="ch.qos.logback.classic.filter.ThresholdFilter"><level>DEBUG</level></filter><encoder><pattern>%date{yyyy-MM-dd HH:mm:ss.SSS} %-5level[%thread]%logger{56}.%method:%L -%msg%n</pattern></encoder><!--滚动策略--><rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"><!--路径--><fileNamePattern>logs/logbackError.%d.log</fileNamePattern></rollingPolicy></appender><root level="info"><appender-ref ref="consoleLog"/><appender-ref ref="fileInfoLog"/><appender-ref ref="fileErrorLog"/></root></configuration>

3. 配置yml(日志输出级别)

logging:level:com.example: infopattern:console: "%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n"

③:配置定时任务

1. 引入依赖

<!--   Quartz定时任务库-->
<dependency><groupId>org.quartz-scheduler</groupId><artifactId>quartz</artifactId><version>2.3.2</version> <!-- 使用适当的版本号 -->
</dependency>

2. 创建定时任务执行逻辑类

image.png

@Slf4j
@Component
public class MyJob {@Autowiredprivate LogMapper logMapper;@Scheduled (cron = "0/10 * * * * ?") // 每隔10秒执行一次public void execute() {// 获取当前时间LocalDateTime currentTime = LocalDateTime.now();// 创建日期时间格式化对象DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");// 格式化当前时间String formattedTime = currentTime.format(formatter);log.info("定时任务执行了!" + formattedTime);LogEntity logEntity = new LogEntity();Date date = new Date();int i = logMapper.add(date);if (i > 0){log.info("插入数据成功");}else {log.error("插入数据失败");}}
}

3. 开启定时任务

在启动类上添加 @EnableScheduling 注解 必要时添加 @ComponentScan 注释

@SpringBootApplication
@EnableScheduling
@ComponentScan("com.sanss.djyp.*")
public class DjypApplication {public static void main(String[] args) {SpringApplication.run(DjypApplication.class, args);}
}

④:启动项目测试

测试成功(每隔10秒都会添加一条数据)

image.png

image.png

⑤:配置stater启动器(方法一)

作用:打成jar后在引入的新的项目中会自动执行

1.引入依赖

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-autoconfigure</artifactId>
</dependency>

2. 配置类进行注册

resources文件夹下面新建一个META-INF文件,并在下面创建spring.factories文件:

image.png

org.springframework.boot.autoconfigure.EnableAutoConfiguration=com.sanss.djyp.job.MyJob

image.png

⑥:配置stater启动器(方法二)推荐

直接在启动类上添加 @Configuration 注解即可

image.png

二、 打成jar包(上传到私服中)

1.配置pom.xml插件

<!-- 上传源码 -->
<plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-source-plugin</artifactId><version>3.0.1</version><configuration><attach>true</attach></configuration><executions><execution><phase>compile</phase><goals><goal>jar</goal></goals></execution></executions>
</plugin>

2.去掉springboot打包插件(否则会报错)

在springboot打包插件中添加一行

image.png

<plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><configuration><skip>true</skip><excludes><exclude><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></exclude></excludes></configuration>
</plugin>

3.拓展(不去掉springboot打包插件)

发现依赖的jar包结构是这样的,多了BOOT-INF/classes
image.png

因此/META-INF/spring.factories这个文件里的配置就匹配不到,所以报错了
image.png

4. 指定部署目标(上传到那个私服中)

注意事项 报错:transfer failed for <http://localhost:8081/repository/maven-releases/com/sanss/djyp/0.0.1-SNAPSHOT/djyp-0.0.1-20230601.013826-1.jar>, status: 400 Repository version policy: RELEASE does not allow version: 0.0.1-20230601.013826-1

image.png

这个错误提示表明你的仓库版本策略不允许使用 -SNAPSHOT 版本的发布。默认情况下,Maven的 maven-releases 仓库版本策略是 RELEASE,它只允许发布稳定的、非快照版本。

要解决此问题,有两个可能的方法:

  1. 更新版本号:修改你的项目的版本号,移除 -SNAPSHOT 后重新构建并发布。例如,将版本号从 0.0.1-SNAPSHOT 修改为 0.0.1,然后重新执行构建和发布操作。

  2. 使用快照仓库:如果你想继续使用快照版本进行开发和测试,你可以配置一个专门用于快照版本的仓库。在你的 settings.xml 文件中,添加一个 <repository> 元素,指定一个 maven-snapshots 仓库,并配置正确的URL和认证信息。

    <repository><id>maven-snapshots</id><url>http://localhost:8081/repository/maven-snapshots/</url><snapshots><enabled>true</enabled></snapshots>
    </repository>
    

    并在你的项目中使用 maven-snapshots 仓库进行发布。

请注意,如果你选择第二种方法使用快照仓库,确保你的私有仓库正确配置了对应的 maven-snapshots 仓库,并允许使用快照版本。此外,快照版本应该仅用于开发和测试,不应该在生产环境中使用。

准备发布

image.png

image.png

<!--    指定部署目标-->
<distributionManagement><repository><id>maven-releases</id><url>http://localhost:8081/repository/maven-releases/</url></repository>
</distributionManagement>

4. 在maven的settings.xml中添加认证信息

image.png

    <server><id>maven-releases</id><!--nexus的认证id(仓库名称)--> <username>admin</username><!--nexus中的用户名密码--> <password>admin123</password> </server>

5. 运行 deploy指令 将jar包发布到私有仓库中

image.png

image.png

image.png

三、在新项目中引入jar包并自动执行

①:引入发布的jar包依赖

<dependency><groupId>com.sanss</groupId><artifactId>djyp</artifactId><version>0.0.1</version>
</dependency>

②:启动项目测试

成功

image.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/185072.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据库索引详解

目录 第一章、快速了解索引1.1&#xff09;索引是什么1.2&#xff09;为什么使用索引1.3&#xff09;快速上手创建简单索引 第二章、索引分类2.1&#xff09;按数据结构分类2.1.1&#xff09;树型数据结构的索引①二叉树②B树③B 树&#xff1a;B 树的升级版 2.1.2&#xff09;…

Unity地面交互效果——4、制作地面凹陷轨迹

大家好&#xff0c;我是阿赵。   上一篇介绍了曲面细分着色器的基本用法和思路&#xff0c;这一篇在曲面细分的基础上&#xff0c;制作地面凹陷的轨迹效果。 一、思路分析 这次需要达到的效果是这样的&#xff1a; 从效果上看&#xff0c;这个凹陷在地面下的轨迹&#xff0…

RabbitMQ 死信队列

在MQ中&#xff0c;当消息成为死信&#xff08;Dead message&#xff09;后&#xff0c;消息中间件可以将其从当前队列发送到另一个队列中&#xff0c;这个队列就是死信队列。而在RabbitMQ中&#xff0c;由于有交换机的概念&#xff0c;实际是将死信发送给了死信交换机&#xf…

【VUE+ elementUI 实现动态表头渲染】

VUE elementUI 实现动态表头渲染 1、定义 columns&#xff08;表头数据&#xff09; 和 dataList&#xff08;表格数据&#xff09; data() {return {loading: false,dataList: [{ name: 张三, sex: 男, age: 18 },{ name: 林琳, sex: 女, age: 20 },{ name: 王五, sex: 男, …

基于减法平均算法的无人机航迹规划-附代码

基于减法平均算法的无人机航迹规划 文章目录 基于减法平均算法的无人机航迹规划1.减法平均搜索算法2.无人机飞行环境建模3.无人机航迹规划建模4.实验结果4.1地图创建4.2 航迹规划 5.参考文献6.Matlab代码 摘要&#xff1a;本文主要介绍利用减法平均算法来优化无人机航迹规划。 …

SpringBoot整合Canal+RabbitMQ监听数据变更(对rabbit进行模块封装)

SpringBootCanal(监听MySQL的binlog)RabbitMQ&#xff08;处理保存变更记录&#xff09; 在SpringBoot中采用一种与业务代码解耦合的方式&#xff0c;来实现数据的变更记录&#xff0c;记录的内容是新数据&#xff0c;如果是更新操作还得有旧数据内容。 使用Canal来监听MySQL的…

open clip论文阅读摘要

看下open clip论文 Learning Transferable Visual Models From Natural Language Supervision These results suggest that the aggregate supervision accessible to modern pre-training methods within web-scale collections of text surpasses that of high-quality crowd…

基于React开发的chatgpt网页版(仿chatgpt)

在浏览github的时候发现了一个好玩的项目本项目&#xff0c;是github大神Yidadaa开发的chatgpt网页版&#xff0c;该开源项目是跨平台的&#xff0c;Web / PWA / Linux / Win / MacOS都可以访问。非常有意思&#xff0c;本人就部署了一套&#xff0c;喜欢的同学可以体验一番。 …

Python之字符串、正则表达式练习

目录 1、输出随机字符串2、货币的转换&#xff08;字符串 crr107&#xff09;3、凯撒加密&#xff08;book 实验 19&#xff09;4、字符替换5、检测字母或数字6、纠正字母7、输出英文中所有长度为3个字母的单词 1、输出随机字符串 编写程序&#xff0c;输出由英文字母大小写或…

wpf添加Halcon的窗口控件报错:下列控件已成功添加到工具箱中,但未在活动设计器中启用

报错截图如下&#xff1a; 注意一下新建工程的时候选择wpf应用而不是wpf应用程序。 添加成功的控件&#xff1a;

第一个ARM程序裸板点灯

硬件知识LED原理图 如何点亮一个LED灯&#xff1f; 看原理图&#xff0c;确定控制LED的引脚。看主芯片的芯片手册&#xff0c;确定如何设置控制这个引脚。写程序。 LED有插脚封装的、贴片封装的。 它们长得完全不一样&#xff0c;因此我们在原理图中把它们抽象出来。 点亮…

双通道 H 桥电机驱动芯片AT8833,软硬件兼容替代DRV8833,应用玩具、打印机等应用

上期小编给大家分享了单通道 H 桥电机驱动芯片&#xff0c;现在来讲一讲双通道的驱动芯片。 双通道 H 桥电机驱动芯片能通过控制电机的正反转、速度和停止等功能&#xff0c;实现对电机的精确控制。下面介绍双通道H桥电机驱动芯片的工作原理和特点。 一、工作原理 双通道 H 桥电…

基于单片机的养殖场温度控制系统设计

博主主页&#xff1a;单片机辅导设计 博主简介&#xff1a;专注单片机技术领域和毕业设计项目。 主要内容&#xff1a;毕业设计、简历模板、学习资料、技术咨询。 文章目录 主要介绍一、控制系统设计二、系统方案设计2.1 系统运行方案设计2.1.1 羊舍环境温度的确定 三、 系统仿…

【FastCAE源码阅读6】C++与Python的集成,实现相互调用

分析FastCAE代码之前先看看C与Python如何相互调用的。 一、C调用Python 先写个C调用Python的例子&#xff0c;然后再来看FastCAE集成Python就比较简单了。直接上代码&#xff1a; #include <iostream> #include "python.h"int main() {Py_Initialize();PyRu…

【C语法学习】20 - 文件访问顺序

文章目录 0 前言1 文件位置指示符2 rewind()2.1 函数原型2.2 参数2.3 返回值2.4 使用说明 3 ftell()函数3.1 函数原型3.2 参数3.3 返回值 4 fseek()4.1 函数原型4.2 参数4.3 返回值 5 示例5.1 示例15.2 示例2 0 前言 C语言文件访问分为顺序文件访问和随机文件访问。 1 文件位…

云架构师学习------腾讯云通识-存储与数据库

云架构师学习------腾讯云通识-存储与数据库 云架构师学习------腾讯云通识-存储与数据库存储基础存储服务对象存储-COS产品概述功能概览产品优势 云硬盘-CBS产品概述产品功能产品优势云硬盘类型 文件存储-CFS产品概述产品功能产品优势文件存储类型及性能规格存储类型性能与规格…

react之Component存在的2个问题

问题 只要执行setState()&#xff0c;即使不改变状态数据&#xff0c;组件也会重新render()只当前组件重新render()&#xff0c;就会自动重新render子组件 原因 Component中的shouldComponentUpdate()总是返回true 思路 只有当组件的state或props数据发生改变时才重新rend…

Qt QTableView排序

1.简介 在开发过程中&#xff0c;我们需要通过点击表头来对QTableView或QTreeView等一系列高级视图进行排序操作&#xff0c;以下是进行排序的步骤。 步骤&#xff1a; 首先创建了一个QStandardItemModel对象或者继承QAbstractTableModel类作为数据模型&#xff0c;并设置了…

工厂设备扫码使用售卖联网开发需要怎么开发开源代码?

我们将详细介绍如何使用开源代码开发一套用于工厂设备联网统计的系统。我们将详细讨论所需硬件组件的选择、开源框架和库的使用、软件开发流程以及最后的集成和部署。在这个过程中&#xff0c;我们将提供实用的操作步骤和指导&#xff0c;帮助你更容易地完成这个复杂的任务。 …

Docker实战

一、Docker安装 以下均以CentOS 7为例 1、安装Docker yum install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin 2、启动和校验 # 启动Docker systemctl start docker# 停止Docker systemctl stop docker# 重启 systemctl resta…