Class DropAndUpdateContentIndexesUpgradeTask
- java.lang.Object
-
- com.atlassian.confluence.upgrade.AbstractUpgradeTask
-
- com.atlassian.confluence.upgrade.upgradetask.DropAndUpdateContentIndexesUpgradeTask
-
- All Implemented Interfaces:
BackupSupport,DatabaseUpgradeTask,UpgradeTask,UpgradeTaskInfo,org.springframework.beans.factory.Aware,org.springframework.beans.factory.BeanNameAware
public class DropAndUpdateContentIndexesUpgradeTask extends AbstractUpgradeTask implements DatabaseUpgradeTask
This upgrade task is to fix index rebuilding performance issues mainly caused by some low cardinality indexes. The databases (mysql5.5, oracle, postgres9.3) may choose these indexes for execution of some query sql, which will lead to extreme slowness during the long-running task. More details at https://jira.atlassian.com/browse/CONF-41010 It is also observed (specifically on oracle) that the column order of multi-column index may mislead the query optimizer as well if the low cardinality column is placed before other columns. The solution is to drop the low cardinality indexes and adjust(drop & create) column order for multi-column indexes.- Since:
- 6.0.3
-
-
Field Summary
-
Fields inherited from interface com.atlassian.confluence.upgrade.UpgradeTask
log
-
-
Constructor Summary
Constructors Constructor Description DropAndUpdateContentIndexesUpgradeTask(DdlExecutor ddlExecutor)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description booleanbreaksBackwardCompatibility()Returns true if a new export can't be imported in an older instance.voiddoUpgrade()Perform the upgrade.StringgetBuildNumber()StringgetShortDescription()A short (<50 chars) description of the upgrade actionbooleanrunOnSpaceImport()Returns true if an older Space can't be imported in a new instance without running this task.-
Methods inherited from class com.atlassian.confluence.upgrade.AbstractUpgradeTask
addAllErrors, addError, addError, getConstraint, getErrors, getName, isDatabaseUpgrade, setBeanName, setBuildNumber, validate
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface com.atlassian.confluence.upgrade.UpgradeTask
getConstraint, getErrors, validate
-
Methods inherited from interface com.atlassian.confluence.upgrade.UpgradeTaskInfo
getName, isDatabaseUpgrade
-
-
-
-
Constructor Detail
-
DropAndUpdateContentIndexesUpgradeTask
public DropAndUpdateContentIndexesUpgradeTask(DdlExecutor ddlExecutor)
-
-
Method Detail
-
getBuildNumber
public String getBuildNumber()
- Specified by:
getBuildNumberin interfaceUpgradeTaskInfo- Overrides:
getBuildNumberin classAbstractUpgradeTask- Returns:
- The build number that this upgrade is applicable to
-
getShortDescription
public String getShortDescription()
Description copied from interface:UpgradeTaskInfoA short (<50 chars) description of the upgrade action- Specified by:
getShortDescriptionin interfaceUpgradeTaskInfo- Overrides:
getShortDescriptionin classAbstractUpgradeTask
-
runOnSpaceImport
public boolean runOnSpaceImport()
Description copied from interface:BackupSupportReturns true if an older Space can't be imported in a new instance without running this task. For example:- A task updating macro names in the BodyContent table would be blocking.
- Tasks which updates data related to the space would be blocking.
- A task upgrading the user table wouldn't be blocking.
- Adding a mandatory column on space-related content breaks space import
Note that tasks don't run on space import yet, so we just reject the import in this case.
- Specified by:
runOnSpaceImportin interfaceBackupSupport
-
breaksBackwardCompatibility
public boolean breaksBackwardCompatibility()
Description copied from interface:BackupSupportReturns true if a new export can't be imported in an older instance.Breaking compatibility means a snapshot of the new version will not work at all with the previous version. For example:
- A destructive operation (Some data is replaced by another) breaks backwards compatibility
- Adding a optional column does NOT break backwards compatibility
- Data is copied to another column doesn't breaks backwards compatibility
- A build number incrementation doesn't breaks backwards compatibility
- Specified by:
breaksBackwardCompatibilityin interfaceBackupSupport
-
doUpgrade
public void doUpgrade() throws ExceptionDescription copied from interface:UpgradeTaskPerform the upgrade.- Specified by:
doUpgradein interfaceUpgradeTask- Throws:
Exception
-
-