Add some checks to prevent any chance of an ArithmaticException because
of divide by zero.
This commit is contained in:
Timothy Bish 2014-05-05 16:12:50 -04:00
parent 53b12820c2
commit 541ed8cf0c
2 changed files with 33 additions and 35 deletions

View File

@ -27,6 +27,7 @@ import javax.management.openmbean.CompositeType;
import javax.management.openmbean.TabularData; import javax.management.openmbean.TabularData;
import javax.management.openmbean.TabularDataSupport; import javax.management.openmbean.TabularDataSupport;
import javax.management.openmbean.TabularType; import javax.management.openmbean.TabularType;
import org.apache.activemq.broker.BrokerService; import org.apache.activemq.broker.BrokerService;
import org.apache.activemq.broker.scheduler.JobSchedulerStore; import org.apache.activemq.broker.scheduler.JobSchedulerStore;
import org.apache.activemq.store.PersistenceAdapter; import org.apache.activemq.store.PersistenceAdapter;
@ -45,7 +46,7 @@ public class HealthView implements HealthViewMBean {
public TabularData health() throws Exception { public TabularData health() throws Exception {
OpenTypeSupport.OpenTypeFactory factory = OpenTypeSupport.getFactory(HealthStatus.class); OpenTypeSupport.OpenTypeFactory factory = OpenTypeSupport.getFactory(HealthStatus.class);
CompositeType ct = factory.getCompositeType(); CompositeType ct = factory.getCompositeType();
TabularType tt = new TabularType("HealthStatus", "HealthStatus", ct, new String[]{"healthId", "level", "message", "resource"}); TabularType tt = new TabularType("HealthStatus", "HealthStatus", ct, new String[] { "healthId", "level", "message", "resource" });
TabularDataSupport rc = new TabularDataSupport(tt); TabularDataSupport rc = new TabularDataSupport(tt);
List<HealthStatus> list = healthList(); List<HealthStatus> list = healthList();
@ -70,7 +71,6 @@ public class HealthView implements HealthViewMBean {
/** /**
* Check persistence store directory limits * Check persistence store directory limits
*
*/ */
BrokerService brokerService = broker.getBrokerService(); BrokerService brokerService = broker.getBrokerService();
if (brokerService != null && brokerService.getPersistenceAdapter() != null) { if (brokerService != null && brokerService.getPersistenceAdapter() != null) {
@ -84,7 +84,6 @@ public class HealthView implements HealthViewMBean {
dir = new File(dirPath); dir = new File(dirPath);
} }
while (dir != null && !dir.isDirectory()) { while (dir != null && !dir.isDirectory()) {
dir = dir.getParentFile(); dir = dir.getParentFile();
} }
@ -92,23 +91,21 @@ public class HealthView implements HealthViewMBean {
long storeLimit = usage.getStoreUsage().getLimit(); long storeLimit = usage.getStoreUsage().getLimit();
long dirFreeSpace = dir.getUsableSpace(); long dirFreeSpace = dir.getUsableSpace();
if (storeSize != 0) { if (storeSize != 0 && storeLimit != 0) {
int val = (int) ((storeSize * 100) / storeLimit); int val = (int) ((storeSize * 100) / storeLimit);
if (val > 90) { if (val > 90) {
answer.add(new HealthStatus("org.apache.activemq.StoreLimit", "WARNING", "Message Store size is within " + val + "% of its limit", adapter.toString())); answer.add(new HealthStatus("org.apache.activemq.StoreLimit", "WARNING", "Message Store size is within " + val + "% of its limit",
adapter.toString()));
} }
} }
if ((storeLimit - storeSize) > dirFreeSpace) { if ((storeLimit - storeSize) > dirFreeSpace) {
String message = "Store limit is " + storeLimit / (1024 * 1024) + String message = "Store limit is " + storeLimit / (1024 * 1024) + " mb, whilst the data directory: " + dir.getAbsolutePath()
" mb, whilst the data directory: " + dir.getAbsolutePath() + + " only has " + dirFreeSpace / (1024 * 1024) + " mb of usable space";
" only has " + dirFreeSpace / (1024 * 1024) + " mb of usable space";
answer.add(new HealthStatus("org.apache.activemq.FreeDiskSpaceLeft", "WARNING", message, adapter.toString())); answer.add(new HealthStatus("org.apache.activemq.FreeDiskSpaceLeft", "WARNING", message, adapter.toString()));
} }
} }
File tmpDir = brokerService.getTmpDataDirectory(); File tmpDir = brokerService.getTmpDataDirectory();
if (tmpDir != null) { if (tmpDir != null) {
@ -123,15 +120,14 @@ public class HealthView implements HealthViewMBean {
tmpDir = tmpDir.getParentFile(); tmpDir = tmpDir.getParentFile();
} }
int val = (int) ((storeSize * 100) / storeLimit); if (storeLimit != 0) {
if (val > 90) { int val = (int) ((storeSize * 100) / storeLimit);
answer.add(new HealthStatus("org.apache.activemq.TempStoreLimit", "WARNING", "TempMessage Store size is within " + val + "% of its limit", adapter.toString())); if (val > 90) {
answer.add(new HealthStatus("org.apache.activemq.TempStoreLimit", "WARNING", "TempMessage Store size is within " + val
+ "% of its limit", adapter.toString()));
}
} }
} }
} }
} }
@ -146,7 +142,6 @@ public class HealthView implements HealthViewMBean {
dir = new File(dirPath); dir = new File(dirPath);
} }
while (dir != null && !dir.isDirectory()) { while (dir != null && !dir.isDirectory()) {
dir = dir.getParentFile(); dir = dir.getParentFile();
} }
@ -154,34 +149,32 @@ public class HealthView implements HealthViewMBean {
long storeLimit = usage.getJobSchedulerUsage().getLimit(); long storeLimit = usage.getJobSchedulerUsage().getLimit();
long dirFreeSpace = dir.getUsableSpace(); long dirFreeSpace = dir.getUsableSpace();
if (storeSize != 0) { if (storeSize != 0 && storeLimit != 0) {
int val = (int) ((storeSize * 100) / storeLimit); int val = (int) ((storeSize * 100) / storeLimit);
if (val > 90) { if (val > 90) {
answer.add(new HealthStatus("org.apache.activemq.JobSchedulerLimit", "WARNING", "JobSchedulerMessage Store size is within " + val + "% of its limit", scheduler.toString())); answer.add(new HealthStatus("org.apache.activemq.JobSchedulerLimit", "WARNING", "JobSchedulerMessage Store size is within " + val
+ "% of its limit", scheduler.toString()));
} }
} }
if ((storeLimit - storeSize) > dirFreeSpace) { if ((storeLimit - storeSize) > dirFreeSpace) {
String message = "JobSchedulerStore limit is " + storeLimit / (1024 * 1024) + String message = "JobSchedulerStore limit is " + storeLimit / (1024 * 1024) + " mb, whilst the data directory: "
" mb, whilst the data directory: " + dir.getAbsolutePath() + + dir.getAbsolutePath() + " only has " + dirFreeSpace / (1024 * 1024) + " mb of usable space";
" only has " + dirFreeSpace / (1024 * 1024) + " mb of usable space";
answer.add(new HealthStatus("org.apache.activemq.FreeDiskSpaceLeft", "WARNING", message, scheduler.toString())); answer.add(new HealthStatus("org.apache.activemq.FreeDiskSpaceLeft", "WARNING", message, scheduler.toString()));
} }
} }
} }
} }
if (answer != null && !answer.isEmpty()){ if (answer != null && !answer.isEmpty()) {
this.currentState = "Getting Worried {"; this.currentState = "Getting Worried {";
for (HealthStatus hs: answer){ for (HealthStatus hs : answer) {
currentState += hs + " , "; currentState += hs + " , ";
}
currentState += " }";
} else {
this.currentState = "Good";
} }
currentState += " }";
} else{
this.currentState="Good";
}
return answer; return answer;
} }
@ -192,5 +185,4 @@ public class HealthView implements HealthViewMBean {
public String getCurrentStatus() { public String getCurrentStatus() {
return this.currentState; return this.currentState;
} }
} }

