Skip to content
项目
群组
代码片段
帮助
正在加载...
登录
切换导航
X
XXL-JOB
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
靳帅
XXL-JOB
Commits
0c4491a1
提交
0c4491a1
authored
6月 08, 2016
作者:
xueli.xue
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
日志逻辑优化
上级
63edb6d8
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
77 行增加
和
35 行删除
+77
-35
XxlJobFileAppender.java
...rc/main/java/com/xxl/job/core/log/XxlJobFileAppender.java
+77
-35
没有找到文件。
xxl-job-core/src/main/java/com/xxl/job/core/log/XxlJobFileAppender.java
浏览文件 @
0c4491a1
...
...
@@ -4,9 +4,10 @@ import java.io.BufferedReader;
import
java.io.File
;
import
java.io.FileInputStream
;
import
java.io.FileOutputStream
;
import
java.io.FileReader
;
import
java.io.IOException
;
import
java.io.InputStream
;
import
java.io.InputStreamReader
;
import
java.io.LineNumberReader
;
import
java.text.SimpleDateFormat
;
import
java.util.Date
;
...
...
@@ -133,48 +134,89 @@ public class XxlJobFileAppender extends AppenderSkeleton {
String
logFileName
=
trigger_log_id
.
concat
(
".log"
);
File
logFile
=
new
File
(
filePathDateDir
,
logFileName
);
if
(!
logFile
.
exists
())
{
try
{
logFile
.
createNewFile
();
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
return
null
;
}
return
null
;
}
String
logData
=
readLines
(
logFile
);
return
logData
;
}
/**
* read log data
* @param logFile
* @return
*/
public
static
String
readLines
(
File
logFile
){
BufferedReader
reader
=
null
;
try
{
InputStream
ins
=
null
;
BufferedReader
reader
=
null
;
try
{
ins
=
new
FileInputStream
(
logFile
);
reader
=
new
BufferedReader
(
new
InputStreamReader
(
ins
,
"utf-8"
));
if
(
reader
!=
null
)
{
String
content
=
null
;
StringBuilder
sb
=
new
StringBuilder
();
while
((
content
=
reader
.
readLine
())
!=
null
)
{
sb
.
append
(
content
).
append
(
"\n"
);
}
return
sb
.
toString
();
reader
=
new
BufferedReader
(
new
InputStreamReader
(
new
FileInputStream
(
logFile
),
"utf-8"
));
if
(
reader
!=
null
)
{
StringBuilder
sb
=
new
StringBuilder
();
String
line
=
null
;
while
((
line
=
reader
.
readLine
())
!=
null
)
{
sb
.
append
(
line
).
append
(
"\n"
);
}
}
finally
{
if
(
ins
!=
null
)
{
try
{
ins
.
close
();
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
return
sb
.
toString
();
}
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
finally
{
if
(
reader
!=
null
)
{
try
{
reader
.
close
();
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
if
(
reader
!=
null
)
{
try
{
reader
.
close
();
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
}
}
return
null
;
}
/**
* read data from line num
* @param sourceFile
* @param fromLineNum
* @return
* @throws Exception
*/
public
static
String
readLinesFrom
(
File
logFile
,
int
fromLineNum
)
{
LineNumberReader
reader
=
null
;
try
{
reader
=
new
LineNumberReader
(
new
FileReader
(
logFile
));
// sBuffer
StringBuffer
sBuffer
=
new
StringBuffer
();
String
line
=
null
;
int
maxLineNum
=
0
;
while
((
line
=
reader
.
readLine
())!=
null
)
{
maxLineNum
++;
if
(
reader
.
getLineNumber
()
>=
fromLineNum
)
{
sBuffer
.
append
(
line
).
append
(
"\n"
);
}
}
}
catch
(
Exception
e
)
{
}
System
.
out
.
println
(
"maxLineNum : "
+
maxLineNum
);
return
sBuffer
.
toString
();
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
finally
{
if
(
reader
!=
null
)
{
try
{
reader
.
close
();
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
}
}
return
null
;
}
/*
// it will return the number of characters actually skipped
reader.skip(Long.MAX_VALUE);
int maxLineNum = reader.getLineNumber();
maxLineNum++; // 最大行号
*/
}
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论