Class BigtableInstanceAdminClient
- All Implemented Interfaces:
AutoCloseable
See the individual methods for example code.
// One instance per application.
BigtableInstanceAdminClient client = BigtableInstanceAdminClient.create("my-project");
CreateInstanceRequest request = CreateInstanceRequest.of("my-instance")
.addCluster("my-cluster", "us-east1-c", 3, StorageType.SSD);
Instance instance = client.createInstance(request);
// Cleanup during application shutdown.
client.close();
Creating a new client is a very expensive operation and should only be done once and shared in an application. However, close() needs to be called on the client object to clean up resources such as threads during application shutdown.
This class can be customized by passing in a custom instance of BigtableInstanceAdminSettings to create(). For example:
To customize credentials:
BigtableInstanceAdminSettings settings = BigtableInstanceAdminSettings.newBuilder()
.setProjectId("my-project")
.setCredentialsProvider(FixedCredentialsProvider.create(myCredentials))
.build();
BigtableInstanceAdminClient client = BigtableInstanceAdminClient.create(settings);
To customize the endpoint:
BigtableInstanceAdminSettings.Builder settingsBuilder = BigtableInstanceAdminSettings.newBuilder()
.setProjectId("my-project");
settingsBuilder.stubSettings()
.setEndpoint(myEndpoint);
BigtableInstanceAdminClient client = BigtableInstanceAdminClient.create(settingsBuilder.build());
-
Method Summary
Modifier and TypeMethodDescriptionvoid
close()
Closes the client and frees all resources associated with it (like thread pools).static BigtableInstanceAdminClient
create
(BigtableInstanceAdminSettings settings) Constructs an instance of BigtableInstanceAdminClient with the given settings.static BigtableInstanceAdminClient
Constructs an instance of BigtableInstanceAdminClient with the given project ID.static BigtableInstanceAdminClient
Constructs an instance of BigtableInstanceAdminClient with the given project ID and stub.createAppProfile
(CreateAppProfileRequest request) Creates a new app profile.com.google.api.core.ApiFuture<AppProfile>
Asynchronously creates a new app profile.createCluster
(CreateClusterRequest request) Creates a new cluster in the specified instance.com.google.api.core.ApiFuture<Cluster>
createClusterAsync
(CreateClusterRequest request) Asynchronously creates a new cluster in the specified instance.createInstance
(CreateInstanceRequest request) Creates a new instance and returns its representation.com.google.api.core.ApiFuture<Instance>
createInstanceAsync
(CreateInstanceRequest request) Asynchronously creates a new instance and returns its representation wrapped in a future.void
deleteAppProfile
(String instanceId, String appProfileId) Deletes the specified app profile.void
deleteAppProfile
(String instanceId, String appProfileId, boolean forceDelete) Deletes the specified app profile with an option to force deletion.com.google.api.core.ApiFuture<Void>
deleteAppProfileAsync
(String instanceId, String appProfileId) Asynchronously deletes the specified app profile.com.google.api.core.ApiFuture<Void>
deleteAppProfileAsync
(String instanceId, String appProfileId, boolean forceDelete) Asynchronously deletes the specified app profile with an option to force deletion.void
deleteCluster
(String instanceId, String clusterId) Deletes the specified cluster.com.google.api.core.ApiFuture<Void>
deleteClusterAsync
(String instanceId, String clusterId) Asynchronously deletes the specified cluster.void
deleteInstance
(String instanceId) Deletes the specified instance.com.google.api.core.ApiFuture<Void>
deleteInstanceAsync
(String instanceId) Asynchronously deletes the specified instance.disableClusterAutoscaling
(String instanceId, String clusterId, int staticSize) Disables autoscaling and enables manual scaling by setting a static node count for the cluster.com.google.api.core.ApiFuture<Cluster>
disableClusterAutoscalingAsync
(String instanceId, String clusterId, int staticSize) Asynchronously disables autoscaling and enables manual scaling by setting a static node count for the cluster.boolean
Checks if the instance specified by the instance ID exists.com.google.api.core.ApiFuture<Boolean>
existsAsync
(String instanceId) Asynchronously checks if the instance specified by the instance ID exists.getAppProfile
(String instanceId, String appProfileId) Gets the app profile by ID.com.google.api.core.ApiFuture<AppProfile>
getAppProfileAsync
(String instanceId, String appProfileId) Asynchronously gets the app profile by ID.getCluster
(String instanceId, String clusterId) Gets the cluster representation by ID.com.google.api.core.ApiFuture<Cluster>
getClusterAsync
(String instanceId, String clusterId) Asynchronously gets the cluster representation by ID.com.google.cloud.Policy
getIamPolicy
(String instanceId) Gets the IAM access control policy for the specified instance.com.google.api.core.ApiFuture<com.google.cloud.Policy>
getIamPolicyAsync
(String instanceId) Asynchronously gets the IAM access control policy for the specified instance.getInstance
(String id) Get the instance representation by ID.com.google.api.core.ApiFuture<Instance>
getInstanceAsync
(String instanceId) Asynchronously gets the instance representation by ID wrapped in a future.Gets the project ID this client is associated with.listAppProfiles
(String instanceId) Lists all app profiles of the specified instance.com.google.api.core.ApiFuture<List<AppProfile>>
listAppProfilesAsync
(String instanceId) Asynchronously lists all app profiles of the specified instance.listClusters
(String instanceId) Lists all clusters in the specified instance.listClustersAsync
(String instanceId) Asynchronously lists all clusters in the specified instance.Lists all of the instances in the current project.Asynchronously lists all of the instances in the current project.resizeCluster
(String instanceId, String clusterId, int numServeNodes) Modifies the cluster's node count for manual scaling.com.google.api.core.ApiFuture<Cluster>
resizeClusterAsync
(String instanceId, String clusterId, int numServeNodes) Asynchronously modifies the cluster's node count for manual scaling.com.google.cloud.Policy
setIamPolicy
(String instanceId, com.google.cloud.Policy policy) Replaces the IAM policy associated with the specified instance.com.google.api.core.ApiFuture<com.google.cloud.Policy>
setIamPolicyAsync
(String instanceId, com.google.cloud.Policy policy) Asynchronously replaces the IAM policy associated with the specified instance.testIamPermission
(String instanceId, String... permissions) Tests whether the caller has the given permissions for the specified instance.testIamPermissionAsync
(String instanceId, String... permissions) Asynchronously tests whether the caller has the given permissions for the specified instance.updateAppProfile
(UpdateAppProfileRequest request) Updates an existing app profile.com.google.api.core.ApiFuture<AppProfile>
Asynchronously updates an existing app profile.updateClusterAutoscalingConfig
(ClusterAutoscalingConfig clusterAutoscalingConfig) Modifies the cluster's autoscaling config.com.google.api.core.ApiFuture<Cluster>
updateClusterAutoscalingConfigAsync
(ClusterAutoscalingConfig clusterAutoscalingConfig) Asynchronously modifies the cluster's autoscaling config.updateInstance
(UpdateInstanceRequest request) Updates a new instance and returns its representation.com.google.api.core.ApiFuture<Instance>
updateInstanceAsync
(UpdateInstanceRequest request) Asynchronously updates a new instance and returns its representation wrapped in a future.
-
Method Details
-
create
Constructs an instance of BigtableInstanceAdminClient with the given project ID.- Throws:
IOException
-
create
public static BigtableInstanceAdminClient create(@Nonnull BigtableInstanceAdminSettings settings) throws IOException Constructs an instance of BigtableInstanceAdminClient with the given settings.- Throws:
IOException
-
create
public static BigtableInstanceAdminClient create(@Nonnull String projectId, @Nonnull com.google.cloud.bigtable.admin.v2.stub.BigtableInstanceAdminStub stub) Constructs an instance of BigtableInstanceAdminClient with the given project ID and stub. -
getProjectId
Gets the project ID this client is associated with. -
close
public void close()Closes the client and frees all resources associated with it (like thread pools).- Specified by:
close
in interfaceAutoCloseable
-
createInstance
Creates a new instance and returns its representation.Sample code:
Instance instance = client.createInstance( CreateInstanceRequest.of("my-instance") .addCluster("my-cluster", "us-east1-c", 3, StorageType.SSD) );
- See Also:
-
createInstanceAsync
Asynchronously creates a new instance and returns its representation wrapped in a future.Sample code:
ApiFuture<Instance> instanceFuture = client.createInstanceAsync( CreateInstanceRequest.of("my-instance") .addCluster("my-cluster", "us-east1-c", 3, StorageType.SSD) ); Instance instance = instanceFuture.get();
- See Also:
-
updateInstance
Updates a new instance and returns its representation.Sample code:
Instance instance = client.updateInstance( UpdateInstanceRequest.of("my-instance") .setProductionType() );
- See Also:
-
updateInstanceAsync
Asynchronously updates a new instance and returns its representation wrapped in a future.Sample code:
ApiFuture<Instance> instanceFuture = client.updateInstanceAsync( UpdateInstanceRequest.of("my-instance") .setProductionType() ); Instance instance = instanceFuture.get();
- See Also:
-
getInstance
Get the instance representation by ID.Sample code:
Instance instance = client.getInstance("my-instance");
-
getInstanceAsync
Asynchronously gets the instance representation by ID wrapped in a future.Sample code:
ApiFuture<Instance> instanceFuture = client.getInstanceAsync("my-instance"); Instance instance = instanceFuture.get();
-
listInstances
Lists all of the instances in the current project.This method will throw a
PartialListInstancesException
when any zone is unavailable. If a partial list is OK, the exception can be caught and inspected.Sample code:
try { List<Instance> instances = client.listInstances(); } catch (PartialListInstancesException e) { System.out.println("The following zones are unavailable: " + e.getUnavailableZones()); System.out.println("But the following instances are reachable: " + e.getInstances()); }
-
listInstancesAsync
Asynchronously lists all of the instances in the current project.This method will throw a
PartialListInstancesException
when any zone is unavailable. If a partial list is OK, the exception can be caught and inspected.Sample code:
ApiFuture<Instance> instancesFuture = client.listInstancesAsync(); ApiFutures.addCallback(instancesFuture, new ApiFutureCallback<List<Instance>>() { public void onFailure(Throwable t) { if (t instanceof PartialListInstancesException) { PartialListInstancesException partialError = (PartialListInstancesException)t; System.out.println("The following zones are unavailable: " + partialError.getUnavailableZones()); System.out.println("But the following instances are reachable: " + partialError.getInstances()); } else { t.printStackTrace(); } } public void onSuccess(List<Instance> result) { System.out.println("Found a complete set of instances: " + result); } }, MoreExecutors.directExecutor());
-
deleteInstance
Deletes the specified instance.Sample code:
client.deleteInstance("my-instance");
-
deleteInstanceAsync
Asynchronously deletes the specified instance.Sample code:
ApiFuture<Void> deleteFuture = client.deleteInstanceAsync("my-instance"); deleteFuture.get();
-
exists
Checks if the instance specified by the instance ID exists.Sample code:
if(client.exists("my-instance")) { System.out.println("Instance exists"); }
-
existsAsync
Asynchronously checks if the instance specified by the instance ID exists.Sample code:
ApiFuture<Boolean> found = client.existsAsync("my-instance"); ApiFutures.addCallback( found, new ApiFutureCallback<Boolean>() { public void onSuccess(Boolean found) { if (found) { System.out.println("Instance exists"); } else { System.out.println("Instance not found"); } } public void onFailure(Throwable t) { t.printStackTrace(); } }, MoreExecutors.directExecutor() );
-
createCluster
Creates a new cluster in the specified instance.Sample code:
Cluster cluster = client.createCluster( CreateClusterRequest.of("my-instance", "my-new-cluster") .setZone("us-east1-c") .setServeNodes(3) .setStorageType(StorageType.SSD) );
-
createClusterAsync
Asynchronously creates a new cluster in the specified instance.Sample code:
ApiFuture<Cluster> clusterFuture = client.createClusterAsync( CreateClusterRequest.of("my-instance", "my-new-cluster") .setZone("us-east1-c") .setServeNodes(3) .setStorageType(StorageType.SSD) ); Cluster cluster = clusterFuture.get();
-
getCluster
Gets the cluster representation by ID.Sample code:
Cluster cluster = client.getCluster("my-instance", "my-cluster");
-
getClusterAsync
Asynchronously gets the cluster representation by ID.Sample code:
ApiFuture<Cluster> clusterFuture = client.getClusterAsync("my-instance", "my-cluster"); Cluster cluster = clusterFuture.get();
-
listClusters
Lists all clusters in the specified instance.This method will throw a
PartialListClustersException
when any zone is unavailable. If a partial list is OK, the exception can be caught and inspected.Sample code:
try { List<Cluster> clusters = client.listClusters("my-instance"); } catch (PartialListClustersException e) { System.out.println("The following zones are unavailable: " + e.getUnavailableZones()); System.out.println("But the following clusters are reachable: " + e.getClusters()) }
-
listClustersAsync
Asynchronously lists all clusters in the specified instance.This method will throw a
PartialListClustersException
when any zone is unavailable. If a partial list is OK, the exception can be caught and inspected.Sample code:
ApiFuture<Cluster> clustersFuture = client.listClustersAsync("my-instance"); ApiFutures.addCallback(clustersFuture, new ApiFutureCallback<List<Cluster>>() { public void onFailure(Throwable t) { if (t instanceof PartialListClustersException) { PartialListClustersException partialError = (PartialListClustersException)t; System.out.println("The following zones are unavailable: " + partialError.getUnavailableZones()); System.out.println("But the following clusters are reachable: " + partialError.getClusters()); } else { t.printStackTrace(); } } public void onSuccess(List<Cluster> result) { System.out.println("Found a complete set of instances: " + result); } }, MoreExecutors.directExecutor());
-
resizeCluster
Modifies the cluster's node count for manual scaling. If autoscaling is already enabled, manual scaling will be silently ignored. If you wish to disable autoscaling and enable manual scaling, please usedisableClusterAutoscaling(String, String, int)
instead. Please note that only clusters that belong to a production instance can be resized.Sample code:
Cluster cluster = client.resizeCluster("my-instance", "my-cluster", 30);
-
resizeClusterAsync
public com.google.api.core.ApiFuture<Cluster> resizeClusterAsync(String instanceId, String clusterId, int numServeNodes) Asynchronously modifies the cluster's node count for manual scaling. If autoscaling is already enabled, manual scaling will be silently ignored. If you wish to disable autoscaling and enable manual scaling, please usedisableClusterAutoscaling(String, String, int)
instead. Please note that only clusters that belong to a production instance can be resized.ApiFuture<Cluster> clusterFuture = client.resizeCluster("my-instance", "my-cluster", 30); Cluster cluster = clusterFuture.get();
-
updateClusterAutoscalingConfig
public Cluster updateClusterAutoscalingConfig(@Nonnull ClusterAutoscalingConfig clusterAutoscalingConfig) Modifies the cluster's autoscaling config. This will enable autoscaling and disable manual scaling if the cluster is manually scaled. Please note that only clusters that belong to a production instance can enable autoscaling.Sample code:
ClusterAutoscalingConfig clusterAutoscalingConfig = ClusterAutoscalingConfig.of("my-instance", "my-cluster") .setMinNodes(1) .setMaxNodes(4) .setCpuUtilizationTargetPercent(40); Cluster cluster = client.updateClusterAutoscalingConfig(clusterAutoscalingConfig);
-
updateClusterAutoscalingConfigAsync
public com.google.api.core.ApiFuture<Cluster> updateClusterAutoscalingConfigAsync(@Nonnull ClusterAutoscalingConfig clusterAutoscalingConfig) Asynchronously modifies the cluster's autoscaling config. This will enable autoscaling and disable manual scaling if the cluster is manually scaled. Please note that only clusters that belong to a production instance can enable autoscaling.Sample code:
ClusterAutoscalingConfig clusterAutoscalingConfig = ClusterAutoscalingConfig.of(targetInstanceId, targetClusterId) .setMinNodes(1) .setMaxNodes(4) .setCpuUtilizationTargetPercent(40); ApiFuture<Cluster> clusterApiFuture = client.updateClusterAutoscalingConfigAsync(clusterAutoscalingConfig); Cluster cluster = clusterApiFuture.get();
-
disableClusterAutoscaling
Disables autoscaling and enables manual scaling by setting a static node count for the cluster. Please note that only clusters that belong to a production instance can be resized.Sample code:
Cluster cluster = client.disableClusterAutoscaling("my-instance", "my-cluster", 3);
-
disableClusterAutoscalingAsync
public com.google.api.core.ApiFuture<Cluster> disableClusterAutoscalingAsync(String instanceId, String clusterId, int staticSize) Asynchronously disables autoscaling and enables manual scaling by setting a static node count for the cluster. Please note that only clusters that belong to a production instance can be resized.Sample code:
ApiFuture<Cluster> clusterApiFuture = client.disableClusterAutoscalingAsync("my-instance", "my-cluster", 3); Cluster cluster = clusterApiFuture.get();
-
deleteCluster
Deletes the specified cluster. Please note that an instance must have at least 1 cluster. To remove the last cluster, please usedeleteInstance(String)
.Sample code:
client.deleteCluster("my-instance", "my-cluster");
-
deleteClusterAsync
Asynchronously deletes the specified cluster. Please note that an instance must have at least 1 cluster. To remove the last cluster, please usedeleteInstanceAsync(String)
.Sample code:
ApiFuture<Void> future = client.deleteClusterAsync("my-instance", "my-cluster"); future.get();
-
createAppProfile
Creates a new app profile.Sample code:
AppProfile appProfile = client.createAppProfile( CreateAppProfileRequest.of("my-instance", "my-new-app-profile") .setRoutingPolicy(SingleClusterRoutingPolicy.of("my-cluster")) );
- See Also:
-
createAppProfileAsync
public com.google.api.core.ApiFuture<AppProfile> createAppProfileAsync(CreateAppProfileRequest request) Asynchronously creates a new app profile.Sample code:
ApiFuture<AppProfile> appProfileFuture = client.createAppProfileAsync( CreateAppProfileRequest.of("my-instance", "my-new-app-profile") .setRoutingPolicy(SingleClusterRoutingPolicy.of("my-cluster")) ); AppProfile appProfile = appProfileFuture.get();
- See Also:
-
getAppProfile
Gets the app profile by ID.Sample code:
AppProfile appProfile = client.getAppProfile("my-instance", "my-app-profile");
- See Also:
-
getAppProfileAsync
public com.google.api.core.ApiFuture<AppProfile> getAppProfileAsync(String instanceId, String appProfileId) Asynchronously gets the app profile by ID.Sample code:
ApiFuture<AppProfile> appProfileFuture = client.getAppProfileAsync("my-instance", "my-app-profile"); AppProfile appProfile = appProfileFuture.get();
- See Also:
-
listAppProfiles
Lists all app profiles of the specified instance.Sample code:
List<AppProfile> appProfiles = client.listAppProfiles("my-instance");
- See Also:
-
listAppProfilesAsync
Asynchronously lists all app profiles of the specified instance.Sample code:
ApiFuture<List<AppProfile>> appProfilesFuture = client.listAppProfilesAsync("my-instance"); List<AppProfile> appProfiles = appProfileFuture.get();
- See Also:
-
updateAppProfile
Updates an existing app profile.Sample code:
AppProfile existingAppProfile = client.getAppProfile("my-instance", "my-app-profile"); AppProfile updatedAppProfile = client.updateAppProfile( UpdateAppProfileRequest.of(existingAppProfile) .setRoutingPolicy(SingleClusterRoutingPolicy.of("my-cluster")) );
- See Also:
-
updateAppProfileAsync
public com.google.api.core.ApiFuture<AppProfile> updateAppProfileAsync(UpdateAppProfileRequest request) Asynchronously updates an existing app profile.Sample code:
ApiFuture<AppProfile> existingAppProfileFuture = client.getAppProfileAsync("my-instance", "my-app-profile"); ApiFuture<AppProfile> updatedAppProfileFuture = ApiFutures.transformAsync( existingAppProfileFuture, new ApiAsyncFunction<AppProfile, AppProfile>() { public ApiFuture<AppProfile> apply(AppProfile existingAppProfile) { return client.updateAppProfileAsync( UpdateAppProfileRequest.of(existingAppProfile) .setRoutingPolicy(SingleClusterRoutingPolicy.of("my-other-cluster")) ); } }, MoreExecutors.directExecutor() ); ApiFuture<AppProfile> appProfile = updatedAppProfileFuture.get();
- See Also:
-
deleteAppProfile
Deletes the specified app profile.Sample code:
client.deleteAppProfile("my-instance", "my-app-profile");
-
deleteAppProfileAsync
public com.google.api.core.ApiFuture<Void> deleteAppProfileAsync(String instanceId, String appProfileId) Asynchronously deletes the specified app profile.Sample code:
ApiFuture<Void> deleteFuture = client.deleteAppProfileAsync("my-instance", "my-app-profile"); deleteFuture.get();
-
deleteAppProfile
Deletes the specified app profile with an option to force deletion.Sample code:
client.deleteAppProfile("my-instance", "my-app-profile", true);
-
deleteAppProfileAsync
public com.google.api.core.ApiFuture<Void> deleteAppProfileAsync(String instanceId, String appProfileId, boolean forceDelete) Asynchronously deletes the specified app profile with an option to force deletion.Sample code:
ApiFuture<Void> deleteFuture = client.deleteAppProfileAsync("my-instance", "my-app-profile", true); deleteFuture.get();
-
getIamPolicy
Gets the IAM access control policy for the specified instance.Sample code:
Policy policy = client.getIamPolicy("my-instance"); for(Map.Entry<Role, Set<Identity>> entry : policy.getBindings().entrySet()) { System.out.printf("Role: %s Identities: %s\n", entry.getKey(), entry.getValue()); }
- See Also:
-
getIamPolicyAsync
Asynchronously gets the IAM access control policy for the specified instance.Sample code:
ApiFuture<Policy> policyFuture = client.getIamPolicyAsync("my-instance"); ApiFutures.addCallback(policyFuture, new ApiFutureCallback<Policy>() { public void onSuccess(Policy policy) { for (Entry<Role, Set<Identity>> entry : policy.getBindings().entrySet()) { System.out.printf("Role: %s Identities: %s\n", entry.getKey(), entry.getValue()); } } public void onFailure(Throwable t) { t.printStackTrace(); } }, MoreExecutors.directExecutor());
- See Also:
-
setIamPolicy
Replaces the IAM policy associated with the specified instance.Sample code:
Policy newPolicy = client.setIamPolicy("my-instance", Policy.newBuilder() .addIdentity(Role.of("bigtable.user"), Identity.user("someone@example.com")) .addIdentity(Role.of("bigtable.admin"), Identity.group("admins@example.com")) .build());
- See Also:
-
setIamPolicyAsync
public com.google.api.core.ApiFuture<com.google.cloud.Policy> setIamPolicyAsync(String instanceId, com.google.cloud.Policy policy) Asynchronously replaces the IAM policy associated with the specified instance.Sample code:
ApiFuture<Policy> newPolicyFuture = client.setIamPolicyAsync("my-instance", Policy.newBuilder() .addIdentity(Role.of("bigtable.user"), Identity.user("someone@example.com")) .addIdentity(Role.of("bigtable.admin"), Identity.group("admins@example.com")) .build()); ApiFutures.addCallback(policyFuture, new ApiFutureCallback<Policy>() { public void onSuccess(Policy policy) { for (Entry<Role, Set<Identity>> entry : policy.getBindings().entrySet()) { System.out.printf("Role: %s Identities: %s\n", entry.getKey(), entry.getValue()); } } public void onFailure(Throwable t) { t.printStackTrace(); } }, MoreExecutors.directExecutor());
- See Also:
-
testIamPermission
Tests whether the caller has the given permissions for the specified instance. Returns a subset of the specified permissions that the caller has.Sample code:
System.out.println("Has read access: " + grantedPermissions.contains("bigtable.tables.readRows")); System.out.println("Has write access: " + grantedPermissions.contains("bigtable.tables.mutateRows"));List<String> grantedPermissions = client.testIamPermission("my-instance", "bigtable.tables.readRows", "bigtable.tables.mutateRows");
- See Also:
-
testIamPermissionAsync
public com.google.api.core.ApiFuture<List<String>> testIamPermissionAsync(String instanceId, String... permissions) Asynchronously tests whether the caller has the given permissions for the specified instance. Returns a subset of the specified permissions that the caller has.Sample code:
ApiFuture<List<String>> grantedPermissionsFuture = client.testIamPermissionAsync("my-instance", "bigtable.tables.readRows", "bigtable.tables.mutateRows"); ApiFutures.addCallback(grantedPermissionsFuture, new ApiFutureCallback<List<String>>() { public void onSuccess(List<String> grantedPermissions) { System.out.println("Has read access: " + grantedPermissions.contains("bigtable.tables.readRows")); System.out.println("Has write access: " + grantedPermissions.contains("bigtable.tables.mutateRows")); } public void onFailure(Throwable t) { t.printStackTrace(); } }, MoreExecutors.directExecutor());
- See Also:
-