All Downloads are FREE. Search and download functionalities are using the official Maven repository.

scouterx.webapp.framework.client.model.AgentModelThread Maven / Gradle / Ivy

There is a newer version: 2.20.0
Show newest version
/*
 *  Copyright 2015 the original author or authors. 
 *  @https://github.com/scouter-project/scouter
 *
 *  Licensed 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 scouterx.webapp.framework.client.model;

import scouter.lang.counters.CounterEngine;
import scouter.lang.pack.ObjectPack;
import scouter.lang.value.ListValue;
import scouter.net.RequestCmd;
import scouter.util.ThreadUtil;
import scouterx.webapp.framework.client.net.LoginMgr;
import scouterx.webapp.framework.client.net.TcpProxy;
import scouterx.webapp.framework.client.server.Server;
import scouterx.webapp.framework.client.server.ServerManager;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeSet;

public class AgentModelThread extends Thread {

	private static AgentModelThread instance = null;

	public final static synchronized AgentModelThread getInstance() {
		if (instance == null) {
			instance = new AgentModelThread();
			instance.setDaemon(true);
			instance.setName(ThreadUtil.getName(instance));
			instance.start();
		}
		return instance;
	}

	private Map agentMap = new HashMap();
	
	ArrayList allAgentList = new ArrayList();
	
	private boolean existUnknownType;
	
	public ArrayList getAgentPackList(){
		return allAgentList;
	}

	@Override
	public void run() {
		while (brun) {
			fetchObjectList();
			for (int i = 0; i < 20 && brun; i++) {
				ThreadUtil.sleep(500);
			}
		}
	}

	public synchronized void fetchObjectList() {
		Map tempAgentMap = new HashMap();
		ArrayList objectPackList = new ArrayList();
		boolean existUnknownType = false;
		existServerSet.clear();
		Set serverIdSet = ServerManager.getInstance().getOpenServerIdList();
		if (serverIdSet.size() > 0) {
			Integer[] serverIds = serverIdSet.toArray(new Integer[serverIdSet.size()]);
			for (int serverId : serverIds) {
				Server server = ServerManager.getInstance().getServer(serverId);
				if (server.isOpen() == false || server.getSession() == 0) {
					continue;
				}
				LoginMgr.refreshCounterEngine(server);
				CounterEngine counterEngine = server.getCounterEngine();
				TcpProxy proxy = TcpProxy.getTcpProxy(serverId);
				try {
					final ArrayList agentList = new ArrayList();
					proxy.process(RequestCmd.OBJECT_LIST_REAL_TIME, null, in -> {
						ObjectPack o = (ObjectPack) in.readPack();
						agentList.add(o);
					});
					objectPackList.addAll(agentList);
					for (int i = 0; agentList != null && i < agentList.size(); i++) {
						ObjectPack m = agentList.get(i);
						String objType = m.objType;
						int objHash = m.objHash;
						String objName = m.objName;
						if (tempAgentMap.containsKey(objHash)) {
							AgentObject oldAgent = tempAgentMap.get(objHash);
							if (oldAgent.isAlive()) {
								continue;
							}
						}
						AgentObject agentObject = new AgentObject(objType, objHash, objName, serverId);
						tempAgentMap.put(objHash, agentObject);
						agentObject.objPack = m;
						if (counterEngine.isUnknownObjectType(objType)) {
							existUnknownType = true;
						}
					}
					if (agentList.size() > 0) {
						existServerSet.add(serverId);
					}
				} catch (Exception e) {
					e.printStackTrace();
				} finally {
					TcpProxy.close(proxy);
				}
			}
		}
		
		allAgentList = objectPackList;
		agentMap = tempAgentMap;
		this.existUnknownType = existUnknownType;
	}
	
	private Set existServerSet = new HashSet();
	
	public Set existServerSet() {
		return existServerSet;
	}
	
	public AgentObject getAgentObject(int objHash) {
		return agentMap.get(objHash);
	}
	
	public Map getAgentObjectMap() {
		return agentMap;
	}
	
	public static void removeInactive() {
		Set serverIdSet = ServerManager.getInstance().getOpenServerIdList();
		if (serverIdSet.size() > 0) {
			Integer[] serverIds = serverIdSet.toArray(new Integer[serverIdSet.size()]);
			for (int serverId : serverIds) {
				TcpProxy proxy = TcpProxy.getTcpProxy(serverId);
				try {
					proxy.process(RequestCmd.OBJECT_REMOVE_INACTIVE, null);
				} finally {
					TcpProxy.close(proxy);
				}
			}
		}
	}
	
	public Set getAgentObjectByServerId (int serverId) {
		Set set = new HashSet();
		for (AgentObject obj : agentMap.values()) {
			if (serverId == obj.getServerId()) {
				set.add(obj);
			}
		}
		return set;
	}
	
	public Set getObjectSetByServerId (int serverId) {
		Set set = new HashSet();
		for (AgentObject obj : agentMap.values()) {
			if (serverId == obj.getServerId()) {
				set.add(obj.objHash);
			}
		}
		return set;
	}
	
	public AgentObject[] getObjectList () {
		return agentMap.values().toArray(new AgentObject[agentMap.size()]);
	}
	
	public Set getCurrentObjTypeSet() {
		Set typeSet = new HashSet();
		Iterator keys = agentMap.keySet().iterator();
		while (keys.hasNext()) {
			AgentObject agent = agentMap.get(keys.next());
			typeSet.add(agent.getObjType());
		}
		return typeSet;
	}
	
	public boolean existUnknownType() {
		return this.existUnknownType;
	}
	
	public Set getObjectList(String objType) {
		Set set = new HashSet();
		Iterator keys = agentMap.keySet().iterator();
		while (keys.hasNext()) {
			AgentObject agent = agentMap.get(keys.next());
			if(objType.equals(agent.getObjType())) {
				set.add(agent.getObjHash());
			}
		}
		return set;
	}
	
	public ListValue getLiveObjHashLV(int serverId, String objType) {
		ListValue lv = new ListValue();
		for (AgentObject obj : agentMap.values()) {
			if (serverId == obj.getServerId() && obj.isAlive() && objType.equals(obj.getObjType()) ) {
				lv.add(obj.objHash);
			}
		}
		return lv;
	}
	
	public Set getCurrentObjectTypeList(int serverId) {
		Set objectTypeList = new TreeSet(); 
		for (AgentObject agent : agentMap.values()) {
			if (agent.getServerId() == serverId) {
				String objType = agent.getObjType();
				objectTypeList.add(objType);
			}
		}
		return objectTypeList;
	}
	
	public boolean existFamilyType(int serverId, String family) {
		CounterEngine engine = ServerManager.getInstance().getServer(serverId).getCounterEngine();
		for (AgentObject agent : agentMap.values()) {
			if (agent.getServerId() == serverId && engine.isChildOf(agent.getObjType(), family)) {
				return true;
			}
		}
		return false;
	}

	private boolean brun = true;

	public void shutdown() {
		brun = false;
	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy