forked from oracle/oci-java-sdk
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathGetAndUpdateExadataIORMExample.java
More file actions
111 lines (86 loc) · 4.86 KB
/
GetAndUpdateExadataIORMExample.java
File metadata and controls
111 lines (86 loc) · 4.86 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/**
* Copyright (c) 2016, 2021, Oracle and/or its affiliates. All rights reserved.
* This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license.
*/
import com.oracle.bmc.ConfigFileReader;
import com.oracle.bmc.auth.AuthenticationDetailsProvider;
import com.oracle.bmc.auth.ConfigFileAuthenticationDetailsProvider;
import com.oracle.bmc.database.DatabaseClient;
import com.oracle.bmc.database.model.DbIormConfigUpdateDetail;
import com.oracle.bmc.database.model.ExadataIormConfigUpdateDetails;
import com.oracle.bmc.database.requests.GetExadataIormConfigRequest;
import com.oracle.bmc.database.requests.UpdateExadataIormConfigRequest;
import com.oracle.bmc.database.responses.GetExadataIormConfigResponse;
import com.oracle.bmc.database.responses.UpdateExadataIormConfigResponse;
import java.util.Collections;
/*
* Example Class to show the usage of Get, Update and Reset of DBaaS Exadata IORM Configuration.
* This Example assumes that an Exadata DB System is already in available state.
*/
public class GetAndUpdateExadataIORMExample {
private static final String CONFIG_LOCATION = "~/.oci/config";
private static final String CONFIG_PROFILE = "DEFAULT";
public static void main(String[] args) throws Exception {
if (args.length != 1) {
throw new Exception("This example expects 1 argument: A Database System OCID");
}
// Configuring the AuthenticationDetailsProvider. It's assuming there is a default OCI config file
// "~/.oci/config", and a profile in that config with the name "DEFAULT". Make changes to the following
// line if needed and use ConfigFileReader.parse(CONFIG_LOCATION, profile);
final ConfigFileReader.ConfigFile configFile = ConfigFileReader.parseDefault();
final AuthenticationDetailsProvider provider =
new ConfigFileAuthenticationDetailsProvider(configFile);
String dbSystemID = args[0];
DatabaseClient databaseClient = new DatabaseClient(provider);
/*
Exadata IORM get configuration Example...
*/
GetExadataIormConfigRequest getExadataIormConfigRequest =
GetExadataIormConfigRequest.builder().dbSystemId(dbSystemID).build();
GetExadataIormConfigResponse exadataIormConfig =
databaseClient.getExadataIormConfig(getExadataIormConfigRequest);
System.out.printf(
"Successfully fetched Exadata IORM configuration :%s\n",
exadataIormConfig.getExadataIormConfig());
/*
Exadata IORM update configuration Example...
Sets the default directive and the Objective for IORM configuration
default share value is set to 10
Objective is set to Balanced
*/
DbIormConfigUpdateDetail defaultPlan =
DbIormConfigUpdateDetail.builder().dbName("default").share(10).build();
ExadataIormConfigUpdateDetails configUpdateDetails =
ExadataIormConfigUpdateDetails.builder()
.objective(ExadataIormConfigUpdateDetails.Objective.Balanced)
.dbPlans(Collections.singletonList(defaultPlan))
.build();
UpdateExadataIormConfigRequest updateExadataIormConfigRequest =
UpdateExadataIormConfigRequest.builder()
.dbSystemId(dbSystemID)
.exadataIormConfigUpdateDetails(configUpdateDetails)
.build();
UpdateExadataIormConfigResponse updateExadataIormConfigResponse =
databaseClient.updateExadataIormConfig(updateExadataIormConfigRequest);
System.out.printf(
"Exadata IORM configuration is being updated:%s\n",
updateExadataIormConfigResponse.getExadataIormConfig());
/*
Exadata IORM reset configuration Example...
Sets the IORM configuration to disabled.
This is achieved by sending in null values for objective and dbPlans
*/
ExadataIormConfigUpdateDetails configResetDetails =
ExadataIormConfigUpdateDetails.builder().objective(null).dbPlans(null).build();
UpdateExadataIormConfigRequest resetExadataIormConfigRequest =
UpdateExadataIormConfigRequest.builder()
.dbSystemId(dbSystemID)
.exadataIormConfigUpdateDetails(configResetDetails)
.build();
UpdateExadataIormConfigResponse resetConfigResponse =
databaseClient.updateExadataIormConfig(resetExadataIormConfigRequest);
System.out.printf(
"Exadata IORM configuration is being reset:%s\n",
resetConfigResponse.getExadataIormConfig());
}
}