org.neo4j.kernel.KernelHealth Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of neo4j-kernel Show documentation
Show all versions of neo4j-kernel Show documentation
Neo4j kernel is a lightweight, embedded Java database designed to
store data structured as graphs rather than tables. For more
information, see http://neo4j.org.
/*
* Copyright (c) 2002-2015 "Neo Technology,"
* Network Engine for Objects in Lund AB [http://neotechnology.com]
*
* This file is part of Neo4j.
*
* Neo4j is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
package org.neo4j.kernel;
import org.neo4j.graphdb.event.ErrorState;
import org.neo4j.kernel.impl.core.KernelPanicEventGenerator;
import org.neo4j.kernel.impl.util.StringLogger;
import org.neo4j.kernel.logging.Logging;
import static org.neo4j.helpers.Exceptions.withCause;
public class KernelHealth
{
private static final String panicMessage = "Kernel has encountered some problem, "
+ "please perform necessary action (tx recovery/restart)";
// Keep that cozy name for legacy purposes
private volatile boolean tmOk = true; // TODO rather skip volatile if possible here.
private final KernelPanicEventGenerator kpe;
private final StringLogger log;
private Throwable causeOfPanic;
public KernelHealth( KernelPanicEventGenerator kpe, Logging logging )
{
this.kpe = kpe;
this.log = logging.getMessagesLog( getClass() );
}
/**
* Asserts that the kernel is in good health. If that is not the case then the cause of the
* unhealthy state is wrapped in an exception of the given type, i.e. the panic disguise.
*
* @param panicDisguise the cause of the unhealthy state wrapped in an exception of this type.
* @throws EXCEPTION exception type to wrap cause in.
*/
public void assertHealthy( Class panicDisguise ) throws EXCEPTION
{
if ( !tmOk )
{
EXCEPTION exception;
try
{
try
{
exception = panicDisguise.getConstructor( String.class, Throwable.class )
.newInstance( panicMessage, causeOfPanic );
}
catch ( NoSuchMethodException e )
{
exception = withCause( panicDisguise.getConstructor( String.class )
.newInstance( panicMessage ), causeOfPanic );
}
}
catch ( Exception e )
{
throw new Error( panicMessage + ". An exception of type " + panicDisguise.getName() +
" was requested to be thrown but that proved impossible", e );
}
throw exception;
}
}
public void panic( Throwable cause )
{
if ( !tmOk )
{
return;
}
if ( cause == null )
{
throw new IllegalArgumentException( "Must provide a cause for the kernel panic" );
}
this.causeOfPanic = cause;
this.tmOk = false;
// Keeps the "setting TM not OK string for grep:ability
log.error( "setting TM not OK. " + panicMessage, cause );
kpe.generateEvent( ErrorState.TX_MANAGER_NOT_OK, causeOfPanic );
}
public boolean isHealthy()
{
return tmOk;
}
public void healed()
{
tmOk = true;
causeOfPanic = null;
log.info( "Kernel health set to OK" );
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy