当前位置: 首页 > news >正文

调用其他网站php页面上海城市分站seo

调用其他网站php页面,上海城市分站seo,阿里云搭载wordpress,网站建设在哪能看1.日志的作用 定位和发现问题(主要)系统监控数据采集日志审计...... 2.日志的使用 2.1 ⽇志格式的说明 2.2 打印日志 Spring集成了日志框架,直接使用即可 步骤: 1.定义日志对象 2.使⽤⽇志对象打印⽇志 RestController public class LoggerController {private static Logger…

1.日志的作用

  1. 定位和发现问题(主要)
  2. 系统监控
  3. 数据采集
  4. 日志审计......

2.日志的使用

2.1 ⽇志格式的说明

2.2 打印日志

Spring集成了日志框架,直接使用即可

步骤:

1.定义日志对象

2.使⽤⽇志对象打印⽇志

@RestController
public class LoggerController {private static Logger logger = LoggerFactory.getLogger(LoggerController.class);//(类名/类名.class)//从日志工厂拿到对象@PostConstructpublic void print(){System.out.println("打印日志");}
}

 这里要注意几点:

  •                        (Logger是 org.slf4j 包下的)

2.3 ⽇志框架介绍

SLF4J不同于其他⽇志框架, 它不是⼀个真正的⽇志实现,而是一个抽象层.

是对⽇志框架制定的⼀种规范, 标准,接⼝.

所有SLF4J并不能独⽴使⽤,需要和具体的⽇志框架配合使⽤

2.2.1 ⻔⾯模式(外观模式)

2.2.1.1 解释

SLF4J是⻔⾯模式的典型应⽤

⻔⾯模式(外观模式), 提供了⼀个统⼀的接⼝, ⽤来访问⼦系统中的⼀群接⼝. 其主要特征是定义了⼀个⾼层接⼝, 让⼦系统更容易使⽤.

这里并不关心子系统的实现,只关心SLF4J(解耦)

⽐如去医院看病,可能要去挂号, ⻔诊, 化验, 取药, 让患者或患者家属觉得很复杂, 如果有提供接待⼈员, 只让接待⼈员来处理, 就很⽅便. 

2.2.1.2 实现

场景实现:

当我们回家后, 我们会开各个屋的灯. 离开家时, 我们会关闭各个屋的灯,这就会很麻烦.

而如果家⾥设置⼀个总开关, 来控制整个屋的灯就会很⽅便.

public interface Light {void on();void off();
}public class DiningLight implements Light{@Overridepublic void on() {System.out.println("打开餐厅灯");}@Overridepublic void off() {System.out.println("关闭餐厅灯");}
}public class HallLight implements Light{@Overridepublic void on() {System.out.println("打开走廊灯");}@Overridepublic void off() {System.out.println("关闭走廊灯");}
}public class LivingLight implements Light{@Overridepublic void on() {System.out.println("打开客厅灯");}@Overridepublic void off() {System.out.println("关闭客厅灯");}
}//对这些进行封装
//门面
public class FacadePattern {public void lightOn(){HallLight hallLight = new HallLight();hallLight.on();LivingLight livingLight = new LivingLight();livingLight.on();DiningLight diningLight = new DiningLight();diningLight.on();}
}public class Main {public static void main(String[] args) {FacadePattern facadePattern = new FacadePattern();facadePattern.lightOn();}
}

2.2.1.3 优点 
  • 减少了系统的相互依赖.
  • 实现了客⼾端与⼦系统的耦合关系, 这使得⼦系统的变化不会影响到调⽤它的客⼾端.

2.2.2 SLF4J 框架介绍

SLF4J 就是其他⽇志框架的⻔⾯

SLF4J可以理解为是提供⽇志服务的统⼀API接⼝,并不涉及到具体的⽇志逻辑实现

①不引入日志门面:

常⻅的⽇志框架有log4J,logback等.如果⼀个项⽬已经使⽤了log4j,⽽你依赖的另⼀个类库,假如是ApacheActive MQ,它依赖于另外⼀个⽇志框架logback,那么你就需要把logback也加载进去.

存在问题:

1. 不同⽇志框架的API接⼝和配置⽂件不同, 如果多个⽇志框架共存, 那么不得不维护多套配置⽂件(这个配置⽂件是指⽤⼾⾃定义的配置⽂件).

2. 如果要更换⽇志框架, 应⽤程序将不得不修改代码, 并且修改过程中可能会存在⼀些代码冲突.

3. 如果引⼊的第三⽅框架, 使⽤了多套, 那就不得不维护多套配置.

SLF4J使代码独⽴于任意⼀个特定的⽇志API,这是⼀个对于开发API的开发者很好的思想.

 

②引入日志门面

引⼊⻔⾯⽇志框架之后,应⽤程序和⽇志框架(框架的具体实现)之间有了统⼀的API接⼝(⻔⾯⽇志框架实现),此时应⽤程序只需要维护⼀套⽇志⽂件配置,且当底层实现框架改变时,也不需要更改应⽤程序代码.

SLF4J 就是这个⽇志⻔⾯

 

2.4 ⽇志级别

2.4.1 ⽇志级别的分类

级别(从高到低)解释(级别越⾼, 收到的消息越少)
FATAL致命信息,表⽰需要⽴即被处理的系统级错误
ERROR错误信息, 级别较⾼的错误⽇志信息, 但仍然不影响系统的继续运⾏
WARN警告信息, 不影响使⽤, 但需要注意的问题
INFO普通信息, ⽤于记录应⽤程序正常运⾏时的⼀些信息, 例如系统启动完成、请求处理完成等
DEBUG调试信息, 需要调试时候的关键信息打印
TRACE追踪信息, ⽐DEBUG更细粒度的信息事件(除⾮有特殊⽤意,否则请使⽤DEBUG级别替代)

  

2.4.2 ⽇志级别的使⽤

@RestController
public class LoggerController {private static Logger logger = LoggerFactory.getLogger(LoggerController.class);@PostConstructpublic void print(){System.out.println("打印日志");logger.info("============我是日志框架打印的日志==============");logger.error("我是error日志");logger.warn("我是warn日志");logger.info("我是info日志");logger.debug("我是debug日志");logger.trace("我是trace日志");}
}

 可以看出,这里打印了error,warn,info,而没有打印debug和trace,

这是因为Spring默认的日志级别是info,所以只会打印⼤于等于此级别的⽇志,即info,warn,error.

2.5 ⽇志配置

2.5.1 配置⽇志级别

logging:level:root: debug

 此时就可以打印debug级别的日志了:

debug会打印较多日志,影响观察,可以对日志进行分目录打印

比如Spring的日志只打印info,项目日志打印debug级别(root表示根目录)

 

此时日志就少了:

 


日志也可以设置颜色(只能设置控制台的颜色):

2.5.2 ⽇志持久化

日志持久化就是把日志保存在文件中

2.5.2.1 配置⽇志⽂件的路径和⽂件名

 

2.5.2.2 配置⽇志⽂件的保存路径

 

 这种⽅式只能设置⽇志的路径, ⽂件名为固定的spring.log

2.5.2.3 比较总结

  • name既可以设置路径,又可以设置名称
  • path只能设置路径,默认名称是spring.log
  • 如果没有加路径,默认放在当前项目下
  • 如果两者同时存在,path就失效了,name的优先级要高于path

2.5.3 配置⽇志⽂件分割

  • 当然不是说,只要达到1KB就立即进行分割的,是以行来进行的,不是以字符.
  • 分割后的⽇志⽂件名为:⽇志名.⽇期.索引

2.5.4 配置⽇志格式(了解)

3. 更简单的⽇志输出

因为每次都使⽤ LoggerFactory.getLogger(xxx.class) 很繁琐, 并且需要每个类都添加⼀遍, 而lombok给我们提供了 ⼀种更简单的⽅式:

使⽤ @slf4j 注解输出⽇志

@Slf4j
@RestController
public class LoggerController {//private static Logger logger = LoggerFactory.getLogger(LoggerController.class);@PostConstructpublic void print(){System.out.println("打印日志");log.info("============我是日志框架打印的日志==============");log.error("我是error日志");log.warn("我是warn日志");log.info("我是info日志");log.debug("我是debug日志");log.trace("我是trace日志");}
}

http://www.hkea.cn/news/860160/

相关文章:

  • 哪里有网站建设电话查排名官网
  • 做网站需要准备的工具网络营销方案模板
  • 科技未来网站建设百度推广开户公司
  • 十度网站建设保定网站推广公司
  • php可以做视频网站有哪些软文推广渠道主要有
  • 成都网站建设桔子科技淘宝付费推广有几种方式
  • 福田的网站建设公司网络营销成功案例ppt免费
  • 网站建设英文专业术语百度推广网址
  • 做网站之前需要准备什么企业网络营销策划案
  • dreamweaver动态网站开发与设计教程内容怎么在百度上面打广告
  • 济南网站搜索优化深圳网络推广招聘
  • 网站 色彩武汉it培训机构排名前十
  • 怎么做资源网站网络培训中心
  • 服装品牌网站建设营销网站建设选择原则
  • 乌鲁木齐新市网站建设有哪些网络营销公司
  • 网站的后台怎么做企业网络规划设计方案
  • 做网站文字字号大小企业网站设计要求
  • ae有么有做gif的网站品牌推广方案范文
  • apicloud官网下载seo关键词优化排名公司
  • 上海网站制作福州百度关键字优化精灵
  • 做uml图网站百度账号快速注册入口
  • 广西梧州南京 seo 价格
  • 网站警察备案seo关键词优化平台
  • 网站开发设计实训 报告惠州网站建设
  • 网站开发的原理山西免费网站关键词优化排名
  • 石家庄网站建设全包免费推广网站2024
  • 阿里云网站备案时间无锡seo网站管理
  • 景点介绍网站模板重庆百度关键词推广
  • 做亚马逊网站费用吗曲靖新闻今日头条
  • bing 网站管理员2023今日新闻头条