本文整理匯總了Java中org.apache.thrift.TApplicationException類的典型用法代碼示例。如果您正苦於以下問題:Java TApplicationException類的具體用法?Java TApplicationException怎麽用?Java TApplicationException使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
TApplicationException類屬於org.apache.thrift包,在下文中一共展示了TApplicationException類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: invoke
import org.apache.thrift.TApplicationException; //導入依賴的package包/類
@Override
public Object invoke(MethodInvocation methodInvocation) throws Throwable {
Object thriftProxy = ThriftUtil.buildClient(getServiceInterface(), protocolFactory.getProtocol(getTransport()));
ClassLoader originalClassLoader = overrideThreadContextClassLoader();
try {
return methodInvocation.getMethod().invoke(thriftProxy, methodInvocation.getArguments());
} catch (InvocationTargetException e) {
Throwable targetEx = e.getTargetException();
if (targetEx instanceof InvocationTargetException) {
targetEx = ((InvocationTargetException) targetEx).getTargetException();
}
if (targetEx instanceof TApplicationException && ((TApplicationException) targetEx).getType() == TApplicationException.MISSING_RESULT) {
return null;
} else {
throw targetEx;
}
} catch (Throwable ex) {
throw new RemoteProxyFailureException("Failed to invoke Thrift proxy for remote service [" + getServiceUrl() + "]", ex);
} finally {
resetThreadContextClassLoader(originalClassLoader);
}
}
示例2: process
import org.apache.thrift.TApplicationException; //導入依賴的package包/類
@Override
public boolean process(TProtocol in, TProtocol out) throws TException {
TMessage msg = in.readMessageBegin();
Controller<?, ?> fn = (Controller<?, ?>) this.beanFactory
.getBean(msg.name);
if (fn == null) {
if (LOGGER.isWarnEnabled()) {
LOGGER.warn("Invalid request: failed to find interface="
+ msg.name + ", from: " + getInetAddress(in));
}
TProtocolUtil.skip(in, TType.STRUCT);
in.readMessageEnd();
TApplicationException x = new TApplicationException(
TApplicationException.UNKNOWN_METHOD,
"Invalid method name: '" + msg.name + "'");
out.writeMessageBegin(new TMessage(msg.name,
TMessageType.EXCEPTION, msg.seqid));
x.write(out);
out.writeMessageEnd();
out.getTransport().flush();
return true;
}
process(msg.seqid, msg.name, in, out, fn);
return true;
}
示例3: process
import org.apache.thrift.TApplicationException; //導入依賴的package包/類
@Override
public final boolean process(final TProtocol in, final TProtocol out)
throws TException {
final TMessage msg = in.readMessageBegin();
final ProcessFunction<LocatorServiceImpl, ?> fn = this.fnMap
.get(msg.name);
if (fn != null) {
fn.process(msg.seqid, in, out, this.inst);
// terminate connection on receiving closeConnection
// direct class comparison should be the fastest way
return fn.getClass() != LocatorService.Processor.closeConnection.class;
}
else {
TProtocolUtil.skip(in, TType.STRUCT);
in.readMessageEnd();
TApplicationException x = new TApplicationException(
TApplicationException.UNKNOWN_METHOD, "Invalid method name: '"
+ msg.name + "'");
out.writeMessageBegin(new TMessage(msg.name, TMessageType.EXCEPTION,
msg.seqid));
x.write(out);
out.writeMessageEnd();
out.getTransport().flush();
return true;
}
}
示例4: read
import org.apache.thrift.TApplicationException; //導入依賴的package包/類
/**
* 讀取操作
*/
@Override
public void read(TProtocol iprot) throws TException {
if (!"org.apache.thrift.scheme.StandardScheme".equals(iprot.getScheme().getName()))
throw new TApplicationException("Service scheme must be 'org.apache.thrift.scheme.StandardScheme' !");
TField schemeField;
iprot.readStructBegin();
while (Boolean.TRUE) {
schemeField = iprot.readFieldBegin();
if (schemeField.type == TType.STOP)
break;
if (schemeField.type == TType.STRING)
str = iprot.readString();
else
throw new TApplicationException("field type must be 'String' !");
iprot.readFieldEnd();
}
iprot.readStructEnd();
}
示例5: handleTApplicationException
import org.apache.thrift.TApplicationException; //導入依賴的package包/類
void handleTApplicationException(Throwable cause,
Optional<StreamOp> op,
SocketAddress addr,
ProxyClient sc) {
TApplicationException ex = (TApplicationException) cause;
if (ex.getType() == TApplicationException.UNKNOWN_METHOD) {
// if we encountered unknown method exception on thrift server, it means this proxy
// has problem. we should remove it from routing service, clean up ownerships
routingService.removeHost(addr, cause);
onServerLeft(addr, sc);
if (op.isPresent()) {
ownershipCache.removeOwnerFromStream(op.get().stream, addr, cause.getMessage());
doSend(op.get(), addr);
}
} else {
handleException(cause, op, addr);
}
}
示例6: releaseResource
import org.apache.thrift.TApplicationException; //導入依賴的package包/類
@Override
public void releaseResource(String handle, List<Integer> idList)
throws TException, InvalidSessionHandle, SafeModeException {
checkSafeMode("releaseResource");
try {
LOG.info("Release " + idList.size() + " resources from session: " +
handle);
sessionManager.heartbeat(handle);
Collection<ResourceGrant> canceledGrants =
sessionManager.releaseResource(handle, idList);
if (canceledGrants == null) {
// LOG.info("No canceled grants for session " + handle);
return;
}
for (ResourceGrant grant: canceledGrants) {
nodeManager.cancelGrant(grant.nodeName, handle, grant.id);
metrics.releaseResource(grant.type);
}
scheduler.notifyScheduler();
} catch (RuntimeException e) {
throw new TApplicationException(e.getMessage());
}
}
示例7: createTranslator
import org.apache.thrift.TApplicationException; //導入依賴的package包/類
private MessageTransalator createTranslator(TProtocolFactory protocolFactory) {
return new MessageTransalator(protocolFactory, new AuthTokenExchanger<AuthToken, UserData>() {
@Override
public AuthToken createEmptyAuthToken() {
return new AuthToken();
}
@Override
public UserData process(AuthToken authToken) throws TException {
if ("sometoken".equals(authToken.getToken())) {
return new UserData().setId("user1");
}
if ("fataltoken".equals(authToken.getToken())) {
throw new TApplicationException(TApplicationException.INTERNAL_ERROR, "fatal!!!");
}
throw new UnauthorizedException("token is invalid");
}
});
}
示例8: readApplicationException
import org.apache.thrift.TApplicationException; //導入依賴的package包/類
private static TApplicationException readApplicationException(int seqId, ThriftFunction func,
TProtocol inputProtocol,
TMessage msg) throws TException {
if (msg.seqid != seqId) {
throw new TApplicationException(TApplicationException.BAD_SEQUENCE_ID);
}
if (!func.name().equals(msg.name)) {
return new TApplicationException(TApplicationException.WRONG_METHOD_NAME, msg.name);
}
if (msg.type == TMessageType.EXCEPTION) {
final TApplicationException appEx = TApplicationExceptions.read(inputProtocol);
inputProtocol.readMessageEnd();
return appEx;
}
return null;
}
示例9: newObjectMapper
import org.apache.thrift.TApplicationException; //導入依賴的package包/類
/**
* Returns newly created {@link ObjectMapper} which is configured properly to serialize some knows classes
* in a good way.
*/
public static ObjectMapper newObjectMapper(SimpleModule... userModules) {
ObjectMapper objectMapper = new ObjectMapper();
SimpleModule module = new SimpleModule();
module.addSerializer(TMessage.class, new TMessageSerializer());
module.addSerializer(TBase.class, new TBaseSerializer());
module.addSerializer(TApplicationException.class, new TApplicationExceptionSerializer());
module.addSerializer(ThriftCall.class, new ThriftCallSerializer());
module.addSerializer(ThriftReply.class, new ThriftReplySerializer());
objectMapper.registerModule(module);
for (SimpleModule userModule : userModules) {
objectMapper.registerModule(userModule);
}
return objectMapper;
}
示例10: getResult
import org.apache.thrift.TApplicationException; //導入依賴的package包/類
/**
* Converts the specified {@code result} into a Java object.
*/
public Object getResult(TBase<?, ?> result) throws TException {
for (TFieldIdEnum fieldIdEnum : exceptionFields()) {
if (ThriftFieldAccess.isSet(result, fieldIdEnum)) {
throw (TException) ThriftFieldAccess.get(result, fieldIdEnum);
}
}
final TFieldIdEnum successField = successField();
if (successField == null) { //void method
return null;
} else if (ThriftFieldAccess.isSet(result, successField)) {
return ThriftFieldAccess.get(result, successField);
} else {
throw new TApplicationException(
TApplicationException.MISSING_RESULT,
result.getClass().getName() + '.' + successField.getFieldName());
}
}
示例11: testSync_FileService_create_exception
import org.apache.thrift.TApplicationException; //導入依賴的package包/類
@Test
public void testSync_FileService_create_exception() throws Exception {
FileService.Client client = new FileService.Client.Factory().getClient(inProto, outProto);
client.send_create(BAZ);
assertThat(out.length(), is(greaterThan(0)));
RuntimeException exception = Exceptions.clearTrace(new RuntimeException());
THttpService service = THttpService.of((FileService.Iface) path -> {
throw exception;
}, defaultSerializationFormat);
invoke(service);
try {
client.recv_create();
fail(TApplicationException.class.getSimpleName() + " not raised.");
} catch (TApplicationException e) {
assertThat(e.getType(), is(TApplicationException.INTERNAL_ERROR));
assertThat(e.getMessage(), containsString(exception.toString()));
}
}
示例12: testAsync_FileService_create_exception
import org.apache.thrift.TApplicationException; //導入依賴的package包/類
@Test
public void testAsync_FileService_create_exception() throws Exception {
FileService.Client client = new FileService.Client.Factory().getClient(inProto, outProto);
client.send_create(BAZ);
assertThat(out.length(), is(greaterThan(0)));
RuntimeException exception = Exceptions.clearTrace(new RuntimeException());
THttpService service = THttpService.of(
(FileService.AsyncIface) (path, resultHandler) ->
resultHandler.onError(exception), defaultSerializationFormat);
invoke(service);
try {
client.recv_create();
fail(TApplicationException.class.getSimpleName() + " not raised.");
} catch (TApplicationException e) {
assertThat(e.getType(), is(TApplicationException.INTERNAL_ERROR));
assertThat(e.getMessage(), containsString(exception.toString()));
}
}
示例13: parse_text
import org.apache.thrift.TApplicationException; //導入依賴的package包/類
public List<ParseTree> parse_text(String text, List<String> outputFormat) throws TApplicationException
{
List<ParseTree> results = new ArrayList<ParseTree>();
try
{
treePrinter = ParserUtil.setOptions(outputFormat, tlp);
// assume no tokenization was done; use Stanford's default org.ets.research.nlp.stanford_thrift.tokenizer
DocumentPreprocessor preprocess = new DocumentPreprocessor(new StringReader(text));
Iterator<List<HasWord>> foundSentences = preprocess.iterator();
while (foundSentences.hasNext())
{
Tree parseTree = parser.apply(foundSentences.next());
results.add(new ParseTree(ParserUtil.TreeObjectToString(parseTree, treePrinter), parseTree.score()));
}
}
catch (Exception e)
{
// FIXME
throw new TApplicationException(TApplicationException.INTERNAL_ERROR, e.getMessage());
}
return results;
}
示例14: parse_tokens
import org.apache.thrift.TApplicationException; //導入依賴的package包/類
/**
* @param tokens One sentence worth of tokens at a time.
* @return A ParseTree object of the String representation of the tree, plus its probability.
* @throws TApplicationException
*/
public ParseTree parse_tokens(List<String> tokens, List<String> outputFormat) throws TApplicationException
{
try
{
treePrinter = ParserUtil.setOptions(outputFormat, tlp);
// a single sentence worth of tokens
String[] tokenArray = new String[tokens.size()];
tokens.toArray(tokenArray);
List<CoreLabel> crazyStanfordFormat = Sentence.toCoreLabelList(tokenArray);
Tree parseTree = parser.apply(crazyStanfordFormat);
return new ParseTree(ParserUtil.TreeObjectToString(parseTree, treePrinter), parseTree.score());
}
catch (Exception e)
{
// FIXME
throw new TApplicationException(TApplicationException.INTERNAL_ERROR, e.getMessage());
}
}
示例15: parse_tagged_sentence
import org.apache.thrift.TApplicationException; //導入依賴的package包/類
public ParseTree parse_tagged_sentence(String taggedSentence, List<String> outputFormat, String divider) throws TApplicationException
{
try
{
treePrinter = ParserUtil.setOptions(outputFormat, tlp);
// a single sentence worth of tagged text, better be properly tokenized >:D
Tree parseTree = parser.apply(CoreNLPThriftUtil.getListOfTaggedWordsFromTaggedSentence(taggedSentence, divider));
return new ParseTree(ParserUtil.TreeObjectToString(parseTree, treePrinter), parseTree.score());
}
catch (Exception e)
{
// FIXME
throw new TApplicationException(TApplicationException.INTERNAL_ERROR, e.getMessage());
}
}