A newer version of this documentation is available.

View Latest

Get Backup Plan Information

      +
      The Backup Service REST API lets you get information about backup plans.

      HTTP Methods and URIs

      Get a list of all defined backup plans:

      GET /plan

      Get detailed information about a specific backup plan:

      GET /plan/{PLAN_NAME}
      Table 1. Path Parameters
      Name Description Schema

      PLAN_NAME

      The name of a backup plan.

      String

      Curl Syntax

      curl -X GET http://$BACKUP_SERVICE_NODE:$BACKUP_SERVICE_PORT/plan
        -u $USERNAME:$PASSWORD
      
      curl -X GET http://$BACKUP_SERVICE_NODE:$BACKUP_SERVICE_PORT:8097/plan/$PLAN_NAME
        -u $USERNAME:$PASSWORD

      Required Permissions

      Full Admin, Backup Full Admin, or Read-Only Admin roles.

      Responses

      Value Description

      200 OK and JSON array containing plan information depending on the specific endpoint.

      Successful call.

      400

      Invalid parameter.

      401 Unauthorized

      Authorization failure due to incorrect username or password.

      403 Forbidden, plus a JSON message explaining the minimum permissions.

      The provided username has insufficient privileges to call this method.

      404 Object Not found and the message {"status":404,"msg":"requested plan not found"}

      The plan in the endpoint URI does not exist.

      500 Could not retrieve the requested repository

      Error in Couchbase Server.

      Examples

      The following call returns an array each of whose members is an object containing information for a plan currently defined for the cluster. The command pipes the output to the jq command to improve readability:

      curl -v -X GET http://127.0.0.1:8097/api/v1/api/v1/plan \
      -u Administrator:password | jq '.'

      If the call is successful, 200 OK is returned, with an array the initial part of which may appear as follows:

      [
        {
          "name": "BackupAndMergePlan",
          "description": "A plan for backing up and merging.",
          "services": [
            "data"
          ],
          "tasks": [
            {
              "name": "BackupEveryTuesdayForOneYear",
              "task_type": "BACKUP",
              "schedule": {
                "job_type": "BACKUP",
                "frequency": 52,
                "period": "TUESDAY",
                "time": "21:00"
              },
              "full_backup": true
            },
            {
              "name": "testTask3",
              "task_type": "MERGE",
              "schedule": {
                "job_type": "MERGE",
                "frequency": 4,
                "period": "WEEKS",
                "time": "22:00"
              },
              "full_backup": false
            }
          ]
        },
        {
          "name": "testPlan5",
          "description": "A test plan.",
          "services": [
            "data",
            "gsi"
          ],
          "tasks": [
            {
              "name": "BackupTask",
                .
                .
                .
            }
          ]
        }
      ]

      Each object in the array contains information on the specified plan. The information includes confirmation of the services for which data is backed up by the plan; and the tasks that are performed for the plan. Each task is listed with an account of its type and schedule.

      The following call returns information specifically on the plan testPlan2:

      curl -v -X GET http://127.0.0.1:8091/_p/backup/api/v1/plan/testPlan2 \
      -u Administrator:password | jq '.'

      If the call is successful, 200 OK is returned, with the following object:

      {
        "name": "testPlan2",
        "description": "A test plan.",
        "services": [
          "data",
          "gsi"
        ],
        "tasks": [
          {
            "name": "BackupTask",
            "task_type": "BACKUP",
            "schedule": {
              "job_type": "BACKUP",
              "frequency": 10,
              "period": "MINUTES"
            },
            "full_backup": false
          },
          {
            "name": "MergeTask",
            "task_type": "MERGE",
            "schedule": {
              "job_type": "MERGE",
              "frequency": 1,
              "period": "HOURS",
              "time": "22:00"
            },
            "full_backup": false
          }
        ]
      }

      The object contains information about the specified plan. The information includes confirmation of the services for which data is backed up by the plan; and the tasks that are performed for the plan. Each task is listed with an account of its type and schedule.

      See Also