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

uw.task.api.TaskAPI Maven / Gradle / Ivy

package uw.task.api;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.web.client.RestTemplateBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.stereotype.Component;
import org.springframework.util.LinkedMultiValueMap;
import org.springframework.util.MultiValueMap;
import org.springframework.web.client.RestTemplate;

import com.google.common.util.concurrent.ThreadFactoryBuilder;

import uw.task.TaskData;
import uw.task.conf.TaskProperties;
import uw.task.entity.TaskCronerConfig;
import uw.task.entity.TaskCronerLog;
import uw.task.entity.TaskRunnerConfig;
import uw.task.util.LeaderVote;

/**
 * 对应服务器端的API接口实现。
 * 
 * @author axeon
 *
 */
@Component
public class TaskAPI {

	private static final Logger log = LoggerFactory.getLogger(TaskAPI.class);

	@Autowired
	private TaskProperties taskProperties;

	@Autowired
	private RestTemplate restTemplate;

	/**
	 * 专门给日志发送使用的线程池。
	 */
	private ExecutorService es = Executors
			.newCachedThreadPool(new ThreadFactoryBuilder().setDaemon(true).setNameFormat("TaskAPI-%d").build());

	/**
	 * Rest配置
	 * 
	 * @param builder
	 * @return
	 */
	@Bean
	public RestTemplate restTemplate(RestTemplateBuilder builder) {
		return builder.build();
	}

	/**
	 * 本机的外网IP
	 */
	private String hostIp = "";

	/**
	 * 主机配置名
	 */
	private List hostConfig = null;
	
	/**
	 * @return the hostIp
	 */
	public String getHostIp() {
		return hostIp;
	}
	
	
	/**
	 * @param hostConfig the hostConfig to set
	 */
	public void setHostConfig(List hostConfig) {
		this.hostConfig = hostConfig;
	}

	/**
	 * 更新当前主机状态,返回主机IP地址。
	 */
	public String updateHostStatus() {
		String ip = "";
		MultiValueMap paramMap = new LinkedMultiValueMap<>();
		paramMap.add("uuid", LeaderVote.UUID);
		try {
			ip = restTemplate.postForObject(taskProperties.getServer().getHost() + "/api/host/status", paramMap,
					String.class);
			hostIp = ip;
		} catch (Exception e) {
			log.error("TaskAPI.updateHostStatus()服务端主机状态更新异常:{}", e.getMessage());
		}
		return ip;
	}

	/**
	 * 更新当前主机设置。
	 */
	public List getHostConfig() {
		MultiValueMap paramMap = new LinkedMultiValueMap<>();
		try {
			String[] data = restTemplate.getForObject(taskProperties.getServer().getHost() + "/api/host/config",  String[].class, paramMap);
			hostConfig = Arrays.asList(data);
		} catch (Exception e) {
			log.error("TaskAPI.getHostConfig()服务端主机配置拉取异常:{}", e.getMessage());
		}
		if (hostConfig==null) {
			if (log.isWarnEnabled()) {
				log.warn("获得主机服务端配置失败,启用默认配置项!");
			}
			hostConfig = new ArrayList<>();
			hostConfig.add("");
		}
		return hostConfig;
	}

	/**
	 * 根据包名前缀获得TaskRunner配置列表。
	 * 
	 * @param prefix
	 * @return
	 */
	public List getTaskRunnerConfigList(String taskPackage, long lastUpdateTime) {
		HashMap paramMap = new HashMap<>();
		paramMap.put("lastUpdateTime", String.valueOf(lastUpdateTime));
		paramMap.put("taskPackage", taskPackage);
		List list = null;
		try {
			TaskRunnerConfig[] data = restTemplate.getForObject(taskProperties.getServer().getHost() + "/api/croner/config?taskPackage={taskPackage}&lastUpdateTime={lastUpdateTime}", TaskRunnerConfig[].class,paramMap);
			list = Arrays.asList(data);
		} catch (Exception e) {
			log.error("TaskAPI.getTaskRunnerConfigList()服务端主机状态更新异常:{}", e.getMessage());
		}

		return list;
	}

	/**
	 * 根据包名前缀获得TaskCroner配置列表。
	 * 
	 * @param prefix
	 * @return
	 */
	public List getTaskCronerConfigList(String taskPackage, long lastUpdateTime) {
		HashMap paramMap = new HashMap<>();
		paramMap.put("lastUpdateTime", String.valueOf(lastUpdateTime));
		paramMap.put("taskPackage", taskPackage);
		List list = null;
		try {
			TaskCronerConfig[] data = restTemplate.getForObject(taskProperties.getServer().getHost() + "/api/croner/config?taskPackage={taskPackage}&lastUpdateTime={lastUpdateTime}", TaskCronerConfig[].class,paramMap);
			list = Arrays.asList(data);
		} catch (Exception e) {
			log.error("TaskAPI.getTaskCronerConfigList()服务端主机状态更新异常:{}", e.getMessage());
		}

		return list;
	}

	/**
	 * 发送Runner任务日志。
	 * 
	 * @param taskData
	 */
	public void sendTaskRunnerLog(TaskData taskData) {
		es.submit(new Runnable() {
			@Override
			public void run() {
				try {
					restTemplate.postForLocation(taskProperties.getServer().getHost() + "/api/runner/log", taskData);
				} catch (Exception e) {
					log.error("TaskAPI.sendTaskRunnerLog日志发送到服务端异常:{}", e.getMessage());
				}
			}
		});

	}

	/**
	 * 发送CronLog日志。
	 * 
	 * @param taskCronLog
	 */
	public void sendTaskCronerLog(TaskCronerLog taskCronerLog) {
		es.submit(new Runnable() {
			@Override
			public void run() {
				try {
					restTemplate.postForLocation(taskProperties.getServer().getHost() + "/api/croner/log", taskCronerLog);
				} catch (Exception e) {
					log.error("TaskAPI.sendTaskCronerLog日志发送到服务端异常:{}", e.getMessage());
				}
			}
		});
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy