/*
|
* Copyright 2017-2020 吴学文 and java110 team.
|
*
|
* 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 com.java110.boot;
|
|
import com.java110.core.annotation.Java110CmdDiscovery;
|
import com.java110.core.client.OutRestTemplate;
|
import com.java110.core.client.RestTemplate;
|
import com.java110.core.context.Environment;
|
import com.java110.core.event.cmd.ServiceCmdEventPublishing;
|
import com.java110.core.log.LoggerFactory;
|
import com.java110.core.trace.Java110FeignClientInterceptor;
|
import com.java110.core.trace.Java110RestTemplateInterceptor;
|
import com.java110.doc.annotation.Java110ApiDocDiscovery;
|
import com.java110.doc.annotation.Java110CmdDocDiscovery;
|
import com.java110.doc.registrar.ApiDocCmdPublishing;
|
import com.java110.doc.registrar.ApiDocPublishing;
|
import com.java110.intf.dev.ICacheV1InnerServiceSMO;
|
import com.java110.service.init.ServiceStartInit;
|
import com.java110.utils.cache.MappingCache;
|
import com.java110.utils.constant.MappingConstant;
|
import com.java110.utils.factory.ApplicationContextFactory;
|
import com.java110.utils.util.StringUtil;
|
import okhttp3.ConnectionPool;
|
import org.slf4j.Logger;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.boot.SpringApplication;
|
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnBean;
|
import org.springframework.boot.autoconfigure.liquibase.LiquibaseAutoConfiguration;
|
import org.springframework.boot.web.client.RestTemplateBuilder;
|
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
|
import org.springframework.context.ApplicationContext;
|
import org.springframework.context.annotation.Bean;
|
import org.springframework.http.client.HttpComponentsClientHttpRequestFactory;
|
import org.springframework.http.converter.StringHttpMessageConverter;
|
import org.springframework.scheduling.annotation.EnableAsync;
|
|
import javax.annotation.Resource;
|
import java.nio.charset.Charset;
|
import java.util.concurrent.TimeUnit;
|
|
|
/**
|
* 这个服务是将 系统部署为spring boot版
|
* 如果是spring cloud 微服务部署 不用启动这个类
|
* <p>
|
* excludeName = {
|
* "com.java110.intf.acct",
|
* "com.java110.intf.code",
|
* "com.java110.intf.common",
|
* "com.java110.intf.community",
|
* "com.java110.intf.demo",
|
* "com.java110.intf.dev",
|
* "com.java110.intf.fee",
|
* "com.java110.intf.goods",
|
* "com.java110.intf.job",
|
* "com.java110.intf.oa",
|
* "com.java110.intf.order",
|
* "com.java110.intf.report",
|
* "com.java110.intf.store",
|
* "com.java110.intf.user"
|
* }
|
*
|
* @version v0.1
|
* @auther com.java110.wuxw
|
* @mail 928255095@qq.com
|
* @date 2016年8月6日
|
* @tag
|
*/
|
@SpringBootApplication(scanBasePackages = {
|
"com.java110.service",
|
"com.java110.db",
|
"com.java110.core",
|
"com.java110.config.properties.code",
|
"com.java110.acct",
|
"com.java110.common",
|
"com.java110.community",
|
"com.java110.dev",
|
"com.java110.fee",
|
"com.java110.job",
|
"com.java110.oa",
|
"com.java110.order",
|
"com.java110.report",
|
"com.java110.store",
|
"com.java110.user",
|
"com.java110.doc",
|
"com.java110.scm",
|
"com.java110.boot"
|
},
|
exclude = {LiquibaseAutoConfiguration.class,
|
org.activiti.spring.boot.SecurityAutoConfiguration.class,
|
org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfiguration.class}
|
|
)
|
@Java110CmdDiscovery(cmdPublishClass = ServiceCmdEventPublishing.class,
|
basePackages = {
|
"com.java110.acct.cmd",
|
"com.java110.common.cmd",
|
"com.java110.community.cmd",
|
"com.java110.dev.cmd",
|
"com.java110.fee.cmd",
|
"com.java110.job.cmd",
|
"com.java110.oa.cmd",
|
"com.java110.order.cmd",
|
"com.java110.report.cmd",
|
"com.java110.store.cmd",
|
"com.java110.scm.cmd",
|
"com.java110.user.cmd"
|
})
|
@EnableAsync
|
//文档
|
@Java110ApiDocDiscovery(basePackages = {"com.java110.boot.rest"}, apiDocClass = ApiDocPublishing.class)
|
@Java110CmdDocDiscovery(basePackages = {
|
"com.java110.acct.cmd",
|
"com.java110.acct.payment.business",
|
"com.java110.common.cmd",
|
"com.java110.community.cmd",
|
"com.java110.dev.cmd",
|
"com.java110.fee.cmd",
|
"com.java110.job.cmd",
|
"com.java110.oa.cmd",
|
"com.java110.order.cmd",
|
"com.java110.report.cmd",
|
"com.java110.store.cmd",
|
"com.java110.scm.cmd",
|
"com.java110.user.cmd"
|
},
|
cmdDocClass = ApiDocCmdPublishing.class)
|
public class BootApplicationStart {
|
|
private static Logger logger = LoggerFactory.getLogger(BootApplicationStart.class);
|
|
@Resource
|
private Java110RestTemplateInterceptor java110RestTemplateInterceptor;
|
|
/**
|
* 实例化RestTemplate
|
*
|
* @return restTemplate
|
*/
|
@Bean
|
public OutRestTemplate outRestTemplate() {
|
StringHttpMessageConverter m = new StringHttpMessageConverter(Charset.forName("UTF-8"));
|
OutRestTemplate restTemplate = new RestTemplateBuilder().additionalMessageConverters(m).build(OutRestTemplate.class);
|
restTemplate.getInterceptors().add(java110RestTemplateInterceptor);
|
|
//设置超时时间
|
HttpComponentsClientHttpRequestFactory httpRequestFactory = new HttpComponentsClientHttpRequestFactory();
|
httpRequestFactory.setConnectionRequestTimeout(5000);
|
httpRequestFactory.setConnectTimeout(5000);
|
httpRequestFactory.setReadTimeout(5000);
|
restTemplate.setRequestFactory(httpRequestFactory);
|
return restTemplate;
|
}
|
|
@Bean
|
//@LoadBalanced
|
public RestTemplate formRestTemplate() {
|
RestTemplate restTemplate = new RestTemplate();
|
restTemplate.getMessageConverters().add(new StringHttpMessageConverter(Charset.forName("UTF-8")));
|
return restTemplate;
|
}
|
|
/**
|
* 实例化RestTemplate,通过@LoadBalanced注解开启均衡负载能力.
|
*
|
* @return restTemplate
|
*/
|
@Bean
|
@LoadBalanced
|
public RestTemplate restTemplate() {
|
StringHttpMessageConverter m = new StringHttpMessageConverter(Charset.forName("UTF-8"));
|
RestTemplate restTemplate = new RestTemplateBuilder().additionalMessageConverters(m).build(RestTemplate.class);
|
restTemplate.getInterceptors().add(java110RestTemplateInterceptor);
|
return restTemplate;
|
}
|
|
@Bean
|
@ConditionalOnBean(Java110FeignClientInterceptor.class)
|
public okhttp3.OkHttpClient okHttpClient(@Autowired
|
Java110FeignClientInterceptor okHttpLoggingInterceptor) {
|
okhttp3.OkHttpClient.Builder ClientBuilder = new okhttp3.OkHttpClient.Builder()
|
.readTimeout(30, TimeUnit.SECONDS) //读取超时
|
.connectTimeout(10, TimeUnit.SECONDS) //连接超时
|
.writeTimeout(60, TimeUnit.SECONDS) //写入超时
|
.connectionPool(new ConnectionPool(10 /*maxIdleConnections*/, 3, TimeUnit.MINUTES))
|
.addInterceptor(okHttpLoggingInterceptor);
|
return ClientBuilder.build();
|
}
|
|
public static void main(String[] args) throws Exception {
|
try {
|
ServiceStartInit.preInitSystemConfig();
|
ApplicationContext context = SpringApplication.run(BootApplicationStart.class, args);
|
//服务启动加载
|
ServiceStartInit.initSystemConfig(context);
|
|
Environment.setSystemStartWay(Environment.SPRING_BOOT);
|
|
|
//刷新缓存
|
flushMainCache(args);
|
} catch (Throwable e) {
|
logger.error("系统启动失败", e);
|
}
|
}
|
|
/**
|
* 刷新主要的缓存
|
*
|
* @param args
|
*/
|
private static void flushMainCache(String[] args) {
|
|
logger.debug("判断是否需要刷新日志,参数 args 为 {}", args);
|
|
//因为好多朋友启动时 不加 参数-Dcache 所以启动时检测 redis 中是否存在 java110_hc_version
|
//String mapping = MappingCache.getValue(MappingConstant.ENV_DOMAIN,"java110_hc_version");
|
String mapping = "";
|
if (StringUtil.isEmpty(mapping)) {
|
ICacheV1InnerServiceSMO devServiceCacheSMOImpl = (ICacheV1InnerServiceSMO) ApplicationContextFactory.getBean(ICacheV1InnerServiceSMO.class);
|
devServiceCacheSMOImpl.startFlush();
|
return;
|
}
|
|
if (args == null || args.length == 0) {
|
return;
|
}
|
for (int i = 0; i < args.length; i++) {
|
if (args[i].equalsIgnoreCase("-Dcache")) {
|
logger.debug("开始刷新日志,入参为:{}", args[i]);
|
ICacheV1InnerServiceSMO devServiceCacheSMOImpl = (ICacheV1InnerServiceSMO) ApplicationContextFactory.getBean(ICacheV1InnerServiceSMO.class);
|
devServiceCacheSMOImpl.startFlush();
|
}
|
}
|
}
|
|
}
|