springcloud熱部署
需要將業務腳本groovy放置到另一個git目錄下編寫,開發時使用linked目標放置到project中,部署是不打入jar中。
nhmicro框架代碼地址:https://github.com/jeffreyning/nh-micro
借助nhmicro框架中micro-git-sync模塊功能在啟動時從git倉庫中下載groovy腳本加載到springcloud應用中,
同時還可以支持動態發布,即提交新groovy到git倉庫後,會自動下載並熱部署到springcloud應用中。
使用micro-git-sync模塊優點是:
1, 使應用按照可執行jar包運行時,也支持腳本熱部署。
2, 準實時自動加載遠程git中的新腳本代碼。
3, 可以按照指定版本加載腳本。
配置MicroGitSync設置git遠程地址和本地下載目錄
如果設置了init-method="initRep",則準實時檢查遠程git倉庫是否有代碼更新,有則自動下載。
Version可以設置指定的版本,設置為head表示最新版本
cloneFlag表示啟動時是否完全clone
openFlag表示是否有效,開發環境中可以設置為false,避免調試程序時從遠程下載。
<bean id="gitSync" class="com.nh.micro.sync.git.MicroGitSync" init-method="initRep" lazy-init="false"> <property name="localPath" value="h:/temp/git"></property> <property name="remotePath" value="https://github.com/nhmicro/test-sync-groovy.git"></property> <property name="cloneFlag" value="true"></property> <property name="openFlag" value="${openFlag}"></property> <property name="version" value="head"></property> </bean>
設置從本地下載目錄中加載groovy
註意設置depends-on確保git下載完成後在啟動加載
<bean id="groovyInitUtil" class="com.nh.micro.rule.engine.core.GroovyInitUtil" init-method="initGroovy" lazy-init="false" depends-on="gitSync" > <property name="fileList"> <list> <bean class="com.nh.micro.rule.engine.core.GFileBean"> <property name="ruleStamp" value="true"></property> <property name="jarFileFlag" value="true"></property> <property name="dirFlag" value="true"></property> <property name="rulePath" value="/groovy/"></property> </bean> <bean class="com.nh.micro.rule.engine.core.GFileBean"> <property name="ruleStamp" value="true"></property> <property name="jarFileFlag" value="false"></property> <property name="dirFlag" value="true"></property> <property name="rulePath" value="H:/temp/git/test-sync/groovy/"></property> </bean> </list> </property> </bean>
Micro-mvc不但可以與springmvc整合還可以與springcloud整合
Springcloud的controller層改為接口註解仍使用springcloud和springboot相關註解實現服務註冊路由等配置,但controller接口上需要添加@InjectGroovy註解設置接口實現的關聯groovy。
package com.nh.micro.springcloud.demo.web;
import org.apache.log4j.Logger;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.cloud.client.discovery.DiscoveryClient;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import com.nh.micro.service.InjectGroovy;
@InjectGroovy(name="ComputeGroovy")
@RestController
public interface ComputeController {
@RequestMapping(value = "/add" ,method = RequestMethod.GET)
@ResponseBody
public Integer add(@RequestParam(value="a") Integer a, @RequestParam(value="b") Integer b);
}
Spring配置中使用GroovyBeanScannerConfigurer掃描controller接口
<bean class="com.nh.micro.service.GroovyBeanScannerConfigurer">
<property name="scanPath" value="com.nh.micro.springcloud.demo.web"></property>
</bean>
ComputeController接口實現ComputeGroovy.groovy
package groovy
import javax.annotation.Resource;
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.cloud.client.discovery.DiscoveryClient;
import org.springframework.web.bind.annotation.RequestParam;
import org.apache.log4j.Logger;
class ComputeGroovy {
private final Logger logger = Logger.getLogger(getClass());
//@Resource(name="discoveryClient")
//public DiscoveryClient client;
public Integer add(@RequestParam Integer a, @RequestParam Integer b) {
//GroovyExecUtil.execGroovyRetObj("TestGroovy", "test");
Integer r = a + b;
System.out.println(r);
//ServiceInstance instance = client.getLocalServiceInstance();
//logger.info("/add, host:" + instance.getHost() + ", service_id:" + instance.getServiceId() + ", result:" + r);
return r;
}
}
springcloud熱部署