com.facebook.swift.service.ThriftServerService Maven / Gradle / Ivy
package com.facebook.swift.service;
import java.lang.reflect.Constructor;
import java.lang.reflect.Field;
import java.lang.reflect.Modifier;
import java.util.List;
import org.apache.thrift.protocol.TJSONProtocol;
import org.jboss.netty.channel.ChannelPipeline;
import org.jboss.netty.channel.ChannelPipelineFactory;
import org.jboss.netty.handler.codec.http.HttpChunkAggregator;
import org.jboss.netty3.handler.codec.http.cors.Netty3CorsConfig;
import org.jboss.netty3.handler.codec.http.cors.Netty3CorsConfigBuilder;
import org.jboss.netty3.handler.codec.http.cors.Netty3CorsHandler;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.google.common.base.Throwables;
import com.google.common.base.Joiner;
import com.google.common.base.Strings;
import static com.google.common.base.Preconditions.*;
import static org.jboss.netty.handler.codec.http.HttpMethod.*;
import com.facebook.nifty.codec.ThriftFrameCodecFactory;
import com.facebook.nifty.core.NettyServerTransport;
import com.facebook.nifty.core.NiftyTimer;
import com.facebook.nifty.duplex.TDuplexProtocolFactory;
import com.facebook.swift.codec.FlexibleThriftCodecFactory;
import com.facebook.swift.codec.ThriftCodec;
import com.facebook.swift.codec.ThriftCodecManager;
import com.facebook.swift.codec.metadata.ThriftCatalogWithTransformer;
import com.facebook.swift.service.ThriftEventHandler;
import com.facebook.swift.service.ThriftServer;
import com.facebook.swift.service.ThriftServerConfig;
import com.facebook.swift.service.ThriftService;
import com.facebook.swift.service.ThriftServiceProcessor;
import com.facebook.swift.service.metadata.ThriftServiceMetadata;
import com.google.common.base.Function;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSet;
import com.google.common.collect.Lists;
import com.google.common.util.concurrent.AbstractIdleService;
import com.google.common.util.concurrent.MoreExecutors;
import net.gdface.utils.ReflectionUtils;
/**
* 创建thrift服务实例{@link ThriftServer},封装为{@link com.google.common.util.concurrent.Service}
* @author guyadong
*
*/
public class ThriftServerService extends AbstractIdleService{
private static final Logger logger = LoggerFactory.getLogger(ThriftServerService.class);
public static final String HTTP_TRANSPORT = "http";
public static final String JSON_PROTOCOL = "json";
/**
* 在{@link ThriftServer#DEFAULT_PROTOCOL_FACTORIES}基础上增加'json'支持
*/
public static final ImmutableMap DEFAULT_PROTOCOL_FACTORIES =
ImmutableMap.builder()
.putAll(ThriftServer.DEFAULT_PROTOCOL_FACTORIES)
.put(JSON_PROTOCOL, TDuplexProtocolFactory.fromSingleFactory(new TJSONProtocol.Factory()))
.build();
/**
* 在{@link ThriftServer#DEFAULT_FRAME_CODEC_FACTORIES}基础上增加'http'支持
*/
public static final ImmutableMap DEFAULT_FRAME_CODEC_FACTORIES =
ImmutableMap.builder()
.putAll(ThriftServer.DEFAULT_FRAME_CODEC_FACTORIES)
.put(HTTP_TRANSPORT, (ThriftFrameCodecFactory) new ThriftHttpCodecFactory())
.build();
public static class Builder {
private List> services = ImmutableList.of();
private ThriftServerConfig thriftServerConfig= new ThriftServerConfig();
private List eventHandlers = ImmutableList.of();
private Builder() {
}
public Builder withServices(Object... services) {
return withServices(ImmutableList.copyOf(services));
}
public Builder withServices(List> services) {
this.services = checkNotNull(services);
return this;
}
public Builder setEventHandlers(List eventHandlers){
this.eventHandlers = checkNotNull(eventHandlers);
return this;
}
public Builder setEventHandlers(ThriftEventHandler...eventHandlers){
return setEventHandlers(ImmutableList.copyOf(eventHandlers));
}
/**
* 设置服务端口
* @param servicePort
* @return 当前对象
* @see ThriftServerConfig#setPort(int)
*/
public Builder setServerPort(int servicePort) {
this.thriftServerConfig.setPort(servicePort);
return this;
}
/**
* 设置服务器配置参数对象
* @param thriftServerConfig
* @return 当前对象
*/
public Builder setThriftServerConfig(ThriftServerConfig thriftServerConfig) {
this.thriftServerConfig = checkNotNull(thriftServerConfig,"thriftServerConfig is null");
return this;
}
/**
* 根据参数构造 {@link ThriftServerService}实例
* @return {@link ThriftServerService}实例
*/
public ThriftServerService build() {
return new ThriftServerService(services, eventHandlers, thriftServerConfig);
}
/**
* 根据参数构造 {@link ThriftServerService}子类实例
* @param subServiceClass
* @return instance of subServiceClass
*/
public T build(Class subServiceClass) {
try {
Constructor constructor= checkNotNull(subServiceClass,"subServiceClass is null")
.getDeclaredConstructor(List.class,List.class,ThriftServerConfig.class);
return constructor.newInstance(services,eventHandlers,thriftServerConfig);
} catch (Exception e) {
Throwables.throwIfUnchecked(e);
throw new RuntimeException(e);
}
}
}
public static final Builder bulider() {
return new Builder();
}
protected final ThriftServer thriftServer;
protected final ThriftServiceProcessor processor;
protected final ThriftServerConfig thriftServerConfig;
protected final String serviceName;
/**
* 构造函数
* @param services 服务对象列表
* @param eventHandlers 事件侦听器列表
* @param thriftServerConfig 服务配置对象
* @see ThriftServiceProcessor#ThriftServiceProcessor(ThriftCodecManager, List, List)
* @see ThriftServer#ThriftServer(com.facebook.nifty.processor.NiftyProcessor, ThriftServerConfig)
*/
public ThriftServerService(final List> services,
List eventHandlers,
ThriftServerConfig thriftServerConfig) {
checkArgument(null != services && !services.isEmpty());
this.thriftServerConfig = checkNotNull(thriftServerConfig,"thriftServerConfig is null");
int port = this.thriftServerConfig.getPort();
checkArgument(port > 0 && port < 65535, "INVALID service port %d", port);
this.processor = new ThriftServiceProcessorCustom(
//new ThriftCodecManager(new CompilerThriftCodecFactory(ThriftCodecManager.class.getClassLoader()),ThriftCatalogWithTransformer.CATALOG, ImmutableSet.>of()),
/** 使用自定义的 ThriftCodecFactory 实例支持 gu.sql2java.BaseBean 实例的正确反序列化 */
new ThriftCodecManager(new FlexibleThriftCodecFactory(),ThriftCatalogWithTransformer.CATALOG,ImmutableSet.>of()),
checkNotNull(eventHandlers,"eventHandlers is null"),
services);
this.thriftServer = new ThriftServer(processor,
thriftServerConfig,
new NiftyTimer("thrift"),
DEFAULT_FRAME_CODEC_FACTORIES, DEFAULT_PROTOCOL_FACTORIES,
ThriftServer.DEFAULT_WORKER_EXECUTORS,
ThriftServer.DEFAULT_SECURITY_FACTORY);
addCorsHandlerIfHttp();
String serviceList = Joiner.on(",").join(Lists.transform(services, new Function
© 2015 - 2025 Weber Informatics LLC | Privacy Policy