Skip to main content

Staging

Only available in Sonatype Nexus Repository Pro. Interested in a free trial? Start here.

Overview

In modern software development, it is imperative to thoroughly test the software before deploying it to a production system or externally accessible repository. Most commonly, developers will first deploy a release candidate to a staging system that is a close copy of the production system; here, it will undergo a series of rigorous tests before it is either promoted to production or returned to development.

The staging functionality in Nexus Repository facilitates this process by allowing you to move components between repositories. This allows you to create isolated release candidates that you can then discard or promote as needed to support the decisions that go into certifying a release.

Staging allows your organization to have some sequence of hosted repositories and move or promote components through those repositories under your delivery or code promotion process.

Other features of staging in Nexus Repository let you do the following:

  • Avoid exposing your entire organization to untested components.

  • Identify a batch of components as a “build.”

  • Track build status from development to production.

  • Apply rules to builds (e.g., no SNAPSHOT dependencies).

  • Control build visibility based on status.

Staging can also answer the question of “What made it to production?” This lets you create isolated release candidates that can be promoted or discarded in support of certifying a release.

Building Blocks

Staging comprises three basic building blocks:

  • Hosted repositories - Upload components/assets to hosted repositories; you can then promote/move them to other hosted repositories or delete them as required.

  • Component tags - Tag uploaded components/assets so that you can identify them as a logical group and transfer them together. See Tagging for more information.

  • REST endpoints for directly moving and deleting components between hosted repositories.

    • Move - Move all components/assets matching a specific search query to a target repository.

    • Delete - Delete all components/assets matching a specified search query.

Limitations

Staging has the following limitations:

  • Staging can only be used with hosted repositories in Apt, Docker, Maven, npm, NuGet, PyPI, Raw, and Yum formats.

  • You can only transfer between repositories of the same version policy; you cannot transfer from a snapshot repository to a release repository.

  • Staging moves are not supported for hosted repositories that are configured as the writable member for a Docker group repository; attempting a move for a repository that is a writable member of a Docker group repository will result in an error.

    • This limitation exists due to the way Docker image deployments work. Docker images are comprised of a tag, manifest(s), and layers (See Components and Assets in Docker). When using Docker group deployments, manifests and layers that already exist in any member of the group repository will not be uploaded to the target hosted repository. This happens because Docker clients always test to see if a file is present in the remote before uploading it. This makes it highly likely that some of the uploaded image files will be present in proxy repositories within the group or in other repositories that were not included in the tagging command. Attempting a staging move on an image that has either of these problems will result in a failure.

    • See the Pushing Images to a Group Repositoryfor more information on writable repositories.

  • In order to perform a staging move, a user needs the following privileges:

    nx-repository-view-<repo-format>-<repoId>-delete privilege in the source repository

    nx-repository-view-<repo-format>-<repoId>-add privilege in the destination repository

Workflow

As depicted in the figure below, a typical staging workflow involves hosted repositories, group repositories to include other dependencies, and an external system that coordinates the promotion process. This usually includes a continuous integration (CI) system (e.g., Jenkins) that continuously builds each commit and a release manager that promotes builds for testing and release.

14156058.png

The sections below detail each phase of the process as illustrated above.

Build Phase

When a developer pushes new code, the CI system automatically picks it up and performs the build, including any unit or integration tests. It then uploads the resulting artifacts to the incoming Sonatype Nexus Repository repository. As part of this operation, Nexus Repository tags the artifacts for later identification. The CI project/Job ID and the build ID are often used as the tag. For example, the job project-abc with build ID 142 results in the tag project-abc-build-142.

Test Phase

When ready, you can promote any given build to the next stage. In the figure above, a build is promoted from the incoming hosted repository to the uat repository in preparation for testing. This can be initiated via the CI job/pipeline or as a separate job. Sonatype Nexus Repository receives the promotion call to take all components tagged with project-abc-build-142 and move them into the uat repository. This repository is then available to a group of users who test the build to ensure quality.

Release Phase

When testing is complete, you can promote the build to the next stage; in the figure above, a build is promoted from the uat repository to the prod repository in preparation for release. Again, this may be initiated via the CI job/pipeline or through a separate job. Nexus Repository receives the promotion call to take all components tagged with project-abc-build-142 and move them into the prod repository.

Alternatively, if the build fails testing, then you can issue the call to delete all components tagged with project-abc-build-142.

REST Endpoints

See REST and Integration API for more details on using these endpoints via the interactive user interface.

Promotion

POST service/rest/v1/staging/move/{repository}

This endpoint promotes (or moves) components that match a search into the specified repository.

curl -u admin:admin123 -X POST 'http://127.0.0.1:8081/service/rest/v1/staging/move/uat?tag=project-abc-142'

This example moves all components tagged with project-abc-142 into the repository uat. Note that you can use any search criteria, but the tag parameter is most common when staging.

The response will include a payload showing the moved components.

Example Response

{
    "status": 200,
    "message": "Move Successful",
    "data": {
        "destination": "uat",
        "components moved": [
            {
                "name": "project-abc",
                "group": "com.mycompany",
                "version": "2.1.1"
            }
        ]
    }
}

Deletion

POST /service/rest/v1/staging/delete

This endpoint deletes components that match a search from a repository. The primary use case when staging is to delete a set of components that failed testing.

curl -u admin:admin123 -X POST 'http://127.0.0.1:8081/service/rest/v1/staging/delete?tag=project-abc-142'

This example removes all components with the tag project-abc-142. As with Promote, you can use any search criteria, but the tag parameter is most common when staging.

The response will include a payload showing the deleted components.

Example Response

{
    "status": 200,
    "message": "Delete Successful",
    "data": {
        "components deleted": [
            {
                "repository": "uat",
                "group": "com.mycompany",
                "name": "project-abc",
                "version": "2.1.1"
            }
        ]
    }
}