當前位置: 首頁>>代碼示例>>Java>>正文


Java SharedNotificationExecutor類代碼示例

本文整理匯總了Java中com.heliosapm.utils.jmx.SharedNotificationExecutor的典型用法代碼示例。如果您正苦於以下問題:Java SharedNotificationExecutor類的具體用法?Java SharedNotificationExecutor怎麽用?Java SharedNotificationExecutor使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


SharedNotificationExecutor類屬於com.heliosapm.utils.jmx包,在下文中一共展示了SharedNotificationExecutor類的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: ZooKeepPublisher

import com.heliosapm.utils.jmx.SharedNotificationExecutor; //導入依賴的package包/類
/**
 * Creates a new ZooKeepPublisher
 */
public ZooKeepPublisher() {
	super(SharedNotificationExecutor.getInstance(), NOTIF_INFOS);
	connect = ConfigurationHelper.getSystemThenEnvProperty(CONFIG_CONNECT, DEFAULT_CONNECT);
	timeout = ConfigurationHelper.getIntSystemThenEnvProperty(CONFIG_TIMEOUT, DEFAULT_TIMEOUT);
	adminUrl = "http://" + hostName() + ":" + ConfigurationHelper.getIntSystemThenEnvProperty(CONFIG_PORT, 7560) + "/streamhubadmin";
	//+ ConfigurationHelper.getSystemThenEnvProperty("server.context-path", "/" + ROOT_ADMIN_NODE.replace("/", ""));
	log.info("Advertised Admin URL: [{}]", adminUrl);
}
 
開發者ID:nickman,項目名稱:HeliosStreams,代碼行數:12,代碼來源:ZooKeepPublisher.java

示例2: AgentName

import com.heliosapm.utils.jmx.SharedNotificationExecutor; //導入依賴的package包/類
private AgentName() {
	super(SharedNotificationExecutor.getInstance(), NOTIF_INFOS);
	forceLowerCase = ConfigurationHelper.getBooleanSystemThenEnvProperty(PROP_FORCE_LOWER_CASE, DEFAULT_FORCE_LOWER_CASE);
	shortHostName = ConfigurationHelper.getBooleanSystemThenEnvProperty(PROP_USE_SHORT_HOSTNAMES, DEFAULT_USE_SHORT_HOSTNAMES); 				
	loadExtraTags();
	getAppName();
	getHostName();
	initBufferized();
	JMXHelper.registerMBean(this, OBJECT_NAME);
	sendInitialNotif();
}
 
開發者ID:nickman,項目名稱:HeliosStreams,代碼行數:12,代碼來源:AgentName.java

示例3: fireAgentNameChange

import com.heliosapm.utils.jmx.SharedNotificationExecutor; //導入依賴的package包/類
/**
 * Fires an AgentName change event
 * @param app The new app name, or null if only the host changed
 * @param host The new host name, or null if only the app changed
 */
private void fireAgentNameChange(final String app, final String host) {
	if(app==null && host==null) return;
	Map<String, String> userData = new HashMap<String, String>(2);
	String notifType = null;
	if(app!=null && host!=null) {
		notifType = NOTIF_BOTH_NAME_CHANGE;
		userData.put(APP_TAG, app);
		userData.put(HOST_TAG, host);
		
	} else {
		if(app==null) {
			notifType = NOTIF_HOST_NAME_CHANGE;				
			userData.put(HOST_TAG, host);				
		} else {
			notifType = NOTIF_APP_NAME_CHANGE;				
			userData.put(APP_TAG, app);				
		}
	}
	final Notification n = new Notification(notifType, OBJECT_NAME, notifSerial.incrementAndGet(), System.currentTimeMillis(), "AgentName reset. New Id: [" + appName + "@" + hostName + "]");		
	n.setUserData(userData);
	sendNotification(n);
	for(final AgentNameChangeListener listener: listeners) {
		SharedNotificationExecutor.getInstance().execute(new Runnable(){
			@Override
			public void run() {
				listener.onAgentNameChange(app, host);
			}
		});
		
	}
}
 
開發者ID:nickman,項目名稱:HeliosStreams,代碼行數:37,代碼來源:AgentName.java

示例4: ManagedScript

