This browser is no longer supported.

Upgrade to Microsoft Edge to take advantage of the latest features, security updates, and technical support.

Download Microsoft Edge More info about Internet Explorer and Microsoft Edge

Azure Core Netty HTTP client is a plugin for the azure-core HTTP client API.

Getting started

Prerequisites

  • A Java Development Kit (JDK) , version 8 or later.
  • Include the package

    Include the BOM file

    Please include the azure-sdk-bom to your project to take dependency on the General Availability (GA) version of the library. In the following snippet, replace the {bom_version_to_target} placeholder with the version number. To learn more about the BOM, see the AZURE SDK BOM README .

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>com.azure</groupId>
                <artifactId>azure-sdk-bom</artifactId>
                <version>{bom_version_to_target}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
    

    and then include the direct dependency in the dependencies section without the version tag.

    <dependencies>
      <dependency>
        <groupId>com.azure</groupId>
        <artifactId>azure-core-http-netty</artifactId>
      </dependency>
    </dependencies>
    

    Include direct dependency

    If you want to take dependency on a particular version of the library that is not present in the BOM, add the direct dependency to your project as follows.

    <dependency>
        <groupId>com.azure</groupId>
        <artifactId>azure-core-http-netty</artifactId>
        <version>1.13.2</version>
    </dependency>
    

    Key concepts

    Examples

    The following sections provide several code snippets covering some of the most common client configuration scenarios.

  • Create a Simple Client
  • Create a Client with Proxy
  • Create a Client with HTTP/2 Support
  • Create a Client with Custom Max Chunk Size
  • Create a Simple Client

    Create a Netty HttpClient that uses port 80 and has no proxy.

    HttpClient client = new NettyAsyncHttpClientBuilder().build();
    

    Create a Client with Proxy

    Create a Netty HttpClient that is using a proxy.

    HttpClient client = new NettyAsyncHttpClientBuilder()
        .proxy(new ProxyOptions(ProxyOptions.Type.HTTP, new InetSocketAddress("<proxy-host>", 8888)))
        .build();
    

    Create a Client with HTTP/2 Support

    Create a Netty HttpClient that supports both the HTTP/1.1 and HTTP/2 protocols, with HTTP/2 being the preferred protocol.

    // Constructs an HttpClient that supports both HTTP/1.1 and HTTP/2 with HTTP/2 being the preferred protocol.
    HttpClient client = new NettyAsyncHttpClientBuilder(reactor.netty.http.client.HttpClient.create()
        .protocol(HttpProtocol.HTTP11, HttpProtocol.H2))
        .build();
    

    It is also possible to create a Netty HttpClient that only supports HTTP/2.

    // Constructs an HttpClient that only supports HTTP/2.
    HttpClient client = new NettyAsyncHttpClientBuilder(reactor.netty.http.client.HttpClient.create()
        .protocol(HttpProtocol.H2))
        .build();
    

    Create a Client with Custom Max Chunk Size

    Create a Netty HttpClient that uses a custom max chunk size.

    // Constructs an HttpClient with a modified max chunk size.
    // Max chunk size modifies the maximum size of ByteBufs returned by Netty (later converted to ByteBuffer).
    // Changing the chunk size can positively impact performance of APIs such as Storage's download to file methods
    // provided in azure-storage-blob, azure-storage-file-datalake, and azure-storage-file-shares (32KB - 64KB have
    // shown the most consistent improvement).
    HttpClient httpClient = new NettyAsyncHttpClientBuilder(reactor.netty.http.client.HttpClient.create()
        .httpResponseDecoder(httpResponseDecoderSpec -> httpResponseDecoderSpec.maxChunkSize(64 * 1024)))
        .build();
    

    Next steps

    Get started with Azure libraries that are built using Azure Core.

    Troubleshooting

    If you encounter any bugs, please file issues via GitHub Issues or checkout StackOverflow for Azure Java SDK.

    Enabling Logging

    Azure SDKs for Java provide a consistent logging story to help aid in troubleshooting application errors and expedite their resolution. The logs produced will capture the flow of an application before reaching the terminal state to help locate the root issue. View the logging wiki for guidance about enabling logging.

    Contributing

    For details on contributing to this repository, see the contributing guide.

  • Fork it
  • Create your feature branch (git checkout -b my-new-feature)
  • Commit your changes (git commit -am 'Add some feature')
  • Push to the branch (git push origin my-new-feature)
  • Create new Pull Request
  •