org.neo4j.kernel.impl.query.QueryLoggerKernelExtension Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of neo4j-query-logging Show documentation
Show all versions of neo4j-query-logging Show documentation
Extension for logging queries to a separate query log file
/*
* Copyright (c) 2002-2018 "Neo4j,"
* Neo4j Sweden AB [http://neo4j.com]
*
* This file is part of Neo4j Enterprise Edition. The included source
* code can be redistributed and/or modified under the terms of the
* GNU AFFERO GENERAL PUBLIC LICENSE Version 3
* (http://www.fsf.org/licensing/licenses/agpl-3.0.html) with the
* Commons Clause, as found in the associated LICENSE.txt file.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* Neo4j object code can be licensed independently from the source
* under separate terms from the AGPL. Inquiries can be directed to:
* [email protected]
*
* More information is also available at:
* https://neo4j.com/licensing/
*/
package org.neo4j.kernel.impl.query;
import org.neo4j.helpers.Service;
import org.neo4j.io.fs.FileSystemAbstraction;
import org.neo4j.kernel.configuration.Config;
import org.neo4j.kernel.extension.ExtensionType;
import org.neo4j.kernel.extension.KernelExtensionFactory;
import org.neo4j.kernel.impl.logging.LogService;
import org.neo4j.kernel.impl.spi.KernelContext;
import org.neo4j.kernel.lifecycle.Lifecycle;
import org.neo4j.kernel.lifecycle.LifecycleAdapter;
import org.neo4j.kernel.monitoring.Monitors;
import org.neo4j.logging.Log;
import org.neo4j.scheduler.JobScheduler;
@Service.Implementation( KernelExtensionFactory.class )
public class QueryLoggerKernelExtension extends KernelExtensionFactory
{
public interface Dependencies
{
FileSystemAbstraction fileSystem();
Config config();
Monitors monitoring();
LogService logger();
JobScheduler jobScheduler();
}
public QueryLoggerKernelExtension()
{
super( ExtensionType.DATABASE, "query-logging" );
}
@Override
public Lifecycle newInstance( @SuppressWarnings( "unused" ) KernelContext context, final Dependencies dependencies )
{
FileSystemAbstraction fileSystem = dependencies.fileSystem();
Config config = dependencies.config();
Monitors monitoring = dependencies.monitoring();
LogService logService = dependencies.logger();
JobScheduler jobScheduler = dependencies.jobScheduler();
return new LifecycleAdapter()
{
DynamicLoggingQueryExecutionMonitor logger;
@Override
public void init()
{
Log debugLog = logService.getInternalLog( DynamicLoggingQueryExecutionMonitor.class );
this.logger = new DynamicLoggingQueryExecutionMonitor( config, fileSystem, jobScheduler, debugLog );
this.logger.init();
monitoring.addMonitorListener( this.logger );
}
@Override
public void shutdown()
{
logger.shutdown();
}
};
}
}