
oracle.kv.impl.admin.plan.SNParameterConsistencyPlan Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of oracle-nosql-server Show documentation
Show all versions of oracle-nosql-server Show documentation
NoSQL Database Server - supplies build and runtime support for the server (store) side of the Oracle NoSQL Database.
The newest version!
/*-
* Copyright (C) 2011, 2018 Oracle and/or its affiliates. All rights reserved.
*
* This file was distributed by Oracle as part of a version of Oracle NoSQL
* Database made available at:
*
* http://www.oracle.com/technetwork/database/database-technologies/nosqldb/downloads/index.html
*
* Please see the LICENSE file included in the top-level directory of the
* appropriate version of Oracle NoSQL Database for a copy of the license and
* additional information.
*/
package oracle.kv.impl.admin.plan;
import java.util.List;
import oracle.kv.impl.admin.PlanLocksHeldException;
import oracle.kv.impl.admin.SnConsistencyUtils;
import oracle.kv.impl.admin.plan.task.NewRepNodeParameters;
import oracle.kv.impl.admin.plan.task.UpdateRepNodeParams;
import oracle.kv.impl.admin.plan.task.WriteNewANParams;
import oracle.kv.impl.admin.plan.task.WriteNewGlobalParams;
import oracle.kv.impl.admin.plan.task.WriteNewSNParams;
import oracle.kv.impl.param.ParameterMap;
import oracle.kv.impl.security.KVStorePrivilege;
import oracle.kv.impl.security.SystemPrivilege;
import oracle.kv.impl.topo.ArbNodeId;
import oracle.kv.impl.topo.RepNodeId;
import oracle.kv.impl.topo.ResourceId;
import oracle.kv.impl.topo.StorageNodeId;
public class SNParameterConsistencyPlan extends AbstractPlan {
private static final long serialVersionUID = 1L;
private final StorageNodeId snId;
public
SNParameterConsistencyPlan(String name,
Planner planner,
StorageNodeId snId,
SnConsistencyUtils.ParamCheckResults pcr) {
super(name, planner, true);
this.snId = snId;
/* generate tasks */
if (pcr.getGlobalDiff()) {
addTask(new WriteNewGlobalParams(this, null, snId, true));
}
for (ResourceId resId : pcr.getDiffs()) {
if (resId instanceof StorageNodeId) {
ParameterMap snMap =
getAdmin().getStorageNodeParams(snId).getMap();
addTask(new WriteNewSNParams(this, snId, snMap, true));
} else if (resId instanceof RepNodeId) {
addTask(new UpdateRepNodeParams(this,
(RepNodeId)resId, false,
true, true));
addTask(new NewRepNodeParameters(this, (RepNodeId)resId));
} else if (resId instanceof ArbNodeId) {
ArbNodeId anId = (ArbNodeId)resId;
ParameterMap anMap =
getAdmin().getArbNodeParams(anId).getMap();
addTask(new WriteNewANParams(this, anMap, anId, snId, true));
}
}
}
@Override
public void getCatalogLocks()
throws PlanLocksHeldException {
planner.lockElasticity(getId(), getName());
getPerTaskLocks();
}
@Override
public boolean isExclusive() {
return false;
}
@Override
public void preExecutionSave() {
/* Nothing to save before execution. */
}
@Override
public String getDefaultName() {
return "SN parameter consistency plan for " + snId;
}
@Override
public List extends KVStorePrivilege> getRequiredPrivileges() {
/* Requires SYSOPER */
return SystemPrivilege.sysoperPrivList;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy