All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.miloss.fgsms.sla.rules.HighThreadCount Maven / Gradle / Ivy

Go to download

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; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy