mirror of https://github.com/apache/activemq.git
changed defaults for SystemUsage to 50GB for temp usage, 100GB for store usage and 64mb for memory usage. Added error and warning messages if the SysteMUsage limits cannot be met by the system git-svn-id: https://svn.apache.org/repos/asf/activemq/trunk@1235261 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
1d52f3b53c
commit
dbc661fd9b
|
@ -499,6 +499,7 @@ public class BrokerService implements Service {
|
||||||
if (isUseJmx()) {
|
if (isUseJmx()) {
|
||||||
startManagementContext();
|
startManagementContext();
|
||||||
}
|
}
|
||||||
|
|
||||||
getPersistenceAdapter().setUsageManager(getProducerSystemUsage());
|
getPersistenceAdapter().setUsageManager(getProducerSystemUsage());
|
||||||
getPersistenceAdapter().setBrokerName(getBrokerName());
|
getPersistenceAdapter().setBrokerName(getBrokerName());
|
||||||
LOG.info("Using Persistence Adapter: " + getPersistenceAdapter());
|
LOG.info("Using Persistence Adapter: " + getPersistenceAdapter());
|
||||||
|
@ -546,6 +547,7 @@ public class BrokerService implements Service {
|
||||||
}
|
}
|
||||||
LOG.info("ActiveMQ JMS Message Broker (" + getBrokerName() + ", " + brokerId + ") started");
|
LOG.info("ActiveMQ JMS Message Broker (" + getBrokerName() + ", " + brokerId + ") started");
|
||||||
getBroker().brokerServiceStarted();
|
getBroker().brokerServiceStarted();
|
||||||
|
checkSystemUsageLimits();
|
||||||
startedLatch.countDown();
|
startedLatch.countDown();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LOG.error("Failed to start ActiveMQ JMS Message Broker (" + getBrokerName() + ", " + brokerId + "). Reason: " + e, e);
|
LOG.error("Failed to start ActiveMQ JMS Message Broker (" + getBrokerName() + ", " + brokerId + "). Reason: " + e, e);
|
||||||
|
@ -918,9 +920,9 @@ public class BrokerService implements Service {
|
||||||
systemUsage.getMemoryUsage().setLimit(1024 * 1024 * 64); // Default
|
systemUsage.getMemoryUsage().setLimit(1024 * 1024 * 64); // Default
|
||||||
// 64
|
// 64
|
||||||
// Meg
|
// Meg
|
||||||
systemUsage.getTempUsage().setLimit(1024L * 1024 * 1024 * 100); // 10
|
systemUsage.getTempUsage().setLimit(1024L * 1024 * 1000 * 50); // 50
|
||||||
// Gb
|
// Gb
|
||||||
systemUsage.getStoreUsage().setLimit(1024L * 1024 * 1024 * 100); // 100
|
systemUsage.getStoreUsage().setLimit(1024L * 1024 * 1000 * 100); // 100
|
||||||
// GB
|
// GB
|
||||||
addService(this.systemUsage);
|
addService(this.systemUsage);
|
||||||
}
|
}
|
||||||
|
@ -1672,6 +1674,37 @@ public class BrokerService implements Service {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void checkSystemUsageLimits() throws IOException {
|
||||||
|
SystemUsage usage = getSystemUsage();
|
||||||
|
long memLimit = usage.getMemoryUsage().getLimit();
|
||||||
|
long jvmLimit = Runtime.getRuntime().maxMemory();
|
||||||
|
if (memLimit > jvmLimit){
|
||||||
|
LOG.error("Memory Usage for the Broker (" + memLimit/(1024*1024) + " mb) is more than the maximum available for the JVM: " + jvmLimit/(1024*1024) + " mb" );
|
||||||
|
}
|
||||||
|
if (getPersistenceAdapter() != null){
|
||||||
|
File dir = getPersistenceAdapter().getDirectory();
|
||||||
|
if (dir != null){
|
||||||
|
long storeLimit = usage.getStoreUsage().getLimit();
|
||||||
|
long dirFreeSpace = dir.getFreeSpace();
|
||||||
|
if (storeLimit > dirFreeSpace){
|
||||||
|
LOG.warn("Store limit is " + storeLimit/(1024*1024) + " mb, whilst the data directory: " + dir.getAbsolutePath() + " only has " + dirFreeSpace/(1024*1024) + " mb of free space");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
File tmpDir = getTmpDataDirectory();
|
||||||
|
if (tmpDir != null){
|
||||||
|
String tmpDirPath = tmpDir.getAbsolutePath();
|
||||||
|
long storeLimit = usage.getTempUsage().getLimit();
|
||||||
|
while (tmpDir != null && tmpDir.isDirectory()== false){
|
||||||
|
tmpDir = tmpDir.getParentFile();
|
||||||
|
}
|
||||||
|
long dirFreeSpace = tmpDir.getUsableSpace();
|
||||||
|
if (storeLimit > dirFreeSpace){
|
||||||
|
LOG.error("Temporary Store limit is " + storeLimit/(1024*1024) + " mb, whilst the temporary data directory: " + tmpDirPath + " only has " + dirFreeSpace/(1024*1024) + " mb of free space");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void stopAllConnectors(ServiceStopper stopper) {
|
public void stopAllConnectors(ServiceStopper stopper) {
|
||||||
for (Iterator<NetworkConnector> iter = getNetworkConnectors().iterator(); iter.hasNext();) {
|
for (Iterator<NetworkConnector> iter = getNetworkConnectors().iterator(); iter.hasNext();) {
|
||||||
NetworkConnector connector = iter.next();
|
NetworkConnector connector = iter.next();
|
||||||
|
|
|
@ -22,7 +22,6 @@ import java.util.Set;
|
||||||
|
|
||||||
import org.apache.activemq.Service;
|
import org.apache.activemq.Service;
|
||||||
import org.apache.activemq.broker.ConnectionContext;
|
import org.apache.activemq.broker.ConnectionContext;
|
||||||
import org.apache.activemq.broker.region.Destination;
|
|
||||||
import org.apache.activemq.command.ActiveMQDestination;
|
import org.apache.activemq.command.ActiveMQDestination;
|
||||||
import org.apache.activemq.command.ActiveMQQueue;
|
import org.apache.activemq.command.ActiveMQQueue;
|
||||||
import org.apache.activemq.command.ActiveMQTopic;
|
import org.apache.activemq.command.ActiveMQTopic;
|
||||||
|
@ -145,6 +144,11 @@ public interface PersistenceAdapter extends Service {
|
||||||
*/
|
*/
|
||||||
void setDirectory(File dir);
|
void setDirectory(File dir);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return the directory used by the persistence adaptor
|
||||||
|
*/
|
||||||
|
File getDirectory();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* checkpoint any
|
* checkpoint any
|
||||||
* @param sync
|
* @param sync
|
||||||
|
|
|
@ -92,6 +92,7 @@ public class JDBCPersistenceAdapter extends DataSourceSupport implements Persist
|
||||||
private boolean createTablesOnStartup = true;
|
private boolean createTablesOnStartup = true;
|
||||||
private DataSource lockDataSource;
|
private DataSource lockDataSource;
|
||||||
private int transactionIsolation;
|
private int transactionIsolation;
|
||||||
|
private File directory;
|
||||||
|
|
||||||
protected int maxProducersToAudit=1024;
|
protected int maxProducersToAudit=1024;
|
||||||
protected int maxAuditDepth=1000;
|
protected int maxAuditDepth=1000;
|
||||||
|
@ -638,6 +639,14 @@ public class JDBCPersistenceAdapter extends DataSourceSupport implements Persist
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setDirectory(File dir) {
|
public void setDirectory(File dir) {
|
||||||
|
this.directory=dir;
|
||||||
|
}
|
||||||
|
|
||||||
|
public File getDirectory(){
|
||||||
|
if (this.directory==null && brokerService != null){
|
||||||
|
this.directory=brokerService.getBrokerDataDirectory();
|
||||||
|
}
|
||||||
|
return this.directory;
|
||||||
}
|
}
|
||||||
|
|
||||||
// interesting bit here is proof that DB is ok
|
// interesting bit here is proof that DB is ok
|
||||||
|
|
|
@ -115,6 +115,7 @@ public class JournalPersistenceAdapter implements PersistenceAdapter, JournalEve
|
||||||
private final Runnable periodicCheckpointTask = createPeriodicCheckpointTask();
|
private final Runnable periodicCheckpointTask = createPeriodicCheckpointTask();
|
||||||
|
|
||||||
private TaskRunnerFactory taskRunnerFactory;
|
private TaskRunnerFactory taskRunnerFactory;
|
||||||
|
private File directory;
|
||||||
|
|
||||||
public JournalPersistenceAdapter() {
|
public JournalPersistenceAdapter() {
|
||||||
}
|
}
|
||||||
|
@ -730,6 +731,11 @@ public class JournalPersistenceAdapter implements PersistenceAdapter, JournalEve
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setDirectory(File dir) {
|
public void setDirectory(File dir) {
|
||||||
|
this.directory=dir;
|
||||||
|
}
|
||||||
|
|
||||||
|
public File getDirectory(){
|
||||||
|
return directory;
|
||||||
}
|
}
|
||||||
|
|
||||||
public long size(){
|
public long size(){
|
||||||
|
|
|
@ -62,7 +62,9 @@ public class JournalPersistenceAdapterFactory extends DataSourceSupport implemen
|
||||||
if (!useJournal) {
|
if (!useJournal) {
|
||||||
return jdbcPersistenceAdapter;
|
return jdbcPersistenceAdapter;
|
||||||
}
|
}
|
||||||
return new JournalPersistenceAdapter(getJournal(), jdbcPersistenceAdapter, getTaskRunnerFactory());
|
JournalPersistenceAdapter result = new JournalPersistenceAdapter(getJournal(), jdbcPersistenceAdapter, getTaskRunnerFactory());
|
||||||
|
result.setDirectory(getDataDirectoryFile());
|
||||||
|
return result;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -190,6 +190,10 @@ public class MemoryPersistenceAdapter implements PersistenceAdapter {
|
||||||
public void setDirectory(File dir) {
|
public void setDirectory(File dir) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public File getDirectory(){
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
public void checkpoint(boolean sync) throws IOException {
|
public void checkpoint(boolean sync) throws IOException {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue