恢复数据库备份(RecoverDatabaseFromBackup)
从备份库恢复数据库备份。
API请求
URLs
PUT zstack/v1/database-backups/actions?uuid={uuid}
Headers
Authorization: OAuth the-session-uuid
Body
{
"recoverDatabaseFromBackup": {
"backupStorageUrl": "ssh://root:password@localhost:22/zstack_bs",
"backupInstallPath": "zstore://zsbak/0ed599ec519249489475112a058bb93a",
"mysqlRootPassword": "password"
},
"systemTags": [],
"userTags": []
}
Note: 上述示例中systemTags、userTags字段可以省略。列出是为了表示body中可以包含这两个字段。
Curl示例
curl -H "Content-Type: application/json" \
-H "Authorization: OAuth b86c9016b4f24953a9edefb53ca0678c" \
-X PUT -d '{"recoverDatabaseFromBackup":{"backupStorageUrl":"ssh://root:password@localhost:22/zstack_bs","backupInstallPath":"zstore://zsbak/0ed599ec519249489475112a058bb93a","mysqlRootPassword":"password"}}' http://localhost:8080/zstack/v1/database-backups/actions
参数列表
名字 | 类型 | 位置 | 描述 | 可选值 | 起始版本 |
---|---|---|---|---|---|
uuid (可选) | String | url | 资源的UUID,唯一标示该资源 | 3.0.0 | |
backupStorageUrl (可选) | String | body(包含在recoverDatabaseFromBackup结构中) | 镜像服务器URL | 3.0.0 | |
backupInstallPath (可选) | String | body(包含在recoverDatabaseFromBackup结构中) | 数据库备份存储路径 | 3.0.0 | |
mysqlRootPassword | String | body(包含在recoverDatabaseFromBackup结构中) | MYSQL数据库ROOT密码 | 3.0.0 | |
systemTags (可选) | List | body | 3.0.0 | ||
userTags (可选) | List | body | 3.0.0 |
API返回
返回示例
{
"logListenPort": 0.0
}
名字 | 类型 | 描述 | 起始版本 |
---|---|---|---|
logListenPort | int | 浏览器可以通过此端口号实时打印日志 | 3.0.0 |
error | ErrorCode | 错误码,若不为null,则表示操作失败, 操作成功时该字段为null。 详情参考error | 3.0.0 |
#error
名字 | 类型 | 描述 | 起始版本 |
---|---|---|---|
code | String | 错误码号,错误的全局唯一标识,例如SYS.1000, HOST.1001 | 3.0.0 |
description | String | 错误的概要描述 | 3.0.0 |
details | String | 错误的详细信息 | 3.0.0 |
elaboration | String | 保留字段,默认为null | 3.0.0 |
opaque | LinkedHashMap | 保留字段,默认为null | 3.0.0 |
cause | ErrorCode | 根错误,引发当前错误的源错误,若无原错误,该字段为null | 3.0.0 |
SDK示例
Java
SDK
RecoverDatabaseFromBackupAction action = new RecoverDatabaseFromBackupAction();
action.backupStorageUrl = "ssh://root:password@localhost:22/zstack_bs";
action.backupInstallPath = "zstore://zsbak/0ed599ec519249489475112a058bb93a";
action.mysqlRootPassword = "password";
action.sessionId = "b86c9016b4f24953a9edefb53ca0678c";
RecoverDatabaseFromBackupAction.Result res = action.call();
Python
SDK
RecoverDatabaseFromBackupAction action = RecoverDatabaseFromBackupAction()
action.backupStorageUrl = "ssh://root:password@localhost:22/zstack_bs"
action.backupInstallPath = "zstore://zsbak/0ed599ec519249489475112a058bb93a"
action.mysqlRootPassword = "password"
action.sessionId = "b86c9016b4f24953a9edefb53ca0678c"
RecoverDatabaseFromBackupAction.Result res = action.call()