ESBCamelService.java 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. package com.yihu.hos.services;
  2. import com.yihu.hos.common.classLoader.DynamicClassLoader;
  3. import com.yihu.hos.common.compiler.CamelCompiler;
  4. import com.yihu.hos.common.constants.BrokerConstant;
  5. import com.yihu.hos.core.constants.CoreConstant;
  6. import com.yihu.hos.core.datatype.ClassFileUtil;
  7. import com.yihu.hos.core.datatype.StringUtil;
  8. import com.yihu.hos.models.SystemCamelContext;
  9. import com.yihu.hos.models.SystemClassMapping;
  10. import com.yihu.hos.web.framework.model.Result;
  11. import org.apache.camel.builder.RouteBuilder;
  12. import org.apache.log4j.LogManager;
  13. import org.apache.log4j.Logger;
  14. import org.springframework.stereotype.Service;
  15. import java.io.File;
  16. import java.io.IOException;
  17. import java.net.MalformedURLException;
  18. import java.util.Map;
  19. /**
  20. * Created by lingfeng on 2016/8/4.
  21. */
  22. @Service("ESBCamelService")
  23. public class ESBCamelService {
  24. public static final String BEAN_ID = "ESBCamelService";
  25. private static Logger logger = LogManager.getLogger(ESBCamelService.class);
  26. /**
  27. * 当外界组件通知一个新的processor处理器被定义时,该事件被触发。
  28. * @param serviceFlow 本次processor处理器变化,所涉及的业务系统唯一标识。
  29. * @param packageName processor处理器定义涉及的class包名
  30. * @param className processor处理器定义涉及的class类名
  31. * @param path processor处理器定义涉及的class对应路径
  32. */
  33. public Result onProcessorAdded(String serviceFlow, String packageName, String className, String path) {
  34. try {
  35. if(StringUtil.isEmpty(serviceFlow) || StringUtil.isEmpty(packageName)
  36. || StringUtil.isEmpty(className) || StringUtil.isEmpty(path)) {
  37. logger.error("必要的入参数据不正确,请检查!");
  38. return Result.error("必要的入参数据不正确,请检查!");
  39. }
  40. this.createClassfile(serviceFlow, packageName, className, path, BrokerConstant.PROCESSOR);
  41. return Result.success("新增处理器成功!");
  42. } catch (Exception e) {
  43. logger.error(e);
  44. return Result.error("新增处理器失败!");
  45. }
  46. }
  47. /**
  48. * 当外界组件通知一个已有的processor处理器data部分发生变化时,该事件被触发。
  49. */
  50. public Result onProcessorDataChanged(String serviceFlow , String packageName , String className , String path) {
  51. try {
  52. if(StringUtil.isEmpty(serviceFlow) || StringUtil.isEmpty(packageName)
  53. || StringUtil.isEmpty(className) || StringUtil.isEmpty(path)) {
  54. logger.error("必要的入参数据不正确,请检查!");
  55. return Result.error("必要的入参数据不正确,请检查!");
  56. }
  57. this.updateClassfile(serviceFlow, packageName, className, path, BrokerConstant.PROCESSOR);
  58. SystemCamelContext.getDefaultCamelContext().stopRoute(serviceFlow);
  59. SystemCamelContext.getDefaultCamelContext().removeRoute(serviceFlow);
  60. DynamicClassLoader classLoader = new DynamicClassLoader(DynamicClassLoader.class.getClassLoader());
  61. Class<RouteBuilder> routeBuilderClass = (Class<RouteBuilder>) classLoader.loadClass(ClassLoader.getSystemResource(CoreConstant.EMPTY).getPath(), SystemClassMapping.getSystemClassNameMapping().get(serviceFlow + BrokerConstant.ROUTE));
  62. classLoader.loadClass(ClassLoader.getSystemResource(CoreConstant.EMPTY).getPath(), SystemClassMapping.getSystemClassNameMapping().get(serviceFlow + BrokerConstant.PROCESSOR));
  63. if (routeBuilderClass != null) {
  64. RouteBuilder routeBuilder = routeBuilderClass.newInstance();
  65. SystemCamelContext.getDefaultCamelContext().addRoutes(routeBuilder);
  66. }
  67. return Result.success("修改处理器成功!");
  68. } catch (Exception e) {
  69. logger.error(e);
  70. return Result.error("修改路由失败!");
  71. }
  72. }
  73. /**
  74. * 当外界组件通知一个新的RouteDefine路由被定义时,该事件被触发
  75. */
  76. public Result onRouteDefineAdded(String serviceFlow , String packageName , String className , String path) {
  77. try {
  78. if(StringUtil.isEmpty(serviceFlow) || StringUtil.isEmpty(packageName)
  79. || StringUtil.isEmpty(className) || StringUtil.isEmpty(path)) {
  80. logger.error("必要的入参数据不正确,请检查!");
  81. return Result.error("必要的入参数据不正确,请检查!");
  82. }
  83. File systemClassRootPath = new File(ClassLoader.getSystemResource("").getPath() + "/" + serviceFlow);
  84. if (!systemClassRootPath.exists()) {
  85. systemClassRootPath.mkdirs();
  86. }
  87. // 第1、2两步处理过程,都是在这里完成
  88. this.createClassfile(serviceFlow, packageName, className, path, BrokerConstant.ROUTE);
  89. // 3、===============加载到CamelContext中
  90. ClassLoader currentClassLoader = Thread.currentThread().getContextClassLoader();
  91. Class<RouteBuilder> routeBuilderClass = (Class<RouteBuilder>) currentClassLoader.loadClass(SystemClassMapping.getSystemClassNameMapping().get(serviceFlow + BrokerConstant.ROUTE));
  92. if(routeBuilderClass != null) {
  93. RouteBuilder routeBuilder = routeBuilderClass.newInstance();
  94. SystemCamelContext.getDefaultCamelContext().addRoutes(routeBuilder);
  95. }
  96. return Result.success("新增路由成功!");
  97. } catch (Exception e) {
  98. logger.error(e);
  99. return Result.error("新增路由失败!");
  100. }
  101. }
  102. /**
  103. * 当外界组件通知一个已有的RouteDefine路由定义被改变时,主要就是路由定义内容被改变时,该事件被触发。
  104. */
  105. public Result onRouteDefineChanged(String serviceFlow, String packageName, String className, String path) {
  106. try {
  107. if (StringUtil.isEmpty(serviceFlow) || StringUtil.isEmpty(packageName)
  108. || StringUtil.isEmpty(className) || StringUtil.isEmpty(path)) {
  109. logger.error("必要的入参数据不正确,请检查!");
  110. return Result.error("必要的入参数据不正确,请检查!");
  111. }
  112. SystemCamelContext.getDefaultCamelContext().stopRoute(serviceFlow);
  113. SystemCamelContext.getDefaultCamelContext().removeRoute(serviceFlow);
  114. this.updateClassfile(serviceFlow, packageName, className, path, BrokerConstant.ROUTE);
  115. // 3、===============加载到CamelContext中
  116. DynamicClassLoader classLoader = new DynamicClassLoader(DynamicClassLoader.class.getClassLoader());
  117. Class<RouteBuilder> routeBuilderClass = (Class<RouteBuilder>) classLoader.loadClass(ClassLoader.getSystemResource(CoreConstant.EMPTY).getPath(), SystemClassMapping.getSystemClassNameMapping().get(serviceFlow + BrokerConstant.ROUTE));
  118. if (routeBuilderClass != null) {
  119. RouteBuilder routeBuilder = routeBuilderClass.newInstance();
  120. SystemCamelContext.getDefaultCamelContext().addRoutes(routeBuilder);
  121. }
  122. return Result.success("修改路由成功!");
  123. } catch (Exception e) {
  124. return Result.error("修改路由失败!");
  125. }
  126. }
  127. /**
  128. * 当外界组件通知一个已有的RouteDefine路由定义被删除时,该事件被触发。
  129. */
  130. public Result onRouteDefineDelete(String serviceFlow, String packageName, String className) {
  131. try {
  132. if(StringUtil.isEmpty(serviceFlow) || StringUtil.isEmpty(packageName)
  133. || StringUtil.isEmpty(className)) {
  134. logger.error("必要的入参数据不正确,请检查!");
  135. return Result.error("必要的入参数据不正确,请检查!");
  136. }
  137. SystemCamelContext.getDefaultCamelContext().stopRoute(serviceFlow);
  138. SystemCamelContext.getDefaultCamelContext().removeRoute(serviceFlow);
  139. this.deleteClassfile(serviceFlow, packageName, className, BrokerConstant.PROCESSOR);
  140. return Result.success("删除路由成功!");
  141. } catch (Exception e) {
  142. return Result.error("删除路由失败!");
  143. }
  144. }
  145. /**
  146. * 启动路由时,该事件被触发。
  147. */
  148. public Result onRouteDefineStart(String serviceFlow) {
  149. try {
  150. if(StringUtil.isEmpty(serviceFlow)) {
  151. logger.error("必要的入参数据不正确,请检查!");
  152. return Result.error("必要的入参数据不正确,请检查!");
  153. }
  154. SystemCamelContext.getDefaultCamelContext().startRoute(serviceFlow);
  155. return Result.success("启动路由成功!");
  156. } catch (Exception e) {
  157. return Result.error("启动路由失败!");
  158. }
  159. }
  160. /**
  161. * 停止路由时,该事件被触发。
  162. */
  163. public Result onRouteDefineStop(String serviceFlow) {
  164. try {
  165. if(StringUtil.isEmpty(serviceFlow)) {
  166. logger.error("必要的入参数据不正确,请检查!");
  167. return Result.error("必要的入参数据不正确,请检查!");
  168. }
  169. SystemCamelContext.getDefaultCamelContext().stopRoute(serviceFlow);
  170. return Result.success("停止路由成功!");
  171. } catch (Exception e) {
  172. return Result.error("停止路由失败!");
  173. }
  174. }
  175. private void createClassfile(String serviceFlow, String packageName, String className, String path, String type) throws MalformedURLException {
  176. // 1、============
  177. File systemClassFlowPath = new File(ClassLoader.getSystemResource(CoreConstant.EMPTY).getPath() + "/" + serviceFlow);
  178. // 记录到工具类中,以便其它线程需要时进行取用
  179. SystemClassMapping.getSystemClassNameMapping().put(serviceFlow + type, serviceFlow + CoreConstant.DOT + packageName + CoreConstant.DOT + className);
  180. // 2、============开始写入class文件
  181. ClassFileUtil.createClassfile(systemClassFlowPath.toURI().toURL(), packageName, className, path);
  182. // 完成
  183. logger.info("===================" + packageName + CoreConstant.DOT + className + ".class 生成过程结束");
  184. }
  185. private void updateClassfile(String serviceFlow, String packageName, String className, String path, String type) {
  186. // 1、============
  187. Map<String, String> systemClassNameMapping = SystemClassMapping.getSystemClassNameMapping();
  188. String systemClassName = systemClassNameMapping.get(serviceFlow + type);
  189. if(StringUtil.isEmpty(systemClassName)) {
  190. return;
  191. }
  192. String classPath = ClassLoader.getSystemResource("").getPath() + "/" + serviceFlow + "/" + packageName + "/" + className + ".class";
  193. // 2、============开始写入class文件
  194. ClassFileUtil.updateClassfile(classPath, path);
  195. // 完成
  196. logger.info("===================" + packageName + CoreConstant.DOT + className + ".class 修改过程结束");
  197. }
  198. private void deleteClassfile(String serviceFlow, String packageName, String className, String type) {
  199. // 1、============
  200. Map<String, String> systemClassNameMapping = SystemClassMapping.getSystemClassNameMapping();
  201. String systemClassName = systemClassNameMapping.get(serviceFlow + type);
  202. if(StringUtil.isEmpty(systemClassName)) {
  203. return;
  204. }
  205. String classPath = ClassLoader.getSystemResource("").getPath() + "/" + serviceFlow + "/" + packageName + "/" + className + ".class";
  206. // 2、============开始写入class文件
  207. ClassFileUtil.deleteClassfile(classPath);
  208. // 完成
  209. logger.info("===================" + packageName + CoreConstant.DOT + className + ".class 删除过程结束");
  210. }
  211. /* ************************** 修改任务cron生成新的camel文件 add by hzy *********************************** */
  212. public Result genNewClassfile(String routeId, String packageName, String oldClassName, String newClassName,String newCron) {
  213. try {
  214. CamelCompiler.compiler(packageName,oldClassName,newClassName,newCron);
  215. return Result.success("生成新文件成功!");
  216. } catch (IOException e) {
  217. e.printStackTrace();
  218. return Result.error("生成新文件失败!");
  219. }
  220. }
  221. }