Skip to content

Conversation

wendigo
Copy link
Contributor

@wendigo wendigo commented Oct 9, 2025

Description

Additional context and related issues

Release notes

(x) This is not user-visible or is docs only, and no release notes are required.
( ) Release notes are required. Please propose a release note for me.
( ) Release notes are required, with the following suggested text:

## Section
* Fix some things. ({issue}`issuenumber`)

Summary by Sourcery

Enable HTTP/2 by default and activate virtual threads for internal HTTP communication and the HTTP server, adjust connection pool settings accordingly, and update tests to reflect new defaults.

New Features:

  • Enable HTTP/2 by default in the internal communication HTTP client
  • Activate virtual threads for both the HTTP server and internal HTTP client

Enhancements:

  • Adjust max connections per server to 64 when HTTP/2 is enabled (250 otherwise)

Tests:

  • Update InternalCommunicationConfig tests to reflect the new default HTTP/2 setting and explicit property mappings

@cla-bot cla-bot bot added the cla-signed label Oct 9, 2025
Copy link

sourcery-ai bot commented Oct 9, 2025

Reviewer's guide (collapsed on small PRs)

Reviewer's Guide

Internal communication now defaults to HTTP/2 with adjusted connection limits and uses virtual threads for both server HTTP listeners and internal HTTP clients.

Sequence diagram for HTTP client configuration with HTTP/2 and virtual threads

sequenceDiagram
participant CoordinatorModule
participant InternalCommunicationConfig
participant HttpClientConfig
CoordinatorModule->>InternalCommunicationConfig: buildConfigObject()
CoordinatorModule->>HttpClientConfig: withConfigDefaults()
HttpClientConfig->>InternalCommunicationConfig: isHttp2Enabled()
alt HTTP/2 enabled
    HttpClientConfig->>HttpClientConfig: setMaxConnectionsPerServer(64)
else HTTP/2 not enabled
    HttpClientConfig->>HttpClientConfig: setMaxConnectionsPerServer(250)
end
HttpClientConfig->>HttpClientConfig: setHttp2Enabled()
HttpClientConfig->>HttpClientConfig: setUseVirtualThreads(true)
Loading

Class diagram for updated InternalCommunicationConfig and HttpClientConfig

classDiagram
class InternalCommunicationConfig {
  - String sharedSecret
  - boolean http2Enabled = true
  - boolean httpsRequired
  - String keyStorePath
  - String keyStorePassword
}
class HttpClientConfig {
  - boolean http2Enabled
  - boolean useVirtualThreads
  - Duration idleTimeout
  - Duration requestTimeout
  - int maxConnectionsPerServer
}
InternalCommunicationConfig --> HttpClientConfig : configures
Loading

File-Level Changes

Change Details Files
Default HTTP/2 enabled and config class and tests updated accordingly
  • Initialize http2Enabled to true in InternalCommunicationConfig
  • Update TestInternalCommunicationConfig to expect http2Enabled=true by default
  • Adjust explicit property mapping tests to reflect default HTTP/2 behavior
core/trino-main/src/main/java/io/trino/server/InternalCommunicationConfig.java
core/trino-main/src/test/java/io/trino/server/TestInternalCommunicationConfig.java
CoordinatorModule dynamically sets connection pool size based on HTTP/2 flag
  • Read InternalCommunicationConfig in CoordinatorModule
  • Use isHttp2Enabled() to choose maxConnectionsPerServer 64 for HTTP/2 or 250 otherwise
core/trino-main/src/main/java/io/trino/server/CoordinatorModule.java
Enable virtual thread support for server and internal HTTP clients
  • Call httpServerBinder(binder).enableVirtualThreads() in ServerMainModule
  • Set useVirtualThreads=true in InternalCommunicationHttpClientModule
core/trino-main/src/main/java/io/trino/server/ServerMainModule.java
core/trino-main/src/main/java/io/trino/server/InternalCommunicationHttpClientModule.java

Tips and commands

