diff options
author | Olivier Lamy <olamy@apache.org> | 2013-12-16 22:01:19 +0000 |
---|---|---|
committer | Olivier Lamy <olamy@apache.org> | 2013-12-16 22:01:19 +0000 |
commit | 52caa0198b6f95142300daa37122d6e5dbbf9399 (patch) | |
tree | 726488c30dd91c98ed23a432b2b37b0a4cb65398 | |
parent | ef5c16fe218e6d027f79cf3626cf356a6f856471 (diff) | |
download | archiva-52caa0198b6f95142300daa37122d6e5dbbf9399.tar.gz archiva-52caa0198b6f95142300daa37122d6e5dbbf9399.zip |
better handling of FNFE
git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1551370 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r-- | archiva-modules/archiva-base/archiva-filelock/src/main/java/org/apache/archiva/common/filelock/DefaultFileLockManager.java | 210 |
1 files changed, 100 insertions, 110 deletions
diff --git a/archiva-modules/archiva-base/archiva-filelock/src/main/java/org/apache/archiva/common/filelock/DefaultFileLockManager.java b/archiva-modules/archiva-base/archiva-filelock/src/main/java/org/apache/archiva/common/filelock/DefaultFileLockManager.java index db26076b9..ba3ab2fa1 100644 --- a/archiva-modules/archiva-base/archiva-filelock/src/main/java/org/apache/archiva/common/filelock/DefaultFileLockManager.java +++ b/archiva-modules/archiva-base/archiva-filelock/src/main/java/org/apache/archiva/common/filelock/DefaultFileLockManager.java @@ -63,76 +63,65 @@ public class DefaultFileLockManager StopWatch stopWatch = new StopWatch(); boolean acquired = false; mkdirs( file.getParentFile() ); - try - { - Lock lock = null; + Lock lock = null; - stopWatch.start(); + stopWatch.start(); - while ( !acquired ) - { + while ( !acquired ) + { - if ( timeout > 0 ) + if ( timeout > 0 ) + { + long delta = stopWatch.getTime(); + log.debug( "delta {}, timeout {}", delta, timeout ); + if ( delta > timeout ) { - long delta = stopWatch.getTime(); - log.debug( "delta {}, timeout {}", delta, timeout ); - if ( delta > timeout ) - { - log.warn( "Cannot acquire read lock within {} millis. Will skip the file: {}", timeout, file ); - // we could not get the lock within the timeout period, so throw FileLockTimeoutException - throw new FileLockTimeoutException(); - } + log.warn( "Cannot acquire read lock within {} millis. Will skip the file: {}", timeout, file ); + // we could not get the lock within the timeout period, so throw FileLockTimeoutException + throw new FileLockTimeoutException(); } + } - lock = new Lock( file, false ); - - Lock current = lockFiles.get( file ); + Lock current = lockFiles.get( file ); - if ( current != null ) - { - log.debug( "read lock file exist continue wait" ); - // close RandomAccessFile!!! - RandomAccessFile raf = lock.getRandomAccessFile(); - if (raf != null) - { - raf.close(); - } - continue; - } + if ( current != null ) + { + log.debug( "read lock file exist continue wait" ); + continue; + } - try - { - createNewFileQuietly( file ); - lock.openLock( false, timeout > 0 ); - acquired = true; - } - catch ( FileNotFoundException e ) - { - // can happen if an other thread has deleted the file - log.debug( "read Lock skip: {} try to create file", e.getMessage() ); - createNewFileQuietly( file ); - } - catch ( IOException e ) - { - throw new FileLockException( e.getMessage(), e ); - } - catch ( IllegalStateException e ) - { - log.debug( "openLock {}:{}", e.getClass(), e.getMessage() ); - } + try + { + lock = new Lock( file, false ); + createNewFileQuietly( file ); + lock.openLock( false, timeout > 0 ); + acquired = true; } - Lock current = lockFiles.putIfAbsent( file, lock ); - if ( current != null ) + catch ( FileNotFoundException e ) { - lock = current; + // can happen if an other thread has deleted the file + // close RandomAccessFile!!! + closeQuietly( lock.getRandomAccessFile() ); + log.debug( "read Lock skip: {} try to create file", e.getMessage() ); + createNewFileQuietly( file ); + } + catch ( IOException e ) + { + throw new FileLockException( e.getMessage(), e ); + } + catch ( IllegalStateException e ) + { + log.debug( "openLock {}:{}", e.getClass(), e.getMessage() ); } - return lock; } - catch ( IOException e ) + Lock current = lockFiles.putIfAbsent( file, lock ); + if ( current != null ) { - throw new FileLockException( e.getMessage(), e ); + lock = current; } + return lock; + } @@ -150,85 +139,86 @@ public class DefaultFileLockManager StopWatch stopWatch = new StopWatch(); boolean acquired = false; - try - { - Lock lock = null; + Lock lock = null; - stopWatch.start(); + stopWatch.start(); - while ( !acquired ) - { + while ( !acquired ) + { - if ( timeout > 0 ) + if ( timeout > 0 ) + { + long delta = stopWatch.getTime(); + log.debug( "delta {}, timeout {}", delta, timeout ); + if ( delta > timeout ) { - long delta = stopWatch.getTime(); - log.debug( "delta {}, timeout {}", delta, timeout ); - if ( delta > timeout ) - { - log.warn( "Cannot acquire read lock within {} millis. Will skip the file: {}", timeout, file ); - // we could not get the lock within the timeout period, so throw FileLockTimeoutException - throw new FileLockTimeoutException(); - } + log.warn( "Cannot acquire read lock within {} millis. Will skip the file: {}", timeout, file ); + // we could not get the lock within the timeout period, so throw FileLockTimeoutException + throw new FileLockTimeoutException(); } + } - lock = new Lock( file, true ); + Lock current = lockFiles.get( file ); - Lock current = lockFiles.get( file ); + try + { - try + if ( current != null ) { + log.debug( "write lock file exist continue wait" ); - if ( current != null ) - { - log.debug( "write lock file exist continue wait" ); - // close RandomAccessFile!!! - RandomAccessFile raf = lock.getRandomAccessFile(); - if (raf != null) - { - raf.close(); - } - continue; - } - - createNewFileQuietly( file ); - lock.openLock( true, timeout > 0 ); - acquired = true; - } - catch ( FileNotFoundException e ) - { - // can happen if an other thread has deleted the file - log.debug( "write Lock skip: {} try to create file", e.getMessage() ); - createNewFileQuietly( file ); - } - catch ( IOException e ) - { - throw new FileLockException( e.getMessage(), e ); - } - catch ( IllegalStateException e ) - { - log.debug( "openLock {}:{}", e.getClass(), e.getMessage() ); + continue; } + lock = new Lock( file, true ); + createNewFileQuietly( file ); + lock.openLock( true, timeout > 0 ); + acquired = true; } + catch ( FileNotFoundException e ) + { + // can happen if an other thread has deleted the file + // close RandomAccessFile!!! + closeQuietly( lock.getRandomAccessFile() ); - Lock current = lockFiles.putIfAbsent( file, lock ); - if ( current != null ) + log.debug( "write Lock skip: {} try to create file", e.getMessage() ); + createNewFileQuietly( file ); + } + catch ( IOException e ) + { + throw new FileLockException( e.getMessage(), e ); + } + catch ( IllegalStateException e ) { - lock = current; + log.debug( "openLock {}:{}", e.getClass(), e.getMessage() ); } + } - return lock; + Lock current = lockFiles.putIfAbsent( file, lock ); + if ( current != null ) + { + lock = current; } - catch ( + return lock; - FileNotFoundException e - ) + } + private void closeQuietly( RandomAccessFile randomAccessFile ) + { + if ( randomAccessFile == null ) { - throw new FileLockException( e.getMessage(), e ); + return; } + try + { + randomAccessFile.close(); + } + catch ( IOException e ) + { + // ignore + } } private void createNewFileQuietly( File file ) |