Package com.fluxcapacitor.edge.hystrix

Source Code of com.fluxcapacitor.edge.hystrix.AddLogCommand

/*
*   Copyright 2012 Chris Fregly
*
*    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.fluxcapacitor.edge.hystrix;

import java.net.URI;
import java.net.URLEncoder;

import javax.ws.rs.core.MultivaluedMap;

import org.apache.commons.io.IOUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.fluxcapacitor.core.FluxConstants;
import com.google.common.base.Charsets;
import com.netflix.client.ClientFactory;
import com.netflix.hystrix.HystrixCommand;
import com.netflix.hystrix.HystrixCommandGroupKey;
import com.netflix.hystrix.HystrixCommandKey;
import com.netflix.hystrix.HystrixThreadPoolKey;
import com.netflix.niws.client.http.HttpClientRequest;
import com.netflix.niws.client.http.HttpClientRequest.Verb;
import com.netflix.niws.client.http.HttpClientResponse;
import com.netflix.niws.client.http.RestClient;
import com.sun.jersey.core.util.MultivaluedMapImpl;

/**
* Add a log.
*
* Example of a basic command with fallback.
*
* By default, timeout is set to 1000ms per the following configuration
* property:
*
*     hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=1000
*
* This default can be overridden using any archaius configuration source.
*
* Uses Netflix Ribbon as the communication mechanism to the middletier service.
*
* @author Chris Fregly (chris@fregly.com)
*/
public class AddLogCommand extends HystrixCommand<String> {
  private static final Logger logger = LoggerFactory.getLogger(AddLogCommand.class);
 
  private final String key;
  private final String log;
 
  public AddLogCommand(String key, String log) {
    super(
        Setter.withGroupKey(
            HystrixCommandGroupKey.Factory
                .asKey(FluxConstants.MIDDLETIER_HYSTRIX_GROUP))
            .andCommandKey(
                HystrixCommandKey.Factory
                    .asKey(FluxConstants.MIDDLETIER_HYSTRIX_ADD_LOG_COMMAND_KEY))
            .andThreadPoolKey(
                HystrixThreadPoolKey.Factory
                    .asKey(FluxConstants.MIDDLETIER_HYSTRIX_THREAD_POOL)));
   
    this.key = key;
    this.log = log;
  }

  @Override
  protected String run() {
    try {
      // The named client param must match the prefix for the ribbon
      // configuration specified in the edge.properties file
      RestClient client = (RestClient) ClientFactory
          .getNamedClient("middletier-client");

      MultivaluedMap<String, String> queryParams = new MultivaluedMapImpl();
      queryParams.putSingle("log", URLEncoder.encode(log, Charsets.UTF_8.name()));

      // Note: If running locally on MacOS, you'll need to make sure your
      // /etc/hosts file contains the following entry:
      // 127.0.0.1 <hostname>.local
      // or else this will likely fail.
      HttpClientRequest request = HttpClientRequest
          .newBuilder()
          .setVerb(Verb.POST)
          .setUri(new URI("/service/"
              + FluxConstants.MIDDLETIER_WEB_RESOURCE_ROOT_PATH
              + "/"
              + FluxConstants.MIDDLETIER_WEB_RESOURCE_VERSION
              + "/"
              + FluxConstants.MIDDLETIER_WEB_RESOURCE_ADD_PATH
              + "/"
              + key)
          )
          .setQueryParams(queryParams)
          .build();
     
      HttpClientResponse response = client
          .executeWithLoadBalancer(request);
     
      if (response.getStatus() != 200) { 
        logger.error("error status: {}", response.getStatus());
        throw new Exception("error status: " + response.getStatus());
      }

      return IOUtils.toString(response.getRawEntity(), Charsets.UTF_8);
    } catch (Exception exc) {
      throw new RuntimeException("Exception", exc);
    }
  }

  @Override
  protected String getFallback() {
    return "Fallback:  Great Scott!";
  }
}
TOP

Related Classes of com.fluxcapacitor.edge.hystrix.AddLogCommand

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.