4-9 logback & 定时任务

本文介绍了SpringBoot中Logback的日志配置,包括日志级别设置、输出路径、文件名及格式。同时展示了如何在application.yml中配置Mybatis打印SQL日志。此外,还给出了一个使用示例,展示了一个简单的定时任务,通过@Scheduled注解实现每隔5秒执行一次任务。

logback

简介

  • logback是springboot自带的日志服务,不需要单独导入依赖。

具体代码

application.yml 配置
#logback日志
#日志可以分割,按时间分割、按文件大小分割
logging:
  # 日志输出级别,从低到高为TRACE < DEBUG < INFO < WARN < ERROR < FATAL,默认是INFO级别
  level:
    com.st.controller.StaffController: INFO
    com.st.service.impl.StaffService: DEBUG
  # 日志文件输出路径
  path: E:\workspace-idel\log
  # 日志文件名
  file: E:\workspace-idel\log\bootDemo.log
  # 日志输出匹配格式
  pattern:
    console: "%d - %msg%n"
  • 打印sql日志
# mybatis映射文件
mybatis:
  # mapper.xml文件地址
  mapper-locations: classpath:mybatis/*Mapper.xml
  # 扫描持久化类,将类名作为包路径的别名,用于mapper.xml
  # 比如:com.st.model.Staff 该路径的别名就是 Staff
  type-aliases-package: com.st.model
  # 打印sql日志
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
使用示例
package com.st.controller;

import com.st.service.IStaffService;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
@RequestMapping("staff")
public class StaffController {
    private Logger logger = LoggerFactory.getLogger(StaffController.class);

    @RequestMapping("home")
    public String toHome(){
        logger.info("---info:跳转到主页---");
        return "home";
    }
}

定时任务

  • 使用示例
package com.st.job;

import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.scheduling.annotation.Scheduled;

import java.util.Date;

/*
定时任务-演示类
 */
@Configuration    //1. 主要用于标记配置类,兼备@Component的效果。
@EnableScheduling //2. 开启定时任务
public class MyJob {
    /*
    Cron表达式参数分别表示:* * * * * *
    秒(0~59) 例如0/5表示每5秒
    分(0~59)
    时(0~23)
    日(0~31)的某天,需计算
    月(0~11)
    周几( 可填1-7 或 SUN/MON/TUE/WED/THU/FRI/SAT)

    示例:
    12 * * * * *   每一分钟的第12秒执行 11 12
    0/5 * * * * *  从0秒开始的,每5秒执行一次 11 15
    * /5 从任务启动开始,每5秒执行一次  11 16

    0 0 0/1 * * * 从0点开始,每隔一个小时执行一次
    0 0 13 * * * 每一天的下午1点执行
    0 0 6 1 * *  每个月的1号的早上6点执行
     */
    @Scheduled(cron = "0/5 * * * * ?")
    public void task(){
        System.out.println(new Date());
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值