View File

@ -28,6 +28,7 @@ import javax.management.MBeanServer;
import javax.management.MBeanServerInvocationHandler; import javax.management.MBeanServerInvocationHandler;
import javax.management.MalformedObjectNameException; import javax.management.MalformedObjectNameException;
import javax.management.ObjectName; import javax.management.ObjectName;
import org.apache.activemq.ActiveMQConnectionFactory; import org.apache.activemq.ActiveMQConnectionFactory;
import org.apache.activemq.EmbeddedBrokerTestSupport; import org.apache.activemq.EmbeddedBrokerTestSupport;
import org.apache.activemq.broker.BrokerService; import org.apache.activemq.broker.BrokerService;
@ -39,6 +40,7 @@ public class HealthViewMBeanTest extends EmbeddedBrokerTestSupport {
protected MBeanServer mbeanServer; protected MBeanServer mbeanServer;
protected String domain = "org.apache.activemq"; protected String domain = "org.apache.activemq";
@Override
protected void setUp() throws Exception { protected void setUp() throws Exception {
bindAddress = "tcp://localhost:0"; bindAddress = "tcp://localhost:0";
useTopic = false; useTopic = false;
@ -46,6 +48,7 @@ public class HealthViewMBeanTest extends EmbeddedBrokerTestSupport {
mbeanServer = broker.getManagementContext().getMBeanServer(); mbeanServer = broker.getManagementContext().getMBeanServer();
} }
@Override
protected void tearDown() throws Exception { protected void tearDown() throws Exception {
super.tearDown(); super.tearDown();
} }
@ -55,6 +58,7 @@ public class HealthViewMBeanTest extends EmbeddedBrokerTestSupport {
return new ActiveMQConnectionFactory(broker.getTransportConnectors().get(0).getPublishableConnectString()); return new ActiveMQConnectionFactory(broker.getTransportConnectors().get(0).getPublishableConnectString());
} }
@Override
protected BrokerService createBroker() throws Exception { protected BrokerService createBroker() throws Exception {
BrokerService answer = new BrokerService(); BrokerService answer = new BrokerService();
answer.setPersistent(true); answer.setPersistent(true);
@ -63,6 +67,7 @@ public class HealthViewMBeanTest extends EmbeddedBrokerTestSupport {
answer.getSystemUsage().getTempUsage().setLimit(1024 * 1024 * 64); answer.getSystemUsage().getTempUsage().setLimit(1024 * 1024 * 64);
answer.getSystemUsage().getStoreUsage().setLimit(1024 * 1024 * 64); answer.getSystemUsage().getStoreUsage().setLimit(1024 * 1024 * 64);
answer.setUseJmx(true); answer.setUseJmx(true);
answer.setSchedulerSupport(true);
// allow options to be visible via jmx // allow options to be visible via jmx
@ -84,6 +89,7 @@ public class HealthViewMBeanTest extends EmbeddedBrokerTestSupport {
message.writeBytes(new byte[1024 *1024]); message.writeBytes(new byte[1024 *1024]);
producer.send(message); producer.send(message);
} }
Thread.sleep(1000); Thread.sleep(1000);
String objectNameStr = broker.getBrokerObjectName().toString(); String objectNameStr = broker.getBrokerObjectName().toString();