import com.heliosapm.utils.jmx.SharedNotificationExecutor; //導入依賴的package包/類
/**
	 * Creates a new ManagedScript
	 * @param initialBindings Initial bindings required for instantiation
	 */
	@SuppressWarnings("unchecked")
	public ManagedScript(final Map<String, Object> initialBindings) {
		super(new Binding(initialBindings==null ? new HashMap<String, Object>() : initialBindings));
		springMode = CollectorServer.isSpringMode();
		cache = GlobalCacheService.getInstance();
		dependencyManager = new DependencyManager<ManagedScript>(this, (Class<ManagedScript>) this.getClass());
		executionService = CollectorExecutionService.getInstance();
		broadcaster = new NotificationBroadcasterSupport(SharedNotificationExecutor.getInstance(), NOTIF_INFOS);
		for(Field f: getClass().getDeclaredFields()) {
			fields.put(f.getName(), f);
//			final groovy.transform.Field fieldAnn = f.getAnnotation(groovy.transform.Field.class);
			final Dependency fieldAnn = f.getAnnotation(Dependency.class);
			if(fieldAnn!=null) {
				f.setAccessible(true);
			}
		}
		packageSegs = StringHelper.splitString(getClass().getPackage().getName(), '.');
		packageElems = packageSegs.length;
		packageKey = getClass().getPackage().getName();	
		regionKey = packageKey.substring(packageKey.indexOf('.')+1);
		classKey = getClass().getName();		
		hystrixEnabled.set(ConfigurationHelper.getBooleanSystemThenEnvProperty(CONFIG_HYSTRIX_ENABLED, DEFAULT_HYSTRIX_ENABLED));
		if(hystrixEnabled.get()) {
			commandBuilder = HystrixCommandFactory.getInstance().builder(CONFIG_HYSTRIX, packageSegs[0] + packageSegs[1])
				.andCommandKey(classKey)
				.andThreadPoolKey(regionKey.replace('.', '-'))
				.build();
		}
	}
 
開發者ID:nickman,項目名稱:HeliosStreams,代碼行數:34,代碼來源:ManagedScript.java

示例5: shutdown

import com.heliosapm.utils.jmx.SharedNotificationExecutor; //導入依賴的package包/類
/**
 * <p>Closes the groovy sql instance and removes all related entries from cache, calls super, then emits a close event</p>
 * {@inheritDoc}
 * @see com.zaxxer.hikari.HikariDataSource#shutdown()
 */
@Override
public void shutdown() {
	try { groovySql.close(); } catch (Exception x) {/* No Op */}
	super.shutdown();		
	for(final DataSourceListener listener: listeners) {
		SharedNotificationExecutor.getInstance().execute(new Runnable(){
			@Override
			public void run() {
				listener.onDataSourceStopped(poolName, dsCacheKey, groovydsCacheKey);					
			}
		});
	}
	listeners.clear();
}
 
開發者ID:nickman,項目名稱:HeliosStreams,代碼行數:20,代碼來源:ManagedHikariDataSource.java

示例6: EndpointListener

import com.heliosapm.utils.jmx.SharedNotificationExecutor; //導入依賴的package包/類
/**
 * Creates a new EndpointPubSub
 * @param listeners an optional array of endpoint listeners to add
 */
private EndpointListener(final AdvertisedEndpointListener...listeners) {
	super(SharedNotificationExecutor.getInstance(), NOTIF_INFOS);
	for(AdvertisedEndpointListener listener : listeners) {
		instance.addEndpointListener(listener);
	}		
	CloseableService.getInstance().register(this);
	log.info("ZK_CONNECT_CONF: [{}]", System.getProperty(ZK_CONNECT_CONF, "undefined"));
	zkConnect = ConfigurationHelper.getSystemThenEnvProperty(ZK_CONNECT_CONF, ZK_CONNECT_DEFAULT);
	log.info("EndpointListener ZooKeep Connect: [{}]", zkConnect);
	serviceType = ConfigurationHelper.getSystemThenEnvProperty(SERVICE_TYPE_CONF, SERVICE_TYPE_DEFAULT);
	connectionTimeout = ConfigurationHelper.getIntSystemThenEnvProperty(DISC_CONN_TO_CONF, DISC_CONN_TO_DEFAULT);
	sessionTimeout = ConfigurationHelper.getIntSystemThenEnvProperty(DISC_SESS_TO_CONF, DISC_SESS_TO_DEFAULT);
	curator = CuratorFrameworkFactory.newClient(zkConnect, sessionTimeout, connectionTimeout, new ExponentialBackoffRetry( 1000, 3 ));
	curator.getConnectionStateListenable().addListener(this);
	curator.start();
	treeCache = TreeCache.newBuilder(curator, serviceType) 
		.setCacheData(true)
		.setCreateParentNodes(true)
		.setExecutor(executor)
		.setMaxDepth(5)
		.build();
	treeCache.getListenable().addListener(this, executor);
	try {
		JMXHelper.registerMBean(OBJECT_NAME, this);
	} catch (Exception ex) {
		log.warn("Failed to register management interface. Will continue without.", ex);
	}		
	connectClients();
}
 
