opt:日志优化
This commit is contained in:
@@ -186,11 +186,6 @@
|
|||||||
</dependency>
|
</dependency>
|
||||||
<!--loki-->
|
<!--loki-->
|
||||||
<!-- https://loki4j.github.io/loki-logback-appender/#quick-start -->
|
<!-- https://loki4j.github.io/loki-logback-appender/#quick-start -->
|
||||||
<dependency>
|
|
||||||
<groupId>com.github.loki4j</groupId>
|
|
||||||
<artifactId>loki-logback-appender-jdk8</artifactId>
|
|
||||||
<version>1.3.2</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.apache.httpcomponents</groupId>
|
<groupId>org.apache.httpcomponents</groupId>
|
||||||
<artifactId>httpclient</artifactId>
|
<artifactId>httpclient</artifactId>
|
||||||
@@ -388,19 +383,13 @@
|
|||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<!-- 解析客户端操作系统、浏览器信息 -->
|
<!-- 解析客户端操作系统、浏览器信息 -->
|
||||||
<dependency>
|
|
||||||
<groupId>nl.basjes.parse.useragent</groupId>
|
|
||||||
<artifactId>yauaa</artifactId>
|
|
||||||
<version>5.23</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<dependency>
|
|
||||||
<groupId>eu.bitwalker</groupId>
|
|
||||||
<artifactId>UserAgentUtils</artifactId>
|
|
||||||
<version>1.21</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- Lucence核心包 -->
|
<!-- Lucence核心包 -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.yomahub</groupId>
|
||||||
|
<artifactId>tlog-all-spring-boot-starter</artifactId>
|
||||||
|
<version>1.5.0</version>
|
||||||
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.apache.lucene</groupId>
|
<groupId>org.apache.lucene</groupId>
|
||||||
<artifactId>lucene-core</artifactId>
|
<artifactId>lucene-core</artifactId>
|
||||||
|
|||||||
@@ -184,4 +184,6 @@ public interface AcsToWmsService {
|
|||||||
HttpResponse feedbackVehicleType(JSONObject param);
|
HttpResponse feedbackVehicleType(JSONObject param);
|
||||||
|
|
||||||
HttpResponse mark(JSONObject param);
|
HttpResponse mark(JSONObject param);
|
||||||
|
|
||||||
|
void syncDemo();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -32,6 +32,7 @@ import org.nl.modules.wql.core.bean.WQLObject;
|
|||||||
import org.slf4j.MDC;
|
import org.slf4j.MDC;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.http.HttpStatus;
|
import org.springframework.http.HttpStatus;
|
||||||
|
import org.springframework.scheduling.annotation.Async;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
@@ -1085,4 +1086,11 @@ public class AcsToWmsServiceImpl implements AcsToWmsService {
|
|||||||
MDC.remove(log_file_type);
|
MDC.remove(log_file_type);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Async
|
||||||
|
public void syncDemo() {
|
||||||
|
log.info("线程编号"+Thread.currentThread().getName());
|
||||||
|
log.error("线程编号"+Thread.currentThread().getName());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -158,4 +158,20 @@ public class TaskController {
|
|||||||
String s = acsToWmsService.applyTaskToWms(device_code, container_code, height, weight);
|
String s = acsToWmsService.applyTaskToWms(device_code, container_code, height, weight);
|
||||||
return new ResponseEntity<>(s, HttpStatus.CREATED);
|
return new ResponseEntity<>(s, HttpStatus.CREATED);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@PostMapping("/Threadid")
|
||||||
|
//@PreAuthorize("@el.check('task:add')")
|
||||||
|
public ResponseEntity<Object> Threadid() {
|
||||||
|
log.info("线程编号"+Thread.currentThread().getName());
|
||||||
|
log.error("线程编号"+Thread.currentThread().getName());
|
||||||
|
Thread thread = new Thread(() -> {
|
||||||
|
log.info("线程编号"+Thread.currentThread().getName());
|
||||||
|
log.error("线程编号"+Thread.currentThread().getName());
|
||||||
|
});
|
||||||
|
thread.start();
|
||||||
|
acsToWmsService.syncDemo();
|
||||||
|
return new ResponseEntity<>(HttpStatus.CREATED);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -21,8 +21,6 @@ import cn.hutool.json.JSONUtil;
|
|||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import net.dreamlu.mica.ip2region.core.Ip2regionSearcher;
|
import net.dreamlu.mica.ip2region.core.Ip2regionSearcher;
|
||||||
import net.dreamlu.mica.ip2region.core.IpInfo;
|
import net.dreamlu.mica.ip2region.core.IpInfo;
|
||||||
import nl.basjes.parse.useragent.UserAgent;
|
|
||||||
import nl.basjes.parse.useragent.UserAgentAnalyzer;
|
|
||||||
import org.nl.modules.common.config.ElAdminProperties;
|
import org.nl.modules.common.config.ElAdminProperties;
|
||||||
import org.nl.modules.wql.util.SpringContextHolder;
|
import org.nl.modules.wql.util.SpringContextHolder;
|
||||||
|
|
||||||
@@ -50,13 +48,6 @@ public class StringUtils {
|
|||||||
private final static Ip2regionSearcher IP_SEARCHER = SpringContextHolder.getBean(Ip2regionSearcher.class);
|
private final static Ip2regionSearcher IP_SEARCHER = SpringContextHolder.getBean(Ip2regionSearcher.class);
|
||||||
|
|
||||||
|
|
||||||
private static final UserAgentAnalyzer USER_AGENT_ANALYZER = UserAgentAnalyzer
|
|
||||||
.newBuilder()
|
|
||||||
.hideMatcherLoadStats()
|
|
||||||
.withCache(10000)
|
|
||||||
.withField(UserAgent.AGENT_NAME_VERSION)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 驼峰命名法工具
|
* 驼峰命名法工具
|
||||||
*
|
*
|
||||||
@@ -212,8 +203,7 @@ public class StringUtils {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static String getBrowser(HttpServletRequest request) {
|
public static String getBrowser(HttpServletRequest request) {
|
||||||
UserAgent.ImmutableUserAgent userAgent = USER_AGENT_ANALYZER.parse(request.getHeader("User-Agent"));
|
return "default";
|
||||||
return userAgent.get(UserAgent.AGENT_NAME_VERSION).getValue();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -75,14 +75,6 @@ public class LogAspect {
|
|||||||
*/
|
*/
|
||||||
@Around("logPointcut()")
|
@Around("logPointcut()")
|
||||||
public Object logAround(ProceedingJoinPoint joinPoint) throws Throwable {
|
public Object logAround(ProceedingJoinPoint joinPoint) throws Throwable {
|
||||||
MethodSignature signature = (MethodSignature) joinPoint.getSignature();
|
|
||||||
Method method = signature.getMethod();
|
|
||||||
// 方法路径
|
|
||||||
String methodName = joinPoint.getTarget().getClass().getName() + "." + signature.getName() + "()";
|
|
||||||
String params=getParameter(method, joinPoint.getArgs());
|
|
||||||
// log.info("请求方法:{}",methodName);
|
|
||||||
// log.info("请求方法参数:{}",params);
|
|
||||||
|
|
||||||
Object result;
|
Object result;
|
||||||
currentTime.set(System.currentTimeMillis());
|
currentTime.set(System.currentTimeMillis());
|
||||||
result = joinPoint.proceed();
|
result = joinPoint.proceed();
|
||||||
|
|||||||
@@ -35,6 +35,7 @@ import org.nl.modules.logging.service.mapstruct.LogErrorMapper;
|
|||||||
import org.nl.modules.logging.service.mapstruct.LogSmallMapper;
|
import org.nl.modules.logging.service.mapstruct.LogSmallMapper;
|
||||||
import org.springframework.data.domain.Page;
|
import org.springframework.data.domain.Page;
|
||||||
import org.springframework.data.domain.Pageable;
|
import org.springframework.data.domain.Pageable;
|
||||||
|
import org.springframework.scheduling.annotation.Async;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
import org.springframework.web.bind.annotation.RequestBody;
|
import org.springframework.web.bind.annotation.RequestBody;
|
||||||
@@ -81,13 +82,11 @@ public class LogServiceImpl implements LogService {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@Transactional(rollbackFor = Exception.class)
|
@Async
|
||||||
public void save(String username, String browser, String ip, ProceedingJoinPoint joinPoint, Log logDto) {
|
public void save(String username, String browser, String ip, ProceedingJoinPoint joinPoint, Log logDto) {
|
||||||
|
|
||||||
MethodSignature signature = (MethodSignature) joinPoint.getSignature();
|
MethodSignature signature = (MethodSignature) joinPoint.getSignature();
|
||||||
Method method = signature.getMethod();
|
Method method = signature.getMethod();
|
||||||
org.nl.modules.logging.annotation.Log aopLog = method.getAnnotation(org.nl.modules.logging.annotation.Log.class);
|
org.nl.modules.logging.annotation.Log aopLog = method.getAnnotation(org.nl.modules.logging.annotation.Log.class);
|
||||||
|
|
||||||
// 方法路径
|
// 方法路径
|
||||||
String methodName = joinPoint.getTarget().getClass().getName() + "." + signature.getName() + "()";
|
String methodName = joinPoint.getTarget().getClass().getName() + "." + signature.getName() + "()";
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,34 @@
|
|||||||
|
package org.nl.modules.lucene.common;
|
||||||
|
/**
|
||||||
|
* @author ldjun
|
||||||
|
* @version 1.0
|
||||||
|
* @date 2023年08月24日 13:00
|
||||||
|
* @desc desc
|
||||||
|
*/
|
||||||
|
|
||||||
|
import ch.qos.logback.classic.spi.ILoggingEvent;
|
||||||
|
import com.yomahub.tlog.core.context.AspectLogContext;
|
||||||
|
import com.yomahub.tlog.core.enhance.logback.async.AspectLogbackAsyncAppender;
|
||||||
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
import org.slf4j.MDC;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class AsyncLuceneAppender extends AspectLogbackAsyncAppender {
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void append(ILoggingEvent event) {
|
||||||
|
String traceId = AspectLogContext.getLogValue();
|
||||||
|
if (StringUtils.isNotEmpty(traceId)){
|
||||||
|
MDC.put("traceId",traceId);
|
||||||
|
Map<String, String> mdcPropertyMap = event.getMDCPropertyMap();
|
||||||
|
if (mdcPropertyMap.getClass().getName().contains("SynchronizedMap")){
|
||||||
|
mdcPropertyMap.put("traceId",traceId);
|
||||||
|
}
|
||||||
|
MDC.clear();
|
||||||
|
}
|
||||||
|
super.append(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -60,20 +60,17 @@ public class LuceneAppender extends AppenderBase<ILoggingEvent> {
|
|||||||
String message = event.getFormattedMessage();
|
String message = event.getFormattedMessage();
|
||||||
try {
|
try {
|
||||||
LuceneLogDto luceneLogDto = JSONObject.parseObject(message, LuceneLogDto.class);
|
LuceneLogDto luceneLogDto = JSONObject.parseObject(message, LuceneLogDto.class);
|
||||||
|
|
||||||
// LuceneLogDto luceneLogDto = new LuceneLogDto(itemDto.getOpc_server_code(), itemDto.getOpc_plc_code(), itemDto.getDevice_code(), itemDto.getItem_code().substring(itemDto.getItem_code().lastIndexOf(".") + 1),
|
|
||||||
// String.valueOf(itemDto.getHis_item_value()), String.valueOf(itemDto.getItem_value()));
|
|
||||||
// luceneLogDto.setLogType(LogTypeEnum.DEVICE_LOG.getDesc());
|
|
||||||
//IndexWriter indexWriter = LuceneIndexWriter.getIndexWriter();
|
|
||||||
//创建一个Document对象
|
|
||||||
Document document = new Document();
|
Document document = new Document();
|
||||||
try {
|
try {
|
||||||
//记录索引开始时间
|
|
||||||
long startTime = System.currentTimeMillis();
|
|
||||||
//向document对象中添加域。
|
//向document对象中添加域。
|
||||||
|
Map<String, String> mdcPropertyMap = event.getMDCPropertyMap();
|
||||||
|
String traceId = mdcPropertyMap.get("traceId");
|
||||||
|
System.out.println("---追踪号---"+traceId);
|
||||||
|
if (ObjectUtil.isNotEmpty(traceId)) {
|
||||||
|
document.add(new StringField("trace_id", traceId, Field.Store.YES));
|
||||||
|
}
|
||||||
if (ObjectUtil.isNotEmpty(luceneLogDto.getDevice_code())) {
|
if (ObjectUtil.isNotEmpty(luceneLogDto.getDevice_code())) {
|
||||||
document.add(new StringField("device_code", luceneLogDto.getDevice_code(), Field.Store.YES));
|
document.add(new StringField("device_code", luceneLogDto.getDevice_code(), Field.Store.YES));
|
||||||
// document.add(new TextField("device_code", luceneLogDto.getDevice_code(), Field.Store.YES));
|
|
||||||
}
|
}
|
||||||
if (ObjectUtil.isNotEmpty(luceneLogDto.getContent())) {
|
if (ObjectUtil.isNotEmpty(luceneLogDto.getContent())) {
|
||||||
document.add(new StringField("fieldContent", luceneLogDto.getContent(), Field.Store.YES));
|
document.add(new StringField("fieldContent", luceneLogDto.getContent(), Field.Store.YES));
|
||||||
@@ -93,9 +90,6 @@ public class LuceneAppender extends AppenderBase<ILoggingEvent> {
|
|||||||
document.add(new StringField("logType", luceneLogDto.getLogType(), Field.Store.YES));
|
document.add(new StringField("logType", luceneLogDto.getLogType(), Field.Store.YES));
|
||||||
document.add(new StringField("logTime", DateUtil.format(new DateTime(), "yyyy-MM-dd HH:mm:ss.SSS"), Field.Store.YES));
|
document.add(new StringField("logTime", DateUtil.format(new DateTime(), "yyyy-MM-dd HH:mm:ss.SSS"), Field.Store.YES));
|
||||||
document.add(new NumericDocValuesField("logTime",System.currentTimeMillis()));//排序
|
document.add(new NumericDocValuesField("logTime",System.currentTimeMillis()));//排序
|
||||||
//记录索引结束时间
|
|
||||||
long endTime = System.currentTimeMillis();
|
|
||||||
// log.info("建立索引共耗时{}毫秒", endTime - startTime);
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
indexWriter.addDocument(document);
|
indexWriter.addDocument(document);
|
||||||
|
|||||||
@@ -1,65 +0,0 @@
|
|||||||
package org.nl.modules.lucene.common;
|
|
||||||
|
|
||||||
import cn.hutool.core.date.DateUtil;
|
|
||||||
import org.apache.lucene.index.CorruptIndexException;
|
|
||||||
import org.apache.lucene.index.IndexWriter;
|
|
||||||
import org.apache.lucene.index.IndexWriterConfig;
|
|
||||||
import org.apache.lucene.store.Directory;
|
|
||||||
import org.apache.lucene.store.FSDirectory;
|
|
||||||
import org.nl.modules.lucene.config.UrlConfig;
|
|
||||||
import org.wltea.analyzer.lucene.IKAnalyzer;
|
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.text.ParseException;
|
|
||||||
import java.text.SimpleDateFormat;
|
|
||||||
import java.util.Date;
|
|
||||||
|
|
||||||
public class LuceneIndexWriter {
|
|
||||||
// private static IndexWriter indexWriter;
|
|
||||||
//
|
|
||||||
// static {
|
|
||||||
// try {
|
|
||||||
// Directory directory = FSDirectory.open(new File(UrlConfig.luceneUrl).toPath());
|
|
||||||
// IndexWriterConfig config = new IndexWriterConfig(new IKAnalyzer());
|
|
||||||
// indexWriter = new IndexWriter(directory, config);
|
|
||||||
// } catch (Exception e) {
|
|
||||||
// e.printStackTrace();
|
|
||||||
// }
|
|
||||||
// /**当当前线程结束时,自动关闭IndexWriter,使用Runtime对象*/
|
|
||||||
// Runtime.getRuntime().addShutdownHook(new Thread(){
|
|
||||||
// @Override
|
|
||||||
// public void run() {
|
|
||||||
// try {
|
|
||||||
// closeIndexWriter();
|
|
||||||
// } catch (Exception e) {
|
|
||||||
// e.printStackTrace();
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// });
|
|
||||||
// }
|
|
||||||
// /**在线程结束时,自动关闭IndexWriter*/
|
|
||||||
// public static IndexWriter getIndexWriter() {
|
|
||||||
// return indexWriter;
|
|
||||||
// }
|
|
||||||
// /**关闭IndexWriter
|
|
||||||
// * @throws IOException
|
|
||||||
// * @throws CorruptIndexException */
|
|
||||||
// public static void closeIndexWriter() throws Exception {
|
|
||||||
// if(indexWriter != null) {
|
|
||||||
// indexWriter.close();
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// public static void main(String[] args) throws IOException {
|
|
||||||
// indexWriter.deleteAll();
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
public static String getDate(String timeString) throws ParseException {
|
|
||||||
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSX");//时间格式
|
|
||||||
Date date = sdf.parse(timeString);
|
|
||||||
timeString = DateUtil.format(date, "yyyy-MM-dd HH:mm:ss.SSS");//格式化后的时间
|
|
||||||
return timeString;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -18,10 +18,9 @@ import org.apache.lucene.util.BytesRef;
|
|||||||
import org.wltea.analyzer.lucene.IKAnalyzer;
|
import org.wltea.analyzer.lucene.IKAnalyzer;
|
||||||
|
|
||||||
import java.nio.file.Paths;
|
import java.nio.file.Paths;
|
||||||
import java.util.ArrayList;
|
import java.text.ParseException;
|
||||||
import java.util.Calendar;
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.List;
|
import java.util.*;
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* lucene查询器
|
* lucene查询器
|
||||||
@@ -33,41 +32,27 @@ public class Searcher {
|
|||||||
//获取要查询的路径,也就是索引所在的位置
|
//获取要查询的路径,也就是索引所在的位置
|
||||||
Directory dir = FSDirectory.open(Paths.get(indexDir));
|
Directory dir = FSDirectory.open(Paths.get(indexDir));
|
||||||
IndexReader reader = DirectoryReader.open(dir);
|
IndexReader reader = DirectoryReader.open(dir);
|
||||||
//构建IndexSearcher
|
|
||||||
IndexSearcher searcher = new IndexSearcher(reader);
|
IndexSearcher searcher = new IndexSearcher(reader);
|
||||||
//标准分词器,会自动去掉空格啊,is a the等单词
|
|
||||||
Analyzer analyzer = new IKAnalyzer(true);
|
|
||||||
// Analyzer analyzer = new StandardAnalyzer();
|
|
||||||
// Analyzer analyzer = new IKAnalyzer(false);
|
|
||||||
//查询解析器
|
|
||||||
// QueryParser queryParser = new QueryParser("fieldContent", analyzer);
|
|
||||||
|
|
||||||
//记录索引开始时间
|
|
||||||
long startTime = System.currentTimeMillis();
|
|
||||||
// 实际上Lucene本身不支持分页。因此我们需要自己进行逻辑分页。我们要准备分页参数:
|
// 实际上Lucene本身不支持分页。因此我们需要自己进行逻辑分页。我们要准备分页参数:
|
||||||
int pageSize = Integer.parseInt(whereJson.get("size").toString());// 每页条数
|
int pageSize = Integer.parseInt(whereJson.get("size").toString());// 每页条数
|
||||||
int pageNum = Integer.parseInt(whereJson.get("page").toString());// 当前页码
|
int pageNum = Integer.parseInt(whereJson.get("page").toString());// 当前页码
|
||||||
int start = pageNum * pageSize;// 当前页的起始条数
|
|
||||||
int end = start + pageSize;// 当前页的结束条数(不能包含)
|
|
||||||
// 创建排序对象,需要排序字段SortField,参数:字段的名称、字段的类型、是否反转如果是false,升序。true降序
|
|
||||||
Sort sort = new Sort(new SortField("logTime", SortField.Type.LONG,true));
|
|
||||||
|
|
||||||
TopDocs docs = null;
|
|
||||||
BooleanQuery.Builder booleanQueryBuilder = new BooleanQuery.Builder();
|
BooleanQuery.Builder booleanQueryBuilder = new BooleanQuery.Builder();
|
||||||
//时间范围查询
|
//时间范围查询
|
||||||
String startDate = (String) whereJson.get("begin_time");
|
String startDate = (String) whereJson.get("begin_time");
|
||||||
String endDate = (String) whereJson.get("end_time");
|
String endDate = (String) whereJson.get("end_time");
|
||||||
|
|
||||||
|
if (startDate == null){
|
||||||
Calendar calendar=Calendar.getInstance();
|
Calendar calendar=Calendar.getInstance();
|
||||||
calendar.set(1970, 0, 1);
|
calendar.set(1970, 0, 1);
|
||||||
if (startDate == null){
|
|
||||||
startDate = DateUtil.format(calendar.getTime(),"yyyy-MM-dd HH:mm:ss.SSS");
|
startDate = DateUtil.format(calendar.getTime(),"yyyy-MM-dd HH:mm:ss.SSS");
|
||||||
}else{
|
}else{
|
||||||
startDate = LuceneIndexWriter.getDate(startDate);
|
startDate = getDate(startDate);
|
||||||
}
|
}
|
||||||
if (endDate == null){
|
if (endDate == null){
|
||||||
endDate = DateUtil.format(new DateTime(),"yyyy-MM-dd HH:mm:ss.SSS");
|
endDate = DateUtil.format(new DateTime(),"yyyy-MM-dd HH:mm:ss.SSS");
|
||||||
} else {
|
} else {
|
||||||
endDate = LuceneIndexWriter.getDate(endDate);
|
endDate = getDate(endDate);
|
||||||
}
|
}
|
||||||
TermRangeQuery termRangeQuery = new TermRangeQuery("logTime", new BytesRef(startDate), new BytesRef(endDate), true, true);
|
TermRangeQuery termRangeQuery = new TermRangeQuery("logTime", new BytesRef(startDate), new BytesRef(endDate), true, true);
|
||||||
booleanQueryBuilder.add(termRangeQuery,BooleanClause.Occur.MUST);
|
booleanQueryBuilder.add(termRangeQuery,BooleanClause.Occur.MUST);
|
||||||
@@ -95,18 +80,15 @@ public class Searcher {
|
|||||||
WildcardQuery query = new WildcardQuery(new Term("fieldContent", "*"+(String) whereJson.get("blurry")+"*"));
|
WildcardQuery query = new WildcardQuery(new Term("fieldContent", "*"+(String) whereJson.get("blurry")+"*"));
|
||||||
booleanQueryBuilder.add(query, BooleanClause.Occur.MUST);
|
booleanQueryBuilder.add(query, BooleanClause.Occur.MUST);
|
||||||
}
|
}
|
||||||
docs = searcher.search(booleanQueryBuilder.build(), end,sort);
|
|
||||||
//记录索引时间
|
|
||||||
long endTime = System.currentTimeMillis();
|
|
||||||
log.info("匹配{}共耗时{}毫秒",booleanQueryBuilder.build(),(endTime-startTime));
|
|
||||||
log.info("查询到{}条日志文件", docs.totalHits.value);
|
|
||||||
List<String> list = new ArrayList<>();
|
|
||||||
ScoreDoc[] scoreDocs = docs.scoreDocs;
|
|
||||||
if (end > docs.totalHits.value) end = (int) docs.totalHits.value;
|
|
||||||
JSONArray array = new JSONArray();
|
|
||||||
|
|
||||||
for (int i = start; i < end; i++) {
|
TopFieldCollector collector = TopFieldCollector.create(new Sort(new SortField("logTime", SortField.Type.LONG,true)), 20000, 0);
|
||||||
ScoreDoc scoreDoc = scoreDocs[i];
|
searcher.search(booleanQueryBuilder.build(), collector);
|
||||||
|
TopDocs topDocs = collector.topDocs(pageNum*pageSize, pageSize);
|
||||||
|
int totalSize = collector.getTotalHits();
|
||||||
|
ScoreDoc[] scoreDocs = topDocs.scoreDocs;
|
||||||
|
|
||||||
|
List<JSONObject> list = new ArrayList<>();
|
||||||
|
for (ScoreDoc scoreDoc : scoreDocs) {
|
||||||
Document doc = reader.document(scoreDoc.doc);
|
Document doc = reader.document(scoreDoc.doc);
|
||||||
JSONObject object = new JSONObject();
|
JSONObject object = new JSONObject();
|
||||||
object.put("content",doc.get("fieldContent"));
|
object.put("content",doc.get("fieldContent"));
|
||||||
@@ -117,28 +99,21 @@ public class Searcher {
|
|||||||
object.put("requestparam",doc.get("requestparam"));
|
object.put("requestparam",doc.get("requestparam"));
|
||||||
object.put("responseparam",doc.get("responseparam"));
|
object.put("responseparam",doc.get("responseparam"));
|
||||||
if(doc.get("fieldContent") != null) {
|
if(doc.get("fieldContent") != null) {
|
||||||
array.add(object);
|
list.add(object);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for(Object logDto:array){
|
|
||||||
log.info(logDto.toString());
|
|
||||||
}
|
|
||||||
reader.close();
|
reader.close();
|
||||||
|
dir.close();
|
||||||
JSONObject jo = new JSONObject();
|
JSONObject jo = new JSONObject();
|
||||||
jo.put("content", array);
|
jo.put("content", list);
|
||||||
jo.put("totalElements", docs.totalHits.value);
|
jo.put("totalElements", totalSize);
|
||||||
return jo;
|
return jo;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void main(String[] args) {
|
public static String getDate(String timeString) throws ParseException {
|
||||||
String indexDir = "D:\\lucene\\index";
|
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSSX");//时间格式
|
||||||
//查询这个字符串
|
Date date = sdf.parse(timeString);
|
||||||
String q = "07.832";
|
timeString = DateUtil.format(date, "yyyy-MM-dd HH:mm:ss.SSS");//格式化后的时间
|
||||||
Map whereJson = null;
|
return timeString;
|
||||||
try {
|
|
||||||
search(indexDir, q,whereJson);
|
|
||||||
} catch (Exception e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -7,20 +7,12 @@ import com.alibaba.fastjson.JSON;
|
|||||||
import lombok.RequiredArgsConstructor;
|
import lombok.RequiredArgsConstructor;
|
||||||
import lombok.SneakyThrows;
|
import lombok.SneakyThrows;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import org.apache.lucene.document.Document;
|
|
||||||
import org.apache.lucene.document.Field;
|
|
||||||
import org.apache.lucene.document.StringField;
|
|
||||||
import org.apache.lucene.document.TextField;
|
|
||||||
import org.apache.lucene.index.IndexWriter;
|
|
||||||
import org.nl.modules.lucene.common.LuceneIndexWriter;
|
|
||||||
import org.nl.modules.lucene.enums.LogTypeEnum;
|
import org.nl.modules.lucene.enums.LogTypeEnum;
|
||||||
import org.nl.modules.lucene.service.LuceneExecuteLogService;
|
import org.nl.modules.lucene.service.LuceneExecuteLogService;
|
||||||
import org.nl.modules.lucene.service.dto.LuceneLogDto;
|
import org.nl.modules.lucene.service.dto.LuceneLogDto;
|
||||||
import org.slf4j.MDC;
|
import org.slf4j.MDC;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author jlm
|
* @author jlm
|
||||||
* @description 服务实现
|
* @description 服务实现
|
||||||
@@ -45,50 +37,9 @@ public class LuceneExecuteLogServiceImpl implements LuceneExecuteLogService {
|
|||||||
@Override
|
@Override
|
||||||
public void interfaceExecuteLog(LuceneLogDto luceneLogDto) {
|
public void interfaceExecuteLog(LuceneLogDto luceneLogDto) {
|
||||||
luceneLogDto.setLogType(LogTypeEnum.INTERFACE_LOG.getDesc());
|
luceneLogDto.setLogType(LogTypeEnum.INTERFACE_LOG.getDesc());
|
||||||
// addIndex(luceneLogDto);
|
|
||||||
log.info("{}", JSON.toJSONString(luceneLogDto));
|
log.info("{}", JSON.toJSONString(luceneLogDto));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addIndex(LuceneLogDto luceneLogDto) {
|
|
||||||
// IndexWriter indexWriter = LuceneIndexWriter.getIndexWriter();
|
|
||||||
// //创建一个Document对象
|
|
||||||
// Document document = new Document();
|
|
||||||
// try {
|
|
||||||
// //记录索引开始时间
|
|
||||||
// long startTime = System.currentTimeMillis();
|
|
||||||
// //向document对象中添加域。
|
|
||||||
// if (ObjectUtil.isNotEmpty(luceneLogDto.getDevice_code())) {
|
|
||||||
// document.add(new StringField("device_code", luceneLogDto.getDevice_code(), Field.Store.YES));
|
|
||||||
//// document.add(new TextField("device_code", luceneLogDto.getDevice_code(), Field.Store.YES));
|
|
||||||
// }
|
|
||||||
// if (ObjectUtil.isNotEmpty(luceneLogDto.getContent())) {
|
|
||||||
// document.add(new StringField("fieldContent", luceneLogDto.getContent(), Field.Store.YES));
|
|
||||||
// }
|
|
||||||
// if (ObjectUtil.isNotEmpty(luceneLogDto.getMethod())) {
|
|
||||||
// document.add(new StringField("method", luceneLogDto.getMethod(), Field.Store.YES));
|
|
||||||
// }
|
|
||||||
// if (ObjectUtil.isNotEmpty(luceneLogDto.getStatus_code())) {
|
|
||||||
// document.add(new StringField("status_code", luceneLogDto.getStatus_code(), Field.Store.YES));
|
|
||||||
// }
|
|
||||||
// if (ObjectUtil.isNotEmpty(luceneLogDto.getRequestparam())) {
|
|
||||||
// document.add(new StringField("requestparam", luceneLogDto.getRequestparam(), Field.Store.YES));
|
|
||||||
// }
|
|
||||||
// if (ObjectUtil.isNotEmpty(luceneLogDto.getResponseparam())) {
|
|
||||||
// document.add(new StringField("responseparam", luceneLogDto.getResponseparam(), Field.Store.YES));
|
|
||||||
// }
|
|
||||||
// document.add(new StringField("logType", luceneLogDto.getLogType(), Field.Store.YES));
|
|
||||||
// document.add(new StringField("logTime", DateUtil.format(new DateTime(), "yyyy-MM-dd HH:mm:ss.SSS"), Field.Store.YES));
|
|
||||||
// indexWriter.addDocument(document);
|
|
||||||
// //记录索引结束时间
|
|
||||||
// long endTime = System.currentTimeMillis();
|
|
||||||
// log.info("建立索引共耗时{}毫秒", endTime - startTime);
|
|
||||||
// indexWriter.commit();
|
|
||||||
// MDC.put("DEVICECODE", luceneLogDto.getDevice_code());
|
|
||||||
// } catch (Exception e) {
|
|
||||||
// log.error(e.getMessage(), e);
|
|
||||||
// }
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void extLog(String name, String message) {
|
public void extLog(String name, String message) {
|
||||||
try {
|
try {
|
||||||
|
|||||||
@@ -10,7 +10,7 @@
|
|||||||
<!--日志文件保留天数-->
|
<!--日志文件保留天数-->
|
||||||
<maxHistory>15</maxHistory>
|
<maxHistory>15</maxHistory>
|
||||||
<!--单个日志最大容量 至少10MB才能看得出来-->
|
<!--单个日志最大容量 至少10MB才能看得出来-->
|
||||||
<maxFileSize>200MB</maxFileSize>
|
<maxFileSize>100MB</maxFileSize>
|
||||||
<!--所有日志最多占多大容量-->
|
<!--所有日志最多占多大容量-->
|
||||||
<totalSizeCap>2GB</totalSizeCap>
|
<totalSizeCap>2GB</totalSizeCap>
|
||||||
</rollingPolicy>
|
</rollingPolicy>
|
||||||
@@ -19,15 +19,14 @@
|
|||||||
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
|
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
|
||||||
<charset>${log.charset}</charset>
|
<charset>${log.charset}</charset>
|
||||||
</encoder>
|
</encoder>
|
||||||
|
|
||||||
</appender>
|
</appender>
|
||||||
|
|
||||||
<!-- <logger name="org.nl.start.Init" level="info" additivity="false">
|
<appender name="asyncFileAppender" class="ch.qos.logback.classic.AsyncAppender">
|
||||||
<appender-ref ref="FILE3"/>
|
<appender-ref ref="AcsToWms" />
|
||||||
</logger>-->
|
<!-- 设置队列大小,根据您的需求调整 -->
|
||||||
|
<queueSize>512</queueSize>
|
||||||
<!-- 打印sql -->
|
</appender>
|
||||||
<logger name="org.nl.acs.ext.wms.service.impl.AcsToWmsServiceImpl" level="info" additivity="false">
|
<logger name="org.nl.acs.ext.wms.service.impl.AcsToWmsServiceImpl" level="info" additivity="true">
|
||||||
<appender-ref ref="AcsToWms"/>
|
<appender-ref ref="asyncFileAppender"/>
|
||||||
</logger>
|
</logger>
|
||||||
</included>
|
</included>
|
||||||
|
|||||||
@@ -10,7 +10,7 @@
|
|||||||
<!--日志文件保留天数-->
|
<!--日志文件保留天数-->
|
||||||
<maxHistory>15</maxHistory>
|
<maxHistory>15</maxHistory>
|
||||||
<!--单个日志最大容量 至少10MB才能看得出来-->
|
<!--单个日志最大容量 至少10MB才能看得出来-->
|
||||||
<maxFileSize>200MB</maxFileSize>
|
<maxFileSize>100MB</maxFileSize>
|
||||||
<!--所有日志最多占多大容量-->
|
<!--所有日志最多占多大容量-->
|
||||||
<totalSizeCap>2GB</totalSizeCap>
|
<totalSizeCap>2GB</totalSizeCap>
|
||||||
</rollingPolicy>
|
</rollingPolicy>
|
||||||
@@ -21,13 +21,12 @@
|
|||||||
</encoder>
|
</encoder>
|
||||||
|
|
||||||
</appender>
|
</appender>
|
||||||
|
<appender name="asyncFileAppender" class="ch.qos.logback.classic.AsyncAppender">
|
||||||
<!-- <logger name="org.nl.start.Init" level="info" additivity="false">
|
<appender-ref ref="AgvNdcOneDeviceDriver" />
|
||||||
<appender-ref ref="FILE3"/>
|
<!-- 设置队列大小,根据您的需求调整 -->
|
||||||
</logger>-->
|
<queueSize>512</queueSize>
|
||||||
|
</appender>
|
||||||
<!-- 打印sql -->
|
<logger name="org.nl.acs.device_driver.basedriver.agv.ndcone.AgvNdcOneDeviceDrive" level="info" additivity="true">
|
||||||
<logger name="org.nl.acs.device_driver.basedriver.agv.ndcone.AgvNdcOneDeviceDriver" level="info" additivity="false">
|
<appender-ref ref="asyncFileAppender"/>
|
||||||
<appender-ref ref="AgvNdcOneDeviceDriver"/>
|
|
||||||
</logger>
|
</logger>
|
||||||
</included>
|
</included>
|
||||||
|
|||||||
@@ -10,7 +10,7 @@
|
|||||||
<!--日志文件保留天数-->
|
<!--日志文件保留天数-->
|
||||||
<maxHistory>15</maxHistory>
|
<maxHistory>15</maxHistory>
|
||||||
<!--单个日志最大容量 至少10MB才能看得出来-->
|
<!--单个日志最大容量 至少10MB才能看得出来-->
|
||||||
<maxFileSize>200MB</maxFileSize>
|
<maxFileSize>100MB</maxFileSize>
|
||||||
<!--所有日志最多占多大容量-->
|
<!--所有日志最多占多大容量-->
|
||||||
<totalSizeCap>2GB</totalSizeCap>
|
<totalSizeCap>2GB</totalSizeCap>
|
||||||
</rollingPolicy>
|
</rollingPolicy>
|
||||||
@@ -21,13 +21,12 @@
|
|||||||
</encoder>
|
</encoder>
|
||||||
|
|
||||||
</appender>
|
</appender>
|
||||||
|
<appender name="asyncFileAppender" class="ch.qos.logback.classic.AsyncAppender">
|
||||||
<!-- <logger name="org.nl.start.Init" level="info" additivity="false">
|
<appender-ref ref="AutoCreateInst" />
|
||||||
<appender-ref ref="FILE3"/>
|
<!-- 设置队列大小,根据您的需求调整 -->
|
||||||
</logger>-->
|
<queueSize>512</queueSize>
|
||||||
|
</appender>
|
||||||
<!-- 打印sql -->
|
<logger name="org.nl.modules.quartz.task.AutoCreateInst" level="info" additivity="true">
|
||||||
<logger name="org.nl.modules.quartz.task.AutoCreateInst" level="info" additivity="false">
|
<appender-ref ref="asyncFileAppender"/>
|
||||||
<appender-ref ref="AutoCreateInst"/>
|
|
||||||
</logger>
|
</logger>
|
||||||
</included>
|
</included>
|
||||||
|
|||||||
@@ -10,7 +10,7 @@
|
|||||||
<!--日志文件保留天数-->
|
<!--日志文件保留天数-->
|
||||||
<maxHistory>15</maxHistory>
|
<maxHistory>15</maxHistory>
|
||||||
<!--单个日志最大容量 至少10MB才能看得出来-->
|
<!--单个日志最大容量 至少10MB才能看得出来-->
|
||||||
<maxFileSize>200MB</maxFileSize>
|
<maxFileSize>100MB</maxFileSize>
|
||||||
<!--所有日志最多占多大容量-->
|
<!--所有日志最多占多大容量-->
|
||||||
<totalSizeCap>2GB</totalSizeCap>
|
<totalSizeCap>2GB</totalSizeCap>
|
||||||
</rollingPolicy>
|
</rollingPolicy>
|
||||||
@@ -21,13 +21,12 @@
|
|||||||
</encoder>
|
</encoder>
|
||||||
|
|
||||||
</appender>
|
</appender>
|
||||||
|
<appender name="asyncFileAppender" class="ch.qos.logback.classic.AsyncAppender">
|
||||||
<!-- <logger name="org.nl.start.Init" level="info" additivity="false">
|
<appender-ref ref="LnshRGVDeviceDriver" />
|
||||||
<appender-ref ref="FILE3"/>
|
<!-- 设置队列大小,根据您的需求调整 -->
|
||||||
</logger>-->
|
<queueSize>512</queueSize>
|
||||||
|
</appender>
|
||||||
<!-- 打印sql -->
|
<logger name="org.nl.acs.device_driver.lnsh.lnsh_rgv.LnshRGVDeviceDriver" level="info" additivity="true">
|
||||||
<logger name="org.nl.acs.device_driver.lnsh.lnsh_rgv.LnshRGVDeviceDriver" level="info" additivity="false">
|
<appender-ref ref="asyncFileAppender"/>
|
||||||
<appender-ref ref="LnshRGVDeviceDriver"/>
|
|
||||||
</logger>
|
</logger>
|
||||||
</included>
|
</included>
|
||||||
|
|||||||
@@ -1,41 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<included>
|
|
||||||
<springProperty scope="context" name="logPath" source="logging.file.path" defaultValue="logs"/>
|
|
||||||
<property name="LOG_HOME" value="${logPath}"/>
|
|
||||||
<define name="DEVICECODE" class="org.nl.modules.logging.DeviceCodeDir"/>
|
|
||||||
<!-- 按照每天生成日志文件 -->
|
|
||||||
<appender name="FILE_LUCENE" class="ch.qos.logback.core.rolling.RollingFileAppender">
|
|
||||||
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
|
|
||||||
<!--日志文件输出的文件名-->
|
|
||||||
<FileNamePattern>${LOG_HOME}/lucene/${DEVICECODE}/%d{yyyy-MM-dd}.%i.log</FileNamePattern>
|
|
||||||
<!--日志文件保留天数-->
|
|
||||||
<maxHistory>15</maxHistory>
|
|
||||||
<!--单个日志最大容量 至少10MB才能看得出来-->
|
|
||||||
<maxFileSize>200MB</maxFileSize>
|
|
||||||
<!--所有日志最多占多大容量-->
|
|
||||||
<totalSizeCap>2GB</totalSizeCap>
|
|
||||||
</rollingPolicy>
|
|
||||||
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
|
|
||||||
<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
|
|
||||||
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
|
|
||||||
<charset>${log.charset}</charset>
|
|
||||||
</encoder>
|
|
||||||
|
|
||||||
</appender>
|
|
||||||
|
|
||||||
<appender name="luceneAppender" class="org.nl.modules.lucene.common.LuceneAppender" />
|
|
||||||
<appender name="asyncLuceneAppender" class="ch.qos.logback.classic.AsyncAppender">
|
|
||||||
<appender-ref ref="luceneAppender" />
|
|
||||||
<!-- 设置队列大小,根据您的需求调整 -->
|
|
||||||
<queueSize>512</queueSize>
|
|
||||||
</appender>
|
|
||||||
<!-- <logger name="org.nl.start.Init" level="info" additivity="false">
|
|
||||||
<appender-ref ref="FILE3"/>
|
|
||||||
</logger>-->
|
|
||||||
|
|
||||||
<!-- 打印sql -->
|
|
||||||
<logger name="org.nl.modules.lucene.service.impl.LuceneExecuteLogServiceImpl" level="info" additivity="true">
|
|
||||||
<appender-ref ref="FILE_LUCENE"/>
|
|
||||||
<appender-ref ref="asyncLuceneAppender"/>
|
|
||||||
</logger>
|
|
||||||
</included>
|
|
||||||
@@ -10,7 +10,7 @@
|
|||||||
<!--日志文件保留天数-->
|
<!--日志文件保留天数-->
|
||||||
<maxHistory>15</maxHistory>
|
<maxHistory>15</maxHistory>
|
||||||
<!--单个日志最大容量 至少10MB才能看得出来-->
|
<!--单个日志最大容量 至少10MB才能看得出来-->
|
||||||
<maxFileSize>200MB</maxFileSize>
|
<maxFileSize>100MB</maxFileSize>
|
||||||
<!--所有日志最多占多大容量-->
|
<!--所有日志最多占多大容量-->
|
||||||
<totalSizeCap>2GB</totalSizeCap>
|
<totalSizeCap>2GB</totalSizeCap>
|
||||||
</rollingPolicy>
|
</rollingPolicy>
|
||||||
@@ -22,12 +22,12 @@
|
|||||||
|
|
||||||
</appender>
|
</appender>
|
||||||
|
|
||||||
<!-- <logger name="org.nl.start.Init" level="info" additivity="false">
|
<appender name="asyncFileAppender" class="ch.qos.logback.classic.AsyncAppender">
|
||||||
<appender-ref ref="FILE3"/>
|
<appender-ref ref="NDCAgvServiceImpl" />
|
||||||
</logger>-->
|
<!-- 设置队列大小,根据您的需求调整 -->
|
||||||
|
<queueSize>512</queueSize>
|
||||||
<!-- 打印sql -->
|
</appender>
|
||||||
<logger name="org.nl.acs.agv.server.impl.NDCAgvServiceImpl" level="info" additivity="false">
|
<logger name="org.nl.acs.agv.server.impl.NDCAgvServiceImpl" level="info" additivity="true">
|
||||||
<appender-ref ref="NDCAgvServiceImpl"/>
|
<appender-ref ref="asyncFileAppender"/>
|
||||||
</logger>
|
</logger>
|
||||||
</included>
|
</included>
|
||||||
|
|||||||
@@ -10,7 +10,7 @@
|
|||||||
<!--日志文件保留天数-->
|
<!--日志文件保留天数-->
|
||||||
<maxHistory>15</maxHistory>
|
<maxHistory>15</maxHistory>
|
||||||
<!--单个日志最大容量 至少10MB才能看得出来-->
|
<!--单个日志最大容量 至少10MB才能看得出来-->
|
||||||
<maxFileSize>200MB</maxFileSize>
|
<maxFileSize>100MB</maxFileSize>
|
||||||
<!--所有日志最多占多大容量-->
|
<!--所有日志最多占多大容量-->
|
||||||
<totalSizeCap>2GB</totalSizeCap>
|
<totalSizeCap>2GB</totalSizeCap>
|
||||||
</rollingPolicy>
|
</rollingPolicy>
|
||||||
@@ -21,13 +21,12 @@
|
|||||||
</encoder>
|
</encoder>
|
||||||
|
|
||||||
</appender>
|
</appender>
|
||||||
|
<appender name="asyncFileAppender" class="ch.qos.logback.classic.AsyncAppender">
|
||||||
<!-- <logger name="org.nl.start.Init" level="info" additivity="false">
|
<appender-ref ref="NDCSocketConnectionAutoRun" />
|
||||||
<appender-ref ref="FILE3"/>
|
<!-- 设置队列大小,根据您的需求调整 -->
|
||||||
</logger>-->
|
<queueSize>512</queueSize>
|
||||||
|
</appender>
|
||||||
<!-- 打印sql -->
|
<logger name="org.nl.start.auto.run.NDCSocketConnectionAutoRun" level="info" additivity="true">
|
||||||
<logger name="org.nl.start.auto.run.NDCSocketConnectionAutoRun" level="info" additivity="false">
|
<appender-ref ref="asyncFileAppender"/>
|
||||||
<appender-ref ref="NDCSocketConnectionAutoRun"/>
|
|
||||||
</logger>
|
</logger>
|
||||||
</included>
|
</included>
|
||||||
|
|||||||
@@ -10,7 +10,7 @@
|
|||||||
<!--日志文件保留天数-->
|
<!--日志文件保留天数-->
|
||||||
<maxHistory>15</maxHistory>
|
<maxHistory>15</maxHistory>
|
||||||
<!--单个日志最大容量 至少10MB才能看得出来-->
|
<!--单个日志最大容量 至少10MB才能看得出来-->
|
||||||
<maxFileSize>200MB</maxFileSize>
|
<maxFileSize>100MB</maxFileSize>
|
||||||
<!--所有日志最多占多大容量-->
|
<!--所有日志最多占多大容量-->
|
||||||
<totalSizeCap>2GB</totalSizeCap>
|
<totalSizeCap>2GB</totalSizeCap>
|
||||||
</rollingPolicy>
|
</rollingPolicy>
|
||||||
@@ -21,13 +21,12 @@
|
|||||||
</encoder>
|
</encoder>
|
||||||
|
|
||||||
</appender>
|
</appender>
|
||||||
|
<appender name="asyncFileAppender" class="ch.qos.logback.classic.AsyncAppender">
|
||||||
<!-- <logger name="org.nl.start.Init" level="info" additivity="false">
|
<appender-ref ref="WmsToAcs" />
|
||||||
<appender-ref ref="FILE3"/>
|
<!-- 设置队列大小,根据您的需求调整 -->
|
||||||
</logger>-->
|
<queueSize>512</queueSize>
|
||||||
|
</appender>
|
||||||
<!-- 打印sql -->
|
<logger name="org.nl.acs.ext.wms.service.impl.WmsToAcsServiceImpl" level="info" additivity="true">
|
||||||
<logger name="org.nl.acs.ext.wms.service.impl.WmsToAcsServiceImpl" level="info" additivity="false">
|
<appender-ref ref="asyncFileAppender"/>
|
||||||
<appender-ref ref="WmsToAcs"/>
|
|
||||||
</logger>
|
</logger>
|
||||||
</included>
|
</included>
|
||||||
|
|||||||
@@ -25,7 +25,6 @@ https://juejin.cn/post/6844903775631572999
|
|||||||
<include resource="log/AcsToWms.xml"/>
|
<include resource="log/AcsToWms.xml"/>
|
||||||
<include resource="log/WmsToAcs.xml"/>
|
<include resource="log/WmsToAcs.xml"/>
|
||||||
<include resource="log/NDCSocketConnectionAutoRun.xml"/>
|
<include resource="log/NDCSocketConnectionAutoRun.xml"/>
|
||||||
<include resource="log/Lucene.xml"/>
|
|
||||||
<include resource="log/AgvNdcOneDeviceDriver.xml"/>
|
<include resource="log/AgvNdcOneDeviceDriver.xml"/>
|
||||||
<include resource="log/NDCAgvServiceImpl.xml"/>
|
<include resource="log/NDCAgvServiceImpl.xml"/>
|
||||||
<include resource="log/LnshRGVDeviceDriver.xml"/>
|
<include resource="log/LnshRGVDeviceDriver.xml"/>
|
||||||
@@ -45,7 +44,7 @@ https://juejin.cn/post/6844903775631572999
|
|||||||
<!--日志文件保留天数-->
|
<!--日志文件保留天数-->
|
||||||
<maxHistory>15</maxHistory>
|
<maxHistory>15</maxHistory>
|
||||||
<!--单个日志最大容量 至少10MB才能看得出来-->
|
<!--单个日志最大容量 至少10MB才能看得出来-->
|
||||||
<maxFileSize>200MB</maxFileSize>
|
<maxFileSize>100MB</maxFileSize>
|
||||||
<!--所有日志最多占多大容量-->
|
<!--所有日志最多占多大容量-->
|
||||||
<totalSizeCap>20GB</totalSizeCap>
|
<totalSizeCap>20GB</totalSizeCap>
|
||||||
</rollingPolicy>
|
</rollingPolicy>
|
||||||
@@ -63,72 +62,19 @@ https://juejin.cn/post/6844903775631572999
|
|||||||
</appender>
|
</appender>
|
||||||
|
|
||||||
<appender name="luceneAppender" class="org.nl.modules.lucene.common.LuceneAppender" />
|
<appender name="luceneAppender" class="org.nl.modules.lucene.common.LuceneAppender" />
|
||||||
<appender name="asyncLuceneAppender" class="ch.qos.logback.classic.AsyncAppender">
|
<appender name="asyncLuceneAppender" class="org.nl.modules.lucene.common.AsyncLuceneAppender">
|
||||||
<appender-ref ref="luceneAppender" />
|
<appender-ref ref="luceneAppender" />
|
||||||
<!-- 设置队列大小,根据您的需求调整 -->
|
<!-- 设置队列大小,根据您的需求调整 -->
|
||||||
<queueSize>512</queueSize>
|
<queueSize>512</queueSize>
|
||||||
</appender>
|
</appender>
|
||||||
|
|
||||||
<!--添加loki-->
|
<!--添加loki-->
|
||||||
<appender name="lokiAppender" class="com.github.loki4j.logback.Loki4jAppender">
|
|
||||||
<batchTimeoutMs>1000</batchTimeoutMs>
|
|
||||||
<http class="com.github.loki4j.logback.ApacheHttpSender">
|
|
||||||
<url>${LOKI_URL}/push</url>
|
|
||||||
</http>
|
|
||||||
<format>
|
|
||||||
<label>
|
|
||||||
<pattern>system=${SYSTEM_NAME},level=%level,logType=%X{log_file_type:-logType},device=%X{device_code_log:-device}</pattern>
|
|
||||||
</label>
|
|
||||||
<message>
|
|
||||||
<pattern>${log.pattern}</pattern>
|
|
||||||
</message>
|
|
||||||
<sortByTime>true</sortByTime>
|
|
||||||
</format>
|
|
||||||
</appender>
|
|
||||||
|
|
||||||
|
|
||||||
<!--开发环境:打印控制台-->
|
<!--开发环境:打印控制台-->
|
||||||
<springProfile name="dev">
|
<springProfile name="dev">
|
||||||
<root level="info">
|
<root level="info">
|
||||||
<appender-ref ref="CONSOLE"/>
|
|
||||||
<appender-ref ref="lokiAppender"/>
|
|
||||||
<appender-ref ref="asyncFileAppender"/>
|
|
||||||
<appender-ref ref="asyncLuceneAppender"/>
|
<appender-ref ref="asyncLuceneAppender"/>
|
||||||
|
<appender-ref ref="CONSOLE"/>
|
||||||
</root>
|
</root>
|
||||||
<!--logmanage -->
|
|
||||||
<logger name="org.nl.acs.log.service.impl.DeviceExecuteLogServiceImpl" level="info" additivity="false">
|
|
||||||
<appender-ref ref="lokiAppender" />
|
|
||||||
<appender-ref ref="asyncLuceneAppender"/>
|
|
||||||
</logger>
|
|
||||||
<logger name="jdbc.resultsettable" level="ERROR" additivity="false">
|
|
||||||
<appender-ref ref="CONSOLE"/>
|
|
||||||
<appender-ref ref="lokiAppender" />
|
|
||||||
</logger>
|
|
||||||
<logger name="org.openscada.opc.lib.da.Server" level="ERROR" additivity="false">
|
|
||||||
<appender-ref ref="CONSOLE"/>
|
|
||||||
<appender-ref ref="lokiAppender" />
|
|
||||||
</logger>
|
|
||||||
<!--logmanage -->
|
|
||||||
|
|
||||||
|
|
||||||
<logger name="jdbc.audit" level="ERROR" additivity="false">
|
|
||||||
<appender-ref ref="CONSOLE"/>
|
|
||||||
</logger>
|
|
||||||
<logger name="jdbc.resultset" level="ERROR" additivity="false">
|
|
||||||
<appender-ref ref="CONSOLE"/>
|
|
||||||
</logger>
|
|
||||||
<logger name="springfox.documentation" level="ERROR" additivity="false">
|
|
||||||
<appender-ref ref="CONSOLE"/>
|
|
||||||
</logger>
|
|
||||||
<logger name="jdbc.sqlonly" level="ERROR" additivity="false">
|
|
||||||
<appender-ref ref="CONSOLE"/>
|
|
||||||
</logger>
|
|
||||||
<logger name="jdbc.sqltiming" level="ERROR" additivity="false">
|
|
||||||
<appender-ref ref="CONSOLE"/>
|
|
||||||
</logger>
|
|
||||||
<logger name="org.jinterop" level="ERROR" additivity="false">
|
|
||||||
<appender-ref ref="CONSOLE"/>
|
|
||||||
</logger>
|
|
||||||
</springProfile>
|
</springProfile>
|
||||||
<!--测试环境:打印控制台-->
|
<!--测试环境:打印控制台-->
|
||||||
<springProfile name="test">
|
<springProfile name="test">
|
||||||
@@ -138,54 +84,14 @@ https://juejin.cn/post/6844903775631572999
|
|||||||
</logger>
|
</logger>
|
||||||
<root level="info">
|
<root level="info">
|
||||||
<appender-ref ref="CONSOLE"/>
|
<appender-ref ref="CONSOLE"/>
|
||||||
<appender-ref ref="lokiAppender" />
|
|
||||||
</root>
|
</root>
|
||||||
</springProfile>
|
</springProfile>
|
||||||
|
|
||||||
<!--生产环境:打印控制台和输出到文件-->
|
<!--生产环境:打印控制台和输出到文件-->
|
||||||
<springProfile name="prod">
|
<springProfile name="prod">
|
||||||
<root level="info">
|
<root level="info">
|
||||||
<appender-ref ref="asyncFileAppender"/>
|
|
||||||
<appender-ref ref="lokiAppender" />
|
|
||||||
<appender-ref ref="asyncLuceneAppender"/>
|
<appender-ref ref="asyncLuceneAppender"/>
|
||||||
|
<appender-ref ref="asyncFileAppender"/>
|
||||||
</root>
|
</root>
|
||||||
<logger name="org.nl.acs.log.service.impl.DeviceExecuteLogServiceImpl" level="info" additivity="false">
|
|
||||||
<appender-ref ref="asyncFileAppender"/>
|
|
||||||
<appender-ref ref="lokiAppender" />
|
|
||||||
<appender-ref ref="asyncLuceneAppender"/>
|
|
||||||
</logger>
|
|
||||||
<logger name="jdbc.resultsettable" level="ERROR" additivity="false">
|
|
||||||
<appender-ref ref="asyncFileAppender"/>
|
|
||||||
<appender-ref ref="lokiAppender" />
|
|
||||||
</logger>
|
|
||||||
<logger name="org.openscada.opc.lib.da.Server" level="ERROR" additivity="false">
|
|
||||||
<appender-ref ref="asyncFileAppender"/>
|
|
||||||
<appender-ref ref="lokiAppender" />
|
|
||||||
</logger>
|
|
||||||
|
|
||||||
<logger name="jdbc.audit" level="ERROR" additivity="false">
|
|
||||||
<appender-ref ref="asyncFileAppender"/>
|
|
||||||
<appender-ref ref="lokiAppender" />
|
|
||||||
</logger>
|
|
||||||
<logger name="jdbc.resultset" level="ERROR" additivity="false">
|
|
||||||
<appender-ref ref="asyncFileAppender"/>
|
|
||||||
<appender-ref ref="lokiAppender" />
|
|
||||||
</logger>
|
|
||||||
<logger name="springfox.documentation" level="ERROR" additivity="false">
|
|
||||||
<appender-ref ref="asyncFileAppender"/>
|
|
||||||
<appender-ref ref="lokiAppender" />
|
|
||||||
</logger>
|
|
||||||
<logger name="jdbc.sqlonly" level="ERROR" additivity="false">
|
|
||||||
<appender-ref ref="asyncFileAppender"/>
|
|
||||||
<appender-ref ref="lokiAppender" />
|
|
||||||
</logger>
|
|
||||||
<logger name="jdbc.sqltiming" level="ERROR" additivity="false">
|
|
||||||
<appender-ref ref="asyncFileAppender"/>
|
|
||||||
<appender-ref ref="lokiAppender" />
|
|
||||||
</logger>
|
|
||||||
<logger name="org.jinterop" level="ERROR" additivity="false">
|
|
||||||
<appender-ref ref="asyncFileAppender"/>
|
|
||||||
<appender-ref ref="lokiAppender" />
|
|
||||||
</logger>
|
|
||||||
</springProfile>
|
</springProfile>
|
||||||
</configuration>
|
</configuration>
|
||||||
|
|||||||
Reference in New Issue
Block a user