org.neo4j.kernel.guard.Guard Maven / Gradle / Ivy
/**
* Copyright (c) 2002-2013 "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.guard;
import static java.lang.System.currentTimeMillis;
import org.neo4j.kernel.impl.util.StringLogger;
public class Guard
{
private final ThreadLocal threadLocal = new ThreadLocal();
private final StringLogger logger;
public Guard( final StringLogger logger )
{
this.logger = logger;
}
public void check()
{
GuardInternal guardInternal = currentGuard();
if ( guardInternal != null )
{
guardInternal.check();
}
}
public T currentGuard()
{
return (T) threadLocal.get();
}
public void startOperationsCount( final long maxOps )
{
start( new OperationsCount( maxOps ) );
}
public void startTimeout( final long validFor )
{
final Timeout timeout = new Timeout( validFor + currentTimeMillis() );
start( timeout );
}
public void start( final GuardInternal guard )
{
threadLocal.set( guard );
}
public T stop()
{
T guardInternal = Guard.this.currentGuard();
if ( guardInternal != null )
{
threadLocal.remove();
}
return guardInternal;
}
public interface GuardInternal
{
void check();
}
public class OperationsCount implements GuardInternal
{
private final long max;
private long opsCount = 0;
private OperationsCount( final long max )
{
this.max = max;
}
@Override
public void check()
{
opsCount++;
if ( max < opsCount )
{
logger.logMessage( "guard-timeout: node-ops: more than " + max );
throw new GuardOperationsCountException( opsCount );
}
}
public long getOpsCount()
{
return opsCount;
}
}
public class Timeout implements GuardInternal
{
private final long valid;
private final long start;
private Timeout( final long valid )
{
this.valid = valid;
this.start = currentTimeMillis();
}
@Override
public void check()
{
if ( valid < currentTimeMillis() )
{
final long overtime = currentTimeMillis() - valid;
logger.logMessage( "guard-timeout:" + (valid - start) + "(+" + overtime + ")ms" );
throw new GuardTimeoutException( overtime );
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy