Class FileChangedReloadingStrategy
java.lang.Object
org.apache.commons.configuration.reloading.FileChangedReloadingStrategy
- All Implemented Interfaces:
ReloadingStrategy
A reloading strategy that will reload the configuration every time its underlying file is changed.
This reloading strategy does not actively monitor a configuration file, but is triggered by its associated configuration whenever properties are accessed. It then checks the configuration file's last modification date and causes a reload if this has changed.
To avoid permanent disc access on successive property lookups a refresh delay can be specified. This has the effect that the configuration file's last modification date is only checked once in this delay period. The default value for this refresh delay is 5 seconds.
This strategy only works with FileConfiguration instances.
- Since:
- 1.1
- Version:
- $Id: FileChangedReloadingStrategy.java 1210646 2011-12-05 21:25:01Z oheger $
- Author:
- Emmanuel Bourg
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected FileConfigurationStores a reference to the configuration to be monitored.protected longThe last time the file was checked for changes.protected longThe last time the configuration file was modified.protected longThe minimum delay in milliseconds between checks. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected FilegetFile()Returns the file that is monitored by this strategy.longReturn the minimal time in milliseconds between two reloadings.protected booleanCheck if the configuration has changed since the last time it was loaded.voidinit()Initialize the strategy.voidNotify the strategy that the file has been reloaded.booleanTell if the evaluation of the strategy requires to reload the configuration.voidsetConfiguration(FileConfiguration configuration) Set the configuration managed by this strategy.voidsetRefreshDelay(long refreshDelay) Set the minimal time between two reloadings.protected voidUpdate the last modified time.
-
Field Details
-
configuration
Stores a reference to the configuration to be monitored. -
lastModified
The last time the configuration file was modified. -
lastChecked
The last time the file was checked for changes. -
refreshDelay
The minimum delay in milliseconds between checks.
-
-
Constructor Details
-
FileChangedReloadingStrategy
public FileChangedReloadingStrategy()
-
-
Method Details
-
setConfiguration
Description copied from interface:ReloadingStrategySet the configuration managed by this strategy.- Specified by:
setConfigurationin interfaceReloadingStrategy- Parameters:
configuration- the configuration to monitor
-
init
Description copied from interface:ReloadingStrategyInitialize the strategy.- Specified by:
initin interfaceReloadingStrategy
-
reloadingRequired
Description copied from interface:ReloadingStrategyTell if the evaluation of the strategy requires to reload the configuration.- Specified by:
reloadingRequiredin interfaceReloadingStrategy- Returns:
- a flag whether a reload should be performed
-
reloadingPerformed
Description copied from interface:ReloadingStrategyNotify the strategy that the file has been reloaded.- Specified by:
reloadingPerformedin interfaceReloadingStrategy
-
getRefreshDelay
Return the minimal time in milliseconds between two reloadings.- Returns:
- the refresh delay (in milliseconds)
-
setRefreshDelay
Set the minimal time between two reloadings.- Parameters:
refreshDelay- refresh delay in milliseconds
-
updateLastModified
Update the last modified time. -
hasChanged
Check if the configuration has changed since the last time it was loaded.- Returns:
- a flag whether the configuration has changed
-
getFile
-