All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.rdf4j.federated.monitoring.QueryLog Maven / Gradle / Ivy

There is a newer version: 5.1.0
Show newest version
/*******************************************************************************
 * Copyright (c) 2019 Eclipse RDF4J contributors.
 *
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Distribution License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 *******************************************************************************/
package org.eclipse.rdf4j.federated.monitoring;

import java.util.concurrent.atomic.AtomicBoolean;

import org.eclipse.rdf4j.federated.FedXConfig;
import org.eclipse.rdf4j.federated.structures.QueryInfo;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * Convenience class which writes the query backlog a logger with the name "QueryLog". The logger is configured using
 * the available logging framework.
 * 

* Requires monitoring to be enabled: *

* *
    *
  • {@link FedXConfig#isEnableMonitoring()}
  • *
  • {@link FedXConfig#isLogQueries()}
  • *
* * @author Andreas Schwarte * */ public class QueryLog { private static final Logger log = LoggerFactory.getLogger(QueryLog.class); private final AtomicBoolean active = new AtomicBoolean(false); private Logger queryLog; public QueryLog() { log.info("Initializing logging of queries"); initQueryLog(); } private void initQueryLog() { queryLog = LoggerFactory.getLogger("QueryLog"); // activate the given logger active.set(true); } public void logQuery(QueryInfo query) { if (active.get()) { queryLog.info(query.getQuery().replace("\r\n", " ").replace("\n", " ")); } if (log.isTraceEnabled()) { log.trace("#Query: " + query.getQuery()); } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy