mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			119 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			119 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| // Licensed to the Apache Software Foundation (ASF) under one
 | |
| // or more contributor license agreements.  See the NOTICE file
 | |
| // distributed with this work for additional information
 | |
| // regarding copyright ownership.  The ASF licenses this file
 | |
| // to you under the Apache License, Version 2.0 (the
 | |
| // "License"); you may not use this file except in compliance
 | |
| // with the License.  You may obtain a copy of the License at
 | |
| //
 | |
| //   http://www.apache.org/licenses/LICENSE-2.0
 | |
| //
 | |
| // Unless required by applicable law or agreed to in writing,
 | |
| // software distributed under the License is distributed on an
 | |
| // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 | |
| // KIND, either express or implied.  See the License for the
 | |
| // specific language governing permissions and limitations
 | |
| // under the License.
 | |
| package com.cloud.ha;
 | |
| 
 | |
| import java.util.Date;
 | |
| import java.util.Map;
 | |
| import java.util.concurrent.TimeUnit;
 | |
| 
 | |
| import javax.ejb.Local;
 | |
| import javax.inject.Inject;
 | |
| import javax.naming.ConfigurationException;
 | |
| 
 | |
| import org.springframework.stereotype.Component;
 | |
| 
 | |
| import com.cloud.alert.AlertManager;
 | |
| import com.cloud.configuration.dao.ConfigurationDao;
 | |
| import com.cloud.server.ManagementServer;
 | |
| import com.cloud.usage.dao.UsageJobDao;
 | |
| import com.cloud.utils.component.ComponentLocator;
 | |
| import com.cloud.utils.db.Transaction;
 | |
| 
 | |
| @Component
 | |
| @Local(value={HighAvailabilityManager.class})
 | |
| public class HighAvailabilityManagerExtImpl extends HighAvailabilityManagerImpl {
 | |
| 	
 | |
|     @Inject
 | |
| 	UsageJobDao _usageJobDao;
 | |
|     ConfigurationDao configDao;
 | |
|     
 | |
| 	@Override
 | |
| 	public boolean configure(final String name, final Map<String, Object> xmlParams) throws ConfigurationException {
 | |
| 		super.configure(name, xmlParams);
 | |
| 
 | |
| 		ComponentLocator locator = ComponentLocator.getLocator(ManagementServer.Name);
 | |
|         
 | |
|         configDao = locator.getDao(ConfigurationDao.class);
 | |
|         if (configDao == null) 
 | |
|         {
 | |
|         	s_logger.warn("Unable to get a configuration dao to check config value for enableUsageServer");
 | |
|         	return false;
 | |
|         }
 | |
| 
 | |
|         return true;
 | |
| 	}
 | |
| 
 | |
| 	@Override
 | |
|     public boolean start() 
 | |
| 	{
 | |
| 		super.start();
 | |
| 		
 | |
| 	        
 | |
|         boolean enableUsage = new Boolean(configDao.getValue("enable.usage.server"));
 | |
|         
 | |
|         //By default, usage is enabled for production
 | |
|         //Devs might override this value to disable usage in their setup
 | |
|         if(enableUsage)
 | |
|         {
 | |
|         	_executor.scheduleAtFixedRate(new UsageServerMonitorTask(), 60*60, 10*60, TimeUnit.SECONDS); // schedule starting in one hour to execute every 10 minutes
 | |
|         }
 | |
|         
 | |
|         return true;
 | |
|     }
 | |
| 	
 | |
| 	protected class UsageServerMonitorTask implements Runnable {
 | |
|         @Override
 | |
|         public void run() {
 | |
|             if (s_logger.isInfoEnabled()) {
 | |
|                 s_logger.info("checking health of usage server");
 | |
|             }
 | |
| 
 | |
|             try {
 | |
|                 boolean isRunning = false;
 | |
|                 Transaction txn = Transaction.open(Transaction.USAGE_DB);
 | |
|                 try {
 | |
|                     Date lastHeartbeat = _usageJobDao.getLastHeartbeat();
 | |
|                     if (lastHeartbeat != null) {
 | |
|                         long sinceLastHeartbeat = System.currentTimeMillis() - lastHeartbeat.getTime();
 | |
|                         if (sinceLastHeartbeat <= (10 * 60 * 1000)) {
 | |
|                             // if it's been less than 10 minutes since the last heartbeat, then it appears to be running, otherwise send an alert
 | |
|                             isRunning = true;
 | |
|                         }
 | |
|                     }
 | |
|                     if (s_logger.isDebugEnabled()) {
 | |
|                         s_logger.debug("usage server running? " + isRunning + ", heartbeat: " + lastHeartbeat);
 | |
|                     }
 | |
|                 } finally {
 | |
|                     txn.close();
 | |
| 
 | |
|                     // switch back to VMOPS db
 | |
|                     Transaction swap = Transaction.open(Transaction.CLOUD_DB);
 | |
|                     swap.close();
 | |
|                 }
 | |
| 
 | |
|                 if (!isRunning) {
 | |
|                     _alertMgr.sendAlert(AlertManager.ALERT_TYPE_USAGE_SERVER, 0, new Long(0), "No usage server process running", "No usage server process has been detected, some attention is required");
 | |
|                 } else {
 | |
|                     _alertMgr.clearAlert(AlertManager.ALERT_TYPE_USAGE_SERVER, 0, 0);
 | |
|                 }
 | |
|             } catch (Exception ex) {
 | |
|                 s_logger.warn("Error while monitoring usage job", ex);
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 |