開發者ID:nickman,項目名稱:HeliosStreams,代碼行數:34,代碼來源:EndpointListener.java

示例7: DropWizardMetrics

import com.heliosapm.utils.jmx.SharedNotificationExecutor; //導入依賴的package包/類
/**
 * Creates a new DropWizardMetrics
 * @param objectName The object name to register this mbean with
 * @param description A description for the metric set to be exposed by this mbean
 */
public DropWizardMetrics(final ObjectName objectName, final String description) {
	super(DropWizardMetricsMXBean.class, true, new NotificationBroadcasterSupport(SharedNotificationExecutor.getInstance(), notifInfos));
	if(objectName==null) throw new IllegalArgumentException("The passed object name was null");
	this.objectName = objectName;
	this.description = (description==null || description.trim().isEmpty()) ? "DropWizard Metric Set" : description.trim();		
}
 
開發者ID:nickman,項目名稱:HeliosStreams,代碼行數:12,代碼來源:DropWizardMetrics.java

示例8: fireConnected

import com.heliosapm.utils.jmx.SharedNotificationExecutor; //導入依賴的package包/類
/**
 * Fires a connected event if the channel group has at least one channel
 * and the current state is disconnected.
 */
protected void fireConnected() {
	if(!channels.isEmpty() && !connectionsAvailable.getAndSet(true)) {
		for(final ConnectionStateListener listener: connectedStateListeners) {
			SharedNotificationExecutor.getInstance().execute(new Runnable(){
				@Override
				public void run() {
					listener.onConnected();
				}
			});
		}
	}
}
 
開發者ID:nickman,項目名稱:HeliosStreams,代碼行數:17,代碼來源:NetWriter.java

示例9: fireDisconnected

import com.heliosapm.utils.jmx.SharedNotificationExecutor; //導入依賴的package包/類
/**
 * Fires a disconnected event if the channel group is empty
 * and the current state is connected.
 */
protected void fireDisconnected() {
	if(channels.isEmpty() && connectionsAvailable.getAndSet(false)) {
		for(final ConnectionStateListener listener: connectedStateListeners) {
			SharedNotificationExecutor.getInstance().execute(new Runnable(){
				@Override
				public void run() {
					listener.onDisconnected(!keepReconnecting.get());
				}
			});
		}		
	}
}
 
開發者ID:nickman,項目名稱:HeliosStreams,代碼行數:17,代碼來源:NetWriter.java

示例10: AppMetric

import com.heliosapm.utils.jmx.SharedNotificationExecutor; //導入依賴的package包/類
/**
 * Creates a new AppMetric
 * @param metric The metric
 */
public AppMetric(final Metric metric) {
	super(SharedNotificationExecutor.getInstance(), NOTIFS);
	if(metric==null) throw new IllegalArgumentException("The passed metric was null");
	this.metric = metric;
	objectName = this.metric.toObjectName();
	lastActivity = System.currentTimeMillis();
}
 
開發者ID:nickman,項目名稱:tsdblite,代碼行數:12,代碼來源:AppMetric.java

示例11: GlobalCacheService

import com.heliosapm.utils.jmx.SharedNotificationExecutor; //導入依賴的package包/類
private GlobalCacheService() {		
	super(SharedNotificationExecutor.getInstance(), NOTIF_INFOS);
	JMXHelper.registerMBean(this, objectName);
}
 
開發者ID:nickman,項目名稱:HeliosStreams,代碼行數:5,代碼來源:GlobalCacheService.java

示例12: Blacklist

import com.heliosapm.utils.jmx.SharedNotificationExecutor; //導入依賴的package包/類
private Blacklist() {
	super(SharedNotificationExecutor.getInstance(), INFOS);
	JMXHelper.registerMBean(this, OBJECT_NAME);
}
 
開發者ID:nickman,項目名稱:HeliosStreams,代碼行數:5,代碼來源:Blacklist.java


注:本文中的com.heliosapm.utils.jmx.SharedNotificationExecutor類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。