com.twitter.finagle.thrift

ThriftClient

class ThriftClient extends DefaultClient[ThriftClientRequest, Array[Byte]]

A Finagle Client for Apache Thrift.

The client uses the standard thrift protocols, with support for both framed and buffered transports. Finagle attempts to upgrade the protocol in order to ship an extra envelope carrying trace IDs and client IDs associated with the request. These are used by Finagle's tracing facilities and may be collected via aggregators like Zipkin.

The negotiation is simple: on connection establishment, an improbably-named method is dispatched on the server. If that method isn't found, we are dealing with a legacy thrift server, and the standard protocol is used. If the remote server is also a finagle server (or any other supporting this extension), we reply to the request, and every subsequent request is dispatched with an envelope carrying trace metadata. The envelope itself is also a Thrift struct described here.

Linear Supertypes
DefaultClient[ThriftClientRequest, Array[Byte]], Serializable, Serializable, Product, Equals, Client[ThriftClientRequest, Array[Byte]], AnyRef, Any
Ordering
  1. Alphabetic
  2. By inheritance
Inherited
  1. ThriftClient
  2. DefaultClient
  3. Serializable
  4. Serializable
  5. Product
  6. Equals
  7. Client
  8. AnyRef
  9. Any
  1. Hide All
  2. Show all
Learn more about member selection
Visibility
  1. Public
  2. All

Instance Constructors

  1. new ThriftClient(transporter: (SocketAddress, StatsReceiver) ⇒ Future[Transport[ThriftClientRequest, Array[Byte]]], protocolFactory: TProtocolFactory, serviceName: String = "unknown", clientId: Option[ClientId] = scala.None)

Value Members

  1. final def !=(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  2. final def !=(arg0: Any): Boolean

    Definition Classes
    Any
  3. final def ##(): Int

    Definition Classes
    AnyRef → Any
  4. final def ==(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  5. final def ==(arg0: Any): Boolean

    Definition Classes
    Any
  6. final def asInstanceOf[T0]: T0

    Definition Classes
    Any
  7. val bindStack: (SocketAddress) ⇒ ServiceFactory[ThriftClientRequest, Array[Byte]]

    Definition Classes
    DefaultClient
  8. def clone(): AnyRef

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws()
  9. val endpointer: (SocketAddress, StatsReceiver) ⇒ ServiceFactory[ThriftClientRequest, Array[Byte]]

    Definition Classes
    DefaultClient
  10. final def eq(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  11. val failFast: Boolean

    Definition Classes
    DefaultClient
  12. val failureAccrual: (ServiceFactory[ThriftClientRequest, Array[Byte]]) ⇒ ServiceFactory[ThriftClientRequest, Array[Byte]]

    Definition Classes
    DefaultClient
  13. def finalize(): Unit

    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws()
  14. final def getClass(): Class[_]

    Definition Classes
    AnyRef → Any
  15. val globalStatsReceiver: RollupStatsReceiver

    Definition Classes
    DefaultClient
  16. val hostStatsReceiver: StatsReceiver

    Definition Classes
    DefaultClient
  17. final def isInstanceOf[T0]: Boolean

    Definition Classes
    Any
  18. val loadBalancer: WeightedLoadBalancerFactory

    Definition Classes
    DefaultClient
  19. val maxIdletime: Duration

    Definition Classes
    DefaultClient
  20. val maxLifetime: Duration

    Definition Classes
    DefaultClient
  21. val monitor: Monitor

    Definition Classes
    DefaultClient
  22. val name: String

    Definition Classes
    DefaultClient
  23. final def ne(arg0: AnyRef): Boolean

    Definition Classes
    AnyRef
  24. def newClient(dest: Name, label: String): ServiceFactory[ThriftClientRequest, Array[Byte]]

    Definition Classes
    ThriftClient → DefaultClient → Client
  25. final def newClient(dest: String, label: String): ServiceFactory[ThriftClientRequest, Array[Byte]]

    Definition Classes
    Client
  26. final def newClient(dest: String): ServiceFactory[ThriftClientRequest, Array[Byte]]

    Definition Classes
    Client
  27. final def newService(dest: String): Service[ThriftClientRequest, Array[Byte]]

    Definition Classes
    Client
  28. final def newService(dest: Name, label: String): Service[ThriftClientRequest, Array[Byte]]

    Definition Classes
    Client
  29. val newStack: (Name) ⇒ ServiceFactory[ThriftClientRequest, Array[Byte]]

    Definition Classes
    DefaultClient
  30. val newStack0: (Name) ⇒ ServiceFactory[ThriftClientRequest, Array[Byte]]

    Definition Classes
    DefaultClient
  31. final def notify(): Unit

    Definition Classes
    AnyRef
  32. final def notifyAll(): Unit

    Definition Classes
    AnyRef
  33. val pool: (StatsReceiver) ⇒ (ServiceFactory[ThriftClientRequest, Array[Byte]]) ⇒ ServiceFactory[ThriftClientRequest, Array[Byte]]

    Definition Classes
    DefaultClient
  34. val reporter: ReporterFactory

    Definition Classes
    DefaultClient
  35. val requestTimeout: Duration

    Definition Classes
    DefaultClient
  36. val serviceTimeout: Duration

    Definition Classes
    DefaultClient
  37. val statsReceiver: StatsReceiver

    Definition Classes
    DefaultClient
  38. def superNewClient(dest: Name, label: String): ServiceFactory[ThriftClientRequest, Array[Byte]]

    Attributes
    protected
  39. final def synchronized[T0](arg0: ⇒ T0): T0

    Definition Classes
    AnyRef
  40. val timer: Timer

    Definition Classes
    DefaultClient
  41. val tracer: Tracer

    Definition Classes
    DefaultClient
  42. final def wait(): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws()
  43. final def wait(arg0: Long, arg1: Int): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws()
  44. final def wait(arg0: Long): Unit

    Definition Classes
    AnyRef
    Annotations
    @throws()

Deprecated Value Members

  1. final def newClient(dest: Group[SocketAddress]): ServiceFactory[ThriftClientRequest, Array[Byte]]

    Definition Classes
    Client
    Annotations
    @deprecated
    Deprecated

    (Since version 6.7.x) Use destination names

  2. final def newService(dest: Group[SocketAddress]): Service[ThriftClientRequest, Array[Byte]]

    Definition Classes
    Client
    Annotations
    @deprecated
    Deprecated

    (Since version 6.7.x) Use destination names

Inherited from DefaultClient[ThriftClientRequest, Array[Byte]]

Inherited from Serializable

Inherited from Serializable

Inherited from Product

Inherited from Equals

Inherited from Client[ThriftClientRequest, Array[Byte]]

Inherited from AnyRef

Inherited from Any

Ungrouped