org.miloss.fgsms.sla.rules.HighThreadCount Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of fgsms-sla-processor Show documentation
Show all versions of fgsms-sla-processor Show documentation
The SLA processor handles rules and actions invocations based on service owner defined rules
The newest version!
/**
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* If it is not possible or desirable to put the notice in a particular
* file, then You may include the notice in a location (such as a LICENSE
* file in a relevant directory) where a recipient would be likely to look
* for such a notice.
*
*/
/* ---------------------------------------------------------------------------
* U.S. Government, Department of the Army
* Army Materiel Command
* Research Development Engineering Command
* Communications Electronics Research Development and Engineering Center
* ---------------------------------------------------------------------------
*/
package org.miloss.fgsms.sla.rules;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.atomic.AtomicReference;
import org.miloss.fgsms.common.Utility;
import org.miloss.fgsms.plugins.sla.AlertType;
import org.miloss.fgsms.plugins.sla.SLARuleInterface;
import org.miloss.fgsms.services.interfaces.common.MachinePerformanceData;
import org.miloss.fgsms.services.interfaces.common.NameValuePair;
import org.miloss.fgsms.services.interfaces.common.PolicyType;
import org.miloss.fgsms.services.interfaces.common.ProcessPerformanceData;
import org.miloss.fgsms.services.interfaces.datacollector.AddDataRequestMsg;
import org.miloss.fgsms.services.interfaces.datacollector.BrokerData;
import org.miloss.fgsms.services.interfaces.policyconfiguration.MachinePolicy;
import org.miloss.fgsms.services.interfaces.policyconfiguration.ProcessPolicy;
import org.miloss.fgsms.services.interfaces.policyconfiguration.ServicePolicy;
import org.miloss.fgsms.services.interfaces.status.SetStatusRequestMsg;
/**
*
* @author AO
*/
public class HighThreadCount implements SLARuleInterface {
@Override
public boolean CheckTransactionalRule(SetStatusRequestMsg req, List params, AtomicReference nullableFaultMsg) {
return false;
}
@Override
public boolean CheckTransactionalRule(ProcessPerformanceData req, List params, AtomicReference nullableFaultMsg) {
if (nullableFaultMsg != null) {
nullableFaultMsg = new AtomicReference();
}
NameValuePair value = Utility.getNameValuePairByName(params, "value");
int x = 0;
if (value.isEncrypted()) {
x = Integer.parseInt(Utility.DE(value.getValue()));
} else {
x = Integer.parseInt(value.getValue());
}
if (req.getNumberofActiveThreads() != null && x > req.getNumberofActiveThreads().longValue()) {
nullableFaultMsg.set("The number of active threads, " + req.getNumberofActiveThreads() + " is higher than the threshold of " + x + ", " + nullableFaultMsg.get());
return true;
}
return false;
}
@Override
public boolean CheckTransactionalRule(MachinePerformanceData req, List params, AtomicReference nullableFaultMsg) {
if (nullableFaultMsg != null) {
nullableFaultMsg = new AtomicReference();
}
NameValuePair value = Utility.getNameValuePairByName(params, "value");
int x = 0;
if (value.isEncrypted()) {
x = Integer.parseInt(Utility.DE(value.getValue()));
} else {
x = Integer.parseInt(value.getValue());
}
if (req.getNumberofActiveThreads() != null && x > req.getNumberofActiveThreads().longValue()) {
nullableFaultMsg.set("The number of active threads, " + req.getNumberofActiveThreads() + " is higher than the threshold of " + x + ", " + nullableFaultMsg.get());
return true;
}
return false;
}
@Override
public boolean CheckTransactionalRule(AddDataRequestMsg req, List params, AtomicReference nullableFaultMsg) {
return false;
}
@Override
public boolean CheckTransactionalRule(String url, List data, List params, AtomicReference nullableFaultMsg) {
return false;
}
@Override
public boolean CheckNonTransactionalRule(ServicePolicy pol, List params, AtomicReference nullableFaultMsg, boolean pooled) {
return false;
}
@Override
public String GetDisplayName() {
return "High Thread Count";
}
@Override
public String GetHtmlFormattedHelp() {
return "This rule will trigger when a process or machine has a high number of threads running. This applies to machine and process service policies only.
"
+ "Required Parameters:"
+ ""
+ "- value - some positive integer value representing the threshold such as if the thread count is greater than the value, the rule is triggered.
"
+ "
";
}
@Override
public List GetRequiredParameters() {
List items = new ArrayList();
items.add(Utility.newNameValuePair("value", null, false, false));
return items;
}
@Override
public List GetOptionalParameters() {
return new ArrayList();
}
@Override
public boolean ValidateConfiguration(List params, AtomicReference outError,ServicePolicy policy) {
if (outError == null) {
outError = new AtomicReference();
}
if (params == null || params.isEmpty()) {
outError.set("The parameter 'value' is required. " + outError.get());
}
if (!(policy instanceof ProcessPolicy) && !(policy instanceof MachinePolicy)) {
outError.set("This rule only applies to Machine and Process Policies. " + outError.get());
}
boolean foundSubject = false;
for (int i = 0; i < params.size(); i++) {
if (params.get(i).getName().equals("value")) {
foundSubject = true;
if (Utility.stringIsNullOrEmpty(params.get(i).getValue())) {
outError.set("A value must be specified for the parameter 'value'. " + outError.get());
}
try {
int x = -1;
if (params.get(i).isEncrypted()) {
x = Integer.parseInt(Utility.DE(params.get(i).getValue()));
} else {
x = Integer.parseInt((params.get(i).getValue()));
}
if (x < 0) {
outError.set("The parameter 'value' must be greater than zero. " + outError.get());
}
} catch (Exception ex) {
outError.set("Could not parse the value of 'value' to an integer. Error: " + ex.getMessage() + ". " + outError.get());
}
}
}
if (!foundSubject) {
outError.set("The parameter 'value' is required. " + outError.get());
}
if (Utility.stringIsNullOrEmpty(outError.get())) {
return true;
} else {
return false;
}
}
@Override
public AlertType GetType() {
return AlertType.Performance;
}
@Override
public String GetHtmlFormattedDisplay(List params) {
NameValuePair mc = Utility.getNameValuePairByName(params, "value");
String item = UNDEFINED_VALUE;
if (mc != null) {
item = mc.getValue();
if (mc.isEncrypted() || mc.isEncryptOnSave()) {
item = ENCRYPTED_MASK;
}
}
return Utility.encodeHTML(GetDisplayName() + " " + item );
}
@Override
public List GetAppliesTo() {
List x = new ArrayList();
x.add(PolicyType.MACHINE);
x.add(PolicyType.PROCESS);
return x;
}
}