Interacting with Sourcery

  • Trigger a new review: Comment @sourcery-ai review on the pull request.
  • Continue discussions: Reply directly to Sourcery's review comments.
  • Generate a GitHub issue from a review comment: Ask Sourcery to create an
    issue from a review comment by replying to it. You can also reply to a
    review comment with @sourcery-ai issue to create an issue from it.
  • Generate a pull request title: Write @sourcery-ai anywhere in the pull
    request title to generate a title at any time. You can also comment
    @sourcery-ai title on the pull request to (re-)generate the title at any time.
  • Generate a pull request summary: Write @sourcery-ai summary anywhere in
    the pull request body to generate a PR summary at any time exactly where you
    want it. You can also comment @sourcery-ai summary on the pull request to
    (re-)generate the summary at any time.
  • Generate reviewer's guide: Comment @sourcery-ai guide on the pull
    request to (re-)generate the reviewer's guide at any time.
  • Resolve all Sourcery comments: Comment @sourcery-ai resolve on the
    pull request to resolve all Sourcery comments. Useful if you've already
    addressed all the comments and don't want to see them anymore.
  • Dismiss all Sourcery reviews: Comment @sourcery-ai dismiss on the pull
    request to dismiss all existing Sourcery reviews. Especially useful if you
    want to start fresh with a new review - don't forget to comment
    @sourcery-ai review to trigger a new review!

Customizing Your Experience

Access your dashboard to:

  • Enable or disable review features such as the Sourcery-generated pull request
    summary, the reviewer's guide, and others.
  • Change the review language.
  • Add, remove or edit custom review instructions.
  • Adjust other review settings.

Getting Help

@starburstdata-automation
Copy link

starburstdata-automation commented Oct 9, 2025

Started benchmark workflow for this PR with test type = iceberg/sf1000_parquet_part.

Building Trino finished with status: success
Benchmark finished with status: success
Comparing results to the static baseline values, follow above workflow link for more details/logs.
Status message: NO Regression found.
Building Trino finished with status: success
Benchmark finished with status: success
Comparing results to the static baseline values, follow above workflow link for more details/logs.
Status message: NO Regression found.
Benchmark Comparison to the closest run from Master: Report

Copy link

@sourcery-ai sourcery-ai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hey there - I've reviewed your changes and they look great!

Prompt for AI Agents
Please address the comments from this code review:

## Individual Comments

### Comment 1
<location> `core/trino-main/src/main/java/io/trino/server/CoordinatorModule.java:365-368` </location>
<code_context>
                     config.setIdleTimeout(new Duration(60, SECONDS));
                     config.setRequestTimeout(new Duration(20, SECONDS));
-                    config.setMaxConnectionsPerServer(250);
+                    if (internalCommunicationConfig.isHttp2Enabled()) {
+                        config.setMaxConnectionsPerServer(64);
+                    }
+                    else {
+                        config.setMaxConnectionsPerServer(250);
+                    }
</code_context>

<issue_to_address>
**issue (performance):** Connection limits are now conditional on HTTP/2, which may affect scaling.

Verify that 64 connections per server is adequate for your HTTP/2 workloads, or consider making this limit configurable to better support varying traffic demands.
</issue_to_address>

### Comment 2
<location> `core/trino-main/src/test/java/io/trino/server/TestInternalCommunicationConfig.java:35` </location>
<code_context>
         assertRecordedDefaults(recordDefaults(InternalCommunicationConfig.class)
                 .setSharedSecret(null)
-                .setHttp2Enabled(false)
+                .setHttp2Enabled(true)
                 .setHttpsRequired(false)
                 .setKeyStorePath(null)
</code_context>

<issue_to_address>
**suggestion (testing):** Test for default value of http2Enabled updated to true.

Also add a test case for when http2Enabled is unset to confirm the default value is correctly applied.
</issue_to_address>

Sourcery is free for open source - if you like our reviews please consider sharing them ✨
Help me be more useful! Please click 👍 or 👎 on each comment and I'll use the feedback to improve your reviews.

@starburstdata-automation
Copy link

starburstdata-automation commented Oct 9, 2025

Started benchmark workflow for this PR with test type = iceberg/sf1000_parquet_unpart.

Building Trino finished with status: success
Benchmark finished with status: success
Comparing results to the static baseline values, follow above workflow link for more details/logs.
Status message: NO Regression found.
Benchmark Comparison to the closest run from Master: Report

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Development

Successfully merging this pull request may close these issues.

2 participants