You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@uima.apache.org by de...@apache.org on 2013/04/18 16:47:47 UTC

svn commit: r1469353 - in /uima/sandbox/uima-ducc/trunk/uima-ducc-common/src/main/java/org/apache/uima/ducc/common: mq/ mq/MqHelper.java utils/DuccPropertiesHelper.java

Author: degenaro
Date: Thu Apr 18 14:47:47 2013
New Revision: 1469353

URL: http://svn.apache.org/r1469353
Log:
UIMA-2819 DUCC orchestrator (OR) re-factor reaper for re-usability & employ broker.name correctly

Added:
    uima/sandbox/uima-ducc/trunk/uima-ducc-common/src/main/java/org/apache/uima/ducc/common/mq/
    uima/sandbox/uima-ducc/trunk/uima-ducc-common/src/main/java/org/apache/uima/ducc/common/mq/MqHelper.java
    uima/sandbox/uima-ducc/trunk/uima-ducc-common/src/main/java/org/apache/uima/ducc/common/utils/DuccPropertiesHelper.java

Added: uima/sandbox/uima-ducc/trunk/uima-ducc-common/src/main/java/org/apache/uima/ducc/common/mq/MqHelper.java
URL: http://svn.apache.org/viewvc/uima/sandbox/uima-ducc/trunk/uima-ducc-common/src/main/java/org/apache/uima/ducc/common/mq/MqHelper.java?rev=1469353&view=auto
==============================================================================
--- uima/sandbox/uima-ducc/trunk/uima-ducc-common/src/main/java/org/apache/uima/ducc/common/mq/MqHelper.java (added)
+++ uima/sandbox/uima-ducc/trunk/uima-ducc-common/src/main/java/org/apache/uima/ducc/common/mq/MqHelper.java Thu Apr 18 14:47:47 2013
@@ -0,0 +1,192 @@
+/*
+ * 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 org.apache.uima.ducc.common.mq;
+
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.Hashtable;
+
+import javax.management.MBeanServerConnection;
+import javax.management.MBeanServerInvocationHandler;
+import javax.management.MalformedObjectNameException;
+import javax.management.ObjectName;
+import javax.management.remote.JMXConnector;
+import javax.management.remote.JMXConnectorFactory;
+import javax.management.remote.JMXServiceURL;
+
+import org.apache.activemq.broker.jmx.BrokerViewMBean;
+import org.apache.uima.ducc.common.exception.DuccConfigurationException;
+import org.apache.uima.ducc.common.exception.DuccRuntimeException;
+import org.apache.uima.ducc.common.utils.DuccPropertiesHelper;
+import org.apache.uima.ducc.common.utils.DuccPropertiesResolver;
+
+public class MqHelper {
+	
+	private String broker_hostname = null;
+	private String broker_jmx_port = null;
+	private String broker_name = null;
+	private String broker_url = null;
+	private String objectName = null;
+	private ObjectName activeMQ = null;
+	private BrokerViewMBean mbean = null;
+	private JMXServiceURL url = null;
+	private JMXConnector jmxc = null;
+	private MBeanServerConnection conn = null;
+	
+	private DuccPropertiesResolver duccPropertiesResolver = null;
+	
+	public MqHelper() throws IOException, MalformedObjectNameException, NullPointerException, DuccConfigurationException {
+		resolve();
+		init();
+		connect();
+	}
+	
+	public MqHelper(String broker_hostname, String broker_jmx_port, String broker_name) throws DuccRuntimeException, DuccConfigurationException, MalformedObjectNameException, NullPointerException, IOException {
+		nonempty("broker_host_name", broker_hostname);
+		nonempty("broker_jmx_port", broker_jmx_port);
+		nonempty("broker_name", broker_name);
+		init();
+		connect();
+	}
+	
+	public String get_broker_hostname() {
+		return broker_hostname;
+	}
+	
+	public String get_broker_jmx_port() {
+		return broker_jmx_port;
+	}
+	
+	public String get_broker_name() {
+		return broker_name;
+	}
+	
+	public String get_broker_url() {
+		return broker_url;
+	}
+	
+	private void nonempty(String key, String value) throws DuccRuntimeException {
+		if(value == null) {
+			throw new DuccRuntimeException("missing value for "+key);
+		}
+	}
+	
+	private void init() throws DuccConfigurationException {
+		broker_url = "service:jmx:rmi:///jndi/rmi://"+broker_hostname+":"+broker_jmx_port+"/jmxrmi";
+		objectName = "org.apache.activemq:BrokerName="+broker_name+",Type=Broker";
+	}
+	
+	private void resolve() throws DuccConfigurationException {
+		if(broker_hostname == null) {
+			broker_hostname = getDuccProperty(DuccPropertiesResolver.ducc_broker_hostname);
+		}
+		if(broker_jmx_port == null) {
+			broker_jmx_port = getDuccProperty(DuccPropertiesResolver.ducc_broker_jmx_port);
+		}
+		if(broker_name == null) {
+			broker_name = getDuccProperty(DuccPropertiesResolver.ducc_broker_name);
+		}
+	}
+	
+	private void configure() {
+		duccPropertiesResolver = DuccPropertiesHelper.configure();
+	}
+	
+	private String getDuccProperty(String key) throws DuccConfigurationException {
+		if(duccPropertiesResolver == null) {
+			configure();
+		}
+		String value = duccPropertiesResolver.getFileProperty(key);
+		if(value == null) {
+			throw new DuccConfigurationException("ducc.properties missing "+key);
+		}
+		value = value.trim();
+		if(value.length() == 0) {
+			throw new DuccConfigurationException("ducc.properties undefined "+key);
+		}
+		return value;
+	}
+	
+	public void connect() throws IOException, MalformedObjectNameException, NullPointerException {
+		url = new JMXServiceURL(broker_url);
+		jmxc = JMXConnectorFactory.connect(url);
+		conn = jmxc.getMBeanServerConnection();
+		activeMQ = new ObjectName(objectName);
+		mbean = (BrokerViewMBean) MBeanServerInvocationHandler.newProxyInstance(conn, activeMQ, BrokerViewMBean.class, true);
+	}
+	
+	public String getBrokerUrl() {
+		return broker_url;
+	}
+	
+	private boolean isEqual(String a, String b) {
+		boolean retVal = false;
+		if(a != null) {
+			if(b != null) {
+				if(a.equals(b)) {
+					retVal = true;
+				}
+			}
+		}
+		return retVal;
+	}
+	
+	public ArrayList<String> getQueueList() {
+		ArrayList<String> qNames = new ArrayList<String>();
+		ObjectName[] queues = mbean.getQueues();
+		for( ObjectName queue : queues ) {
+			Hashtable<String, String> propertyTable = queue.getKeyPropertyList();
+			if(propertyTable != null) {
+				String type = propertyTable.get("Type");
+				String destination = propertyTable.get("Destination");
+				if(isEqual(type, "Queue")) {
+					qNames.add(destination);
+				}
+			}
+		}
+		return qNames;
+	}
+	
+	public boolean removeQueue(String qName) throws Exception {
+		boolean retVal = false;
+		mbean.removeQueue(qName);
+		retVal = true;
+		return retVal;
+	}
+	
+	public static void main(String[] args) {
+		try {
+			MqHelper mqManager;
+			mqManager = new MqHelper();
+			System.out.println(mqManager.getBrokerUrl());
+			ArrayList<String> qList = mqManager.getQueueList();
+			for(String qName : qList) {
+				System.out.println(qName);
+			}
+		} catch (MalformedObjectNameException e) {
+			e.printStackTrace();
+		} catch (NullPointerException e) {
+			e.printStackTrace();
+		} catch (IOException e) {
+			e.printStackTrace();
+		} catch (DuccConfigurationException e) {
+			e.printStackTrace();
+		}
+	}
+}

Added: uima/sandbox/uima-ducc/trunk/uima-ducc-common/src/main/java/org/apache/uima/ducc/common/utils/DuccPropertiesHelper.java
URL: http://svn.apache.org/viewvc/uima/sandbox/uima-ducc/trunk/uima-ducc-common/src/main/java/org/apache/uima/ducc/common/utils/DuccPropertiesHelper.java?rev=1469353&view=auto
==============================================================================
--- uima/sandbox/uima-ducc/trunk/uima-ducc-common/src/main/java/org/apache/uima/ducc/common/utils/DuccPropertiesHelper.java (added)
+++ uima/sandbox/uima-ducc/trunk/uima-ducc-common/src/main/java/org/apache/uima/ducc/common/utils/DuccPropertiesHelper.java Thu Apr 18 14:47:47 2013
@@ -0,0 +1,35 @@
+/*
+ * 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 org.apache.uima.ducc.common.utils;
+
+import java.util.Properties;
+
+public class DuccPropertiesHelper {
+	
+	public static DuccPropertiesResolver configure() {
+		String key = "DUCC_HOME";
+		String value = System.getenv(key);
+		if(value != null) {
+			Properties properties = System.getProperties();
+			properties.setProperty(key, value);
+			System.setProperties(properties);
+		}
+		return DuccPropertiesResolver.getInstance();
+	}
+}