Java公开课-05.log4j
log4j
一,log4j简介
1.如果程序中出现异常,我们怎么解决?
01.使用异常处理机制===》异常 (但是使用原则是,能不用异常处理机制,最好不用,怎么办?)
02.通过debug调试 (必须掌握)
03.通过System.out.print();
但是:001.控制台有行数限制
002.影响我们的系统性能
003.如果我们要对用户的行为习惯进行分析
2.我们需要一个把记录用户行为和习惯的代码,记录在一个文件中!
.log(日志文件)
3.log4j:(log for Java)
01.是用java语言编写的一个日志框架
02.是Apache的一个开源项目
03.记录我们程序中的日志信息
04.可以将日志信息输出到我们指定的目的地
4.log4j的作用
01.记录代码中变量的变化,用于我们程序的调试和后期维护
02.可以周期性的保存一些数据,用于后期对数据的分析
03.通过设置日志信息的级别,来便于我们的管理
二,log4j的组成部分
1.日志的记录器(logger)
日志的输出级别
OFF 级别最高,用于关闭所有的日志输出
ALL 级别最低,用于开启所有的日志输出
Fatel 严重的错误事件,将导致我们的程序终止
Error 错误事件,不会影响我们的程序的继续执行
Warn 可能存在潜在的错误场景
Info 指的是粗粒度级别上的使用
Debug 指的是细粒度级别上的使用
Trace 比Debug还要细的
开发环境(开发阶段): 使用日志级别比较低:Debug
生产环境(项目上线): 建立把Debug细粒度的设置成Warn
2.日志的输出格式(Layout)
%p 日志信息的优先级
%d 日志信息的输出时间 %d(yyyy-MM-dd hh:mm:ss)
%C 日志信息输出的类
%l 日志信息的输出位置:类+线程+行号
%M 日志信息的输出所在方法
%m 日志信息的输出内容
%n 输出日志信息之后换行
%t 日志信息的输出所在线程
%r 从程序启动到输出日志信息所经历的时间(毫秒)
3.日志的输出目的地(Appender)
01.把我们的日志信息输出到某个地址
02.可以同时指定多个输出地
03.一个输出地对应一个Appender
将日志输出到Console控制台中=====》ConsoleAppender
将日志输出到文件中
=====》01.RollingFileAppender 根据文件大小创建新的日志文件
=====》02.DailyRollingFileAppender 根据时间创建新的日志文件
三,重点log4j的使用
1.创建Java项目
2.在项目中创建lib文件夹
3.把我们事先下载好的jar包引到我们lib中
4.右键点击 jar builder path 加入到我们项目中
5.创建测试类 书写我们的测试代码(logger)
6.创建source folder
7.在resource文件夹中创建需要的log4j.properties (log4j.properties名字固定,不能随便命名,因为底层默认找这个)
8.书写配置
01.输出到Console控制台
02.输出到文件中,根据文件大小自动创建
03.书写到文件中,根据文件时间自动创建
DailyRollingFileAppender中的DatePattern共分为6种方式
001.每月 yyyy-MM
002.每周 yyyy-ww
003.每天 yyyy-MM-dd
003.每半天 yyyy-MM-dd-a
004..每小时 yyyy-MM-dd-hh
005.每分钟 yyyy-MM-dd-hh-mm
改天我传一个完整的书写配置的代码。今天就先溜了
Java公开课-05.log4j的更多相关文章
- 学习经验分享(最近听了一节Java公开课)
最近听了一节Java公开课,讲的Tomcat8.0的,老师分享的学习方法很好, 时间和精力要用对地方 1.学习一个知识的广度和深度,先学主要的主流的,不要学了很多不该学,没必要学的东西 2.要花时间总 ...
- Java公开课-01.类和对象
一,类和对象的含义 1.类:类是具有相同属性(静态特征)和行为(功能 )的一系列事物的集合. eg:以下俩者是不是类 1)汽车 √ 2)小胖桌子上那个红色的杯子 × 2.对象:被精确限定到一个特殊 ...
- Java公开课-06.单例
一. 什么是单例模式 因程序需要,有时我们只需要某个类同时保留一个对象,不希望有更多对象,此时,我们则应考虑单例模式的设计. 二. 单例模式的特点 1. 单例模式只能有一个实例. 2. 单例类必须创建 ...
- Java公开课-04.异常
一,异常的概念 程序在运行时,发生了我们没有预测的结果,它阻止了程序按照我们预期效果执行 二,怎么保证我们的程序在发生异常以后 ,代码继续执行? 异常处理机制 在程序发生异常以后,还能按照我们事先设定 ...
- Java公开课-03.内部类
一.内部类的作用 1.实现了类的隐藏 2.实现了多重继承 3.内部类拥有外部类所拥有的属性和方法的访问权限 4.避免修改接口的时候出现同名方法 二.内部类--成员内部类 1.如果我们想访问内部类,我们 ...
- Java公开课-02.抽象类和接口
在讲述抽象类和接口之前,扯点别的:封装,继承,多态,我只做个简单的涉略 一,封装 1.体现: 将变量和方法放到一个类中 私有字段封装成共有属性 2.this: 如果发现成员变量的名称和方法参数的名称相 ...
- 【公开课】【阿里在线技术峰会】魏鹏:基于Java容器的多应用部署技术实践
对于公开课,可能目前用不上这些,但是往往能在以后想解决方案的时候帮助到我.以下是阿里对公开课的整理 摘要: 在首届阿里巴巴在线峰会上,阿里巴巴中间件技术部专家魏鹏为大家带来了题为<基于Java容 ...
- 《开源公开课分享》:Java开源框架案例分享
缺乏高端技术人才?缺乏开发标准? 代码复用性低?技术风险难于把控? 招聘成本高?培训成本高? 假设想法不够雄伟,那么就会局限于细节:假设一開始就铺很大的摊子,将会失去控制: ...
- 手把手教你用python打造网易公开课视频下载软件4-图形化界面
上一篇讲解完函数:def getdownLoadInfo (url): 传入公开课的url地址,就可以提取课程的信息,这一篇讲解一下如何编写图像化界面.大概思考一下图像化界面需要的内容: (1)一个标 ...
随机推荐
- 使用IO映射的方式获取tiny4412板子上的ID号
在以前的文章中,有一篇 基于ARM-contexA9-Linux驱动开发:如何获取板子上独有的ID号 在那篇文章中,具体可以参考.那时候我使用了简单的字符设备驱动框架,最终的ID号通过read方法可将 ...
- iOS监听模式系列之关于delegate(代理,委托)的学习
首先,大家应该都明白的是委托是协议的一种,顾名思义,就是委托他人帮自己去做什么事.也就是当自己做什么事情不方便的时候,就可以建立一个委托,这样就可以委托他人帮自己去实现什么方法. 其次,我简单的总结了 ...
- C# 操作Excel数据透视表
一.概述 数据透视表(Pivot Table)是一种交互式的表,可以进行某些计算,如求和与计数等,可动态地改变透视表版面布置,也可以重新安排行号.列标和页字段.当改变版面布置时,数据透视表也会按照新的 ...
- Demo4
<!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8&quo ...
- [总结] 二维ST表及其优化
二维 \(\mathcal{ST}\) 表,可以解决二维 \(\mathcal{RMQ}\) 问题.这里不能带修改,如果要修改,就需要二维线段树解决了. 上一道例题吧 ZOJ2859 类比一维 \(\ ...
- 面向对象,更适合JavaScript
面向对象程序设计是软件开发中一个很庞大很复杂的话题,它并不是仅仅学会类.继承.封装.多态这些面向对象编程语法元素就表示掌握的,这些语法元素只是实现面向对象程序的工具, 就像砖块.水泥能搭建小屋,也能造 ...
- Mybatis 系列7
上篇系列6中 简单地给mybatis的配置画上了一个句号.那么从本篇文章开始,将会介绍mapper映射文件的配置. 这是mybatis的核心之一 一定要学好 在mapper文件中,以mapper作为根 ...
- Mac 下实现 pyenv/virtualenv 与 Anaconda 的兼容
http://blog.csdn.net/vencent7/article/details/76849849 自己一直用的 pyenv 和 pyenv-virtualenv 管理不同的 python ...
- JS 小技巧整理
一.javascript中调用函数并不一定严格执行指定的参数个数.(函数定义时的参数个数和调时指定的参数个数并不一定要相等) function showInfo(arg1) { var defindl ...
- Nginx服务器导致CSS无法解析不起效果
最近部署一个项目html,js正常加载,css也没有报404,css能够正常获取,只是浏览器无法解析,研究了一下发现,原来是配置Nginx的时候将/etc/nginx/nginx.conf的一行inc ...