Tasks
As an administrator, you may schedule and execute maintenance tasks to automate repository management. Users with the nexus-tasks
privilege may access this configuration.
View Tasks
The tasks table shows the following columns:
Name
A user-defined name for the task to identify it in the user interface and log files.
Type
The list of available task types is documented in more detail below.
Status
Displays when a task is disabled, waiting for its next run, running, or the progress of the current run.
Schedule
Displays when the task is configured to run.
Next run
The date and time of the next execution are based on the schedule.
Last run and Last result
The result of the last execution.
Configure Tasks
Add new tasks by selecting Create task or edit the existing tasks. Custom fields are displayed for the task depending on the task type.
When creating or updating a scheduled task, configure the following default properties:
Task enabled
Enable or disable the task.
Notification Email
Configure a notification email for the task execution.
Notification Condition
Notifications may be sent on Failure or on either Success or Failure.
Task frequency
Configure the schedule for the task executions.
Manual, Once, Hourly, Daily, Weekly, Monthly, and Advanced
Advanced (provide a CRON expression) follows the UNIX-style CRON syntax
The characters are not case-sensitive. "LW" may be combined for the "last weekday of the month". [seconds] [minutes] [hours] [day-of-month] [month] [day-of-week] [year] * - any value; * in the minute field triggers every minute ? - allowed for the day-of-month and day-of-week fields for no specific value - - to specify a range such as 10-12 for every hour in the range , - to specify one than one value such as [MON,WED,FRI] in the day-of-week / - specify a start value and increment such as "0/15" for every 15 seconds L - short-hand for the last value in a named range; common in the last day of the week or month W - for a specific weekday of the month adjusted for the nearest weekday # - specify "the nth" named day of the month; "6#3" for the third Friday(6) of the month EXAMPLES 0 0 12 * * ? || 12pm (noon) 0 15 10 ? * * || 10:15am 0 * 14 * * ? || Every minute between 2-3pm 0 0/5 14 * * ? || Every 5 minutes between 2-3pm 0 0/5 14,18 * * ? || Every 5 minutes between 2-3pm and 6-7pm 0 0-5 14 * * ? || Every minute starting at 2pm and ending at 2:05pm, every day 0 10,44 14 ? 3 WED || 2:10pm and at 2:44pm every Wednesday in the month of March 0 15 10 ? * MON-FRI || 10:15am every Monday through Friday 0 15 10 15 * ? || 10:15am on the 15th day of the month 0 15 10 L * ? || 10:15am on the last day of the month 0 15 10 ? * 6L || 10:15am on the last Friday of every month 0 15 10 ? * 6#3 || 10:15am on the third Friday of the month
Task Logs
The output of every task run go to a separate log file that is configured to be removed after 30 days. These task logs are stored in the following task directory:
$data-dir/log/tasks
The file name of each task log is the task type followed by the date and time the task started. For example:
repository-maven.purge-unused-snapshots-20170618153235.log
The output of the task goes to the nexus.log
and the specific task log. Some tasks only go to the nexus.log
.
For long-running tasks, progress such as the number of items is logged to the nexus.log
every 10 minutes.
Types of Tasks
Tasks are prefixed to fall into the following category types:
Admin
Tasks that include regular maintenance such as backing up the database and cleaning up artifacts through cleanup policies. These tasks are often scheduled to run regularly.
Formats
Format-specific tasks are typically to repair metadata and indexes. Some tasks are used for format-specific cleanup tasks which are scheduled regularly.
Repair
Tasks with the "
Repair
" prefix are only intended to be run manually when encountering specific issues with your system.Only run these tasks at the advice of a Sonatype staff member.
Repository
These tasks provide specific functionality such as import/export but include replication and some management tasks. These tasks may be scheduled depending on your use case. Here are some outliers:
Admin - Change repository blob store Admin - Remove a member from a blob store group Admin - Log database table record counts
Statistics
These tasks are for updating useful metrics available in the Repository user interface.
Task Name / ID | Scheduled | Description |
---|---|---|
Admin - Backup H2 Databaseh2.backup.task | Yes | Performs a full backup of the underlying config, security, and component databases when using the embedded H2 database. The task adds a timestamp to the backup files in the backup data location. Choose a location for the backup data for this task. Schedule the task to run as required by your maintenance policy. This task does not back up the contents of the blob stores, only the database. |
Admin - Export databases for backupdb.backup | Yes | Performs a backup of the internal legacy OrientDB database and its underlying config, security, and component databases. Choose a safe location for the backed-up data. The task adds a timestamp to the backup files in the backup data location. This task does not back up the repository content and temporarily puts the repository into a read-only state |
Admin - Cleanup repositories using their associated policiesrepository.cleanup | Yes | Deletes components based on your cleanup policies. The task is automatically created on server restart and is scheduled to run daily at 1 am server time. You may disable or reschedule the task. See Cleanup Policies for more information. |
Admin - Cleanup Tagstags.cleanup | Yes | Remove tags and associated components based on your maintenance criteria. See Tagging for details. |
Admin - Cleanup unused asset blobsassetBlob.cleanup | Yes | This task soft-deletes unused blobs to prevent Nexus Repository from accidentally creating multiple blobs associated with the same asset. Nexus Repository creates one copy of the task for each format to run every 30 minutes. Use the delay minute/hour property to configure the interval before an asset is soft-deleted. This delay avoids soft-delete files that take a significant amount of time to upload to the repository. nexus.assetBlobCleanupTask.blobCreatedDelayHour=1 nexus.assetBlobCleanupTask.blobCreatedDelayMinute=60 Before version 3.62.0, this task deletes asset records from the related table regardless of the blob created time. This task requires an H2 or PostgreSQL database. |
Admin - Compact blob storeblobstore.compact | Yes | When components are deleted they are labeled as soft deleted. This task permanently removed soft-deleted files to recover storage space. This task does not apply to some object stores, which use their managed lifecycles. See Cleanup Policies for more information. |
Admin - Delete orphaned API keyssecurity.purge-api-keys | Yes | This task deletes unused API keys generated when using user tokens. Keys are orphaned when the user account is deleted. |
Admin - Log database table record countscluster.periodicLogging | Yes | This task logs clustered database record counts for each node. The task is automatically added when clustering is enabled and can be disabled by including an additional property in the nexus.properties file: nexus.log.cluster.enabled=false |
Admin - Change repository blob storerepository.move | Use to change which blob store a repository stores it's components. This task requires H2 or PostgreSQL database. See Change repository blob store for more details. | |
Admin - Delete blobstore temporary filesblobstore.delete-temp-files | Deletes the temporary files a the blob store's temp directory. Only file blob stores are processed. | |
Admin - Execute scriptscript | Privously in Nexus Repository, scripts written in Groovy could executed in the tasks menu. These scripts used the APIs to perform maintenance and other modifications. To reduce security risk, as of version 3.21.2 this task is disabled. See the documentation for the Script API. | |
Admin - Export SQL database to scriptdatabase.export.script.h2.task | This task only exists in release 3.69.0 and is only necessary for deployments already using an H2 database. See Upgrade H2 for details. | |
Admin - Remove a member from a blob store groupblobstore.group.memberRemoval | This task removes a blob store from a group. Each blob within the removed store is written back to the group and then deleted from the removed blob store. | |
Automatic Malware Managementmalware-remediator | Yes | Requires Repository Firewall This task identifies the malware reported in the malware risk banner found in your proxy repositories. For smaller deployments, selecting all repositories when running the task is recommended. For large deployments, consider setting up individual instances of the tasks for your largest proxy repositories. Run the task no more than once every 24 hours. |
Apt - Rebuild Apt metadatarepository.apt.rebuild.metadata | This task rebuilds the metadata for a chosen Apt-hosted repository. | |
Docker - Delete incomplete uploadsrepository.docker.upload-purge | Yes | This task cleans up orphaned files that may exist in temporary storage as a result of a restart or incomplete/interrupted uploads. The Age in Hours parameter allows you to configure the minimum age of incomplete uploads to be deleted. |
Docker - Delete unused manifests and imagesrepository.docker.gc | Yes | This task will handle the deletion of content that is no longer referenced, images that are no longer referenced by a tagged manifest, and V1 layers that are no longer referenced by a tagged layer. |
Helm - Rebuild Helm metadatarepository.helm.rebuild.metadata | Rebuilds the metadata for a chosen Helm-hosted repository. | |
Maven - Delete SNAPSHOTrepository.maven.remove-snapshots | Yes | Deletes SNAPSHOT components from a Maven repository based on a configured number of SNAPSHOTs, age, and release version. See Maven SNAPSHOT Tasks for information. |
Maven - Delete unused SNAPSHOTrepository.maven.purge-unused-snapshots | Yes | This task has been replaced with the Cleanup Policies feature. Deletes SNAPSHOT components from a Maven repository based on the number of days it has been since the component was last requested. See Maven SNAPSHOT Tasks for information. |
Maven - Publish Maven Indexer filesrepository.maven.publish-dotindex | The task publishes the indexer files for all or a specific Maven repository. | |
Maven - Unpublish Maven Indexer filesrepository.maven.unpublish-dotindex | This task is the counterpart to the task Maven - Publish Maven Indexer files and can remove the indexer files. | |
Repair - Rebuild Maven repository metadata (maven-metadata.xml)repository.maven.rebuild-metadata | Rebuilds The | |
PyPI - Delete index Asset MD5 Metadatarepository.pypi.rebuild-metadata | Deletes index assets with MD5 checksums on their links from PyPI repositories. Only removes the index and not the checksum. | |
PyPI - Delete legacy proxy assetsrepository.pypi.delete-legacy-proxy-assets | This task deletes old assets that were previously duplicated due to a code-path change. | |
PyPI - Generate Missing SHA256 Checksumsrepository.pypi.generate-missing-sha256-checksums | Generate sha256 checksums when missing from PyPI metadata. | |
Repair - Rebuild repository browsecreate.browse.nodes | Rebuild the tree browsing data from the database. | |
Repair - Rebuild repository searchrepository.rebuild-index | With support for hosted and proxy repositories, this task rebuilds the search index. It inspects actual components and assets found in the selected repository and thus reflects the true content for supporting search and browse actions. Canceling this task results in a partially rebuilt search index. | |
Repair - Recalculate blob store storageblobstore.metrics.reconcile | This is a slow-running task used to fix incorrect blob storage sizes that should be used with care. See recalculated blob storage performance testing for details. | |
Repair - Reconcile component database from blob storeblobstore.rebuildComponentDB | Do not use this task during normal operation of the server. Use this task to recover lost component metadata from a blob store when restoring content from backup and the database and blob storage are out of sync. See the topic Reconcile Component Database task below. | |
Repair - Reconcile date metadata from blob storerebuild.asset.uploadMetadata | Do not run this task except when Nexus Repository version 3.2.1 OR earlier was used and has been upgraded. This task was used to update files when they were missing the creation date. | |
Repair - Reconcile npm /-/v1/searchmetadatarepository.npm.reindex | Extracts the search metadata from npm packages in npm-hosted repositories to support the ' | |
Repair - Rebuild npm metadatarepository.npm.rebuild-metadata | Rebuilds the metadata for an npm-hosted repository. Configure the task to rebuild metadata for all packages or a specified package. This task may be used to repair when the npm metadata has been corrupted. | |
Repair - Rebuild Yum repository metadata (repodata)repository.yum.rebuild.metadata | Rebuilds the metadata for a Yum-hosted repository. This task runs automatically after an RPM is uploaded, deleted, or redeployed. The default wait time is 60 seconds. | |
Replication - Backfill blob store attributes with component metadatareplication.blobattributesbackfill | Adds missing metadata to files in the blob store for replication. Wait until this task finishes before configuring a replication connection. | |
Repository - Delete unused componentsrepository.purge-unused | Use to soft-delete components not requested in the configured number of days from proxy repositories. This task is replaced by the Cleanup Policies. | |
Repository - Import external filesrepository.import | Use to import external content into a repository. See Repository Import for details. | |
Repository - Export assetsrepository.export | Use to export content from a repository. See Repository Export for details. | |
Rubygems - Generate SHA256 Checksumsrepository.rubygems.generate-sha256-checksums | Generate sha256 checksums when missing from RubyGem metadata. | |
Repair - Rebuild Rubygems versions filerepository.ruby.rebuild.versions | Rebuild the | |
Statistics - Recalculate vulnerability statisticsrepository.vulnerability.statistics | Yes | Provides the Log4j Visualizer with request log data. This task deletes the existing data that the visualizer is using and re-processes the logs. See Log4j Visualizer for more details. |
Reconcile Component Database task
This task is used to recover lost component metadata from a blob store when restoring content from backup and the database and blob storage are out of sync. The task searches the blob store for files missing metadata and updates the database with the metadata included in the blob store.
You can configure the task to only reconcile blobs created in the last specified number of days. This can drastically reduce your recovery time. For file blob stores, do not set this number to anything over 90 days. This is the maximum that Sonatype Nexus Repository can recover for file blob stores.
Currently, this task only recovers metadata for:
Apt, Docker, Go, Helm, Maven, npm, NuGet, p2, PyPI,R, Raw, RubyGems, Yum
Run the following tasks once this task is completed. Running these tasks before the restore is complete will cause errors in search and browse results.
Repair - Rebuild repository browse Repair - Rebuild repository search # when using npm Repair - Reconcile npm /-/v1/searchmetadata # when using Yum Repair - Rebuild Yum repository metadata (repodata)