Skip to content

Commit

Permalink
docs(pubsub): clarify NumGoroutines configures number of streams (#7874)
Browse files Browse the repository at this point in the history
* docs(pubsub): clarify NumGoroutines configures number of streams

* explicitly discourage setting a high number of streams

* fix formatting in comment
  • Loading branch information
hongalex authored May 3, 2023
1 parent d661fe9 commit 8ac4432
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 10 deletions.
19 changes: 12 additions & 7 deletions pubsub/doc.go
Original file line number Diff line number Diff line change
Expand Up @@ -91,15 +91,20 @@ pull method.
# Streams Management
Streams used for streaming pull are configured by setting sub.ReceiveSettings.NumGoroutines.
However, the total number of streams possible is capped by the gRPC connection pool setting.
By default, the number of connections in the pool is min(4,GOMAXPROCS).
If you have 4 or more CPU cores, the default setting allows a maximum of 400 streams which is still a good default for most cases.
If you want to have more open streams (such as for low CPU core machines), you should pass in the grpc option as described below:
The number of StreamingPull connections can be configured by setting sub.ReceiveSettings.NumGoroutines.
The default value of 10 means the client library will maintain 10 StreamingPull connections.
This is more than sufficient for most use cases, as StreamingPull connections can handle up to
10 MB/s https://cloud.google.com/pubsub/quotas#resource_limits. In some cases, using too many streams
can lead to client library behaving poorly as the application becomes I/O bound.
By default, the number of connections in the gRPC conn pool is min(4,GOMAXPROCS). Each connection supports
up to 100 streams. Thus, if you have 4 or more CPU cores, the default setting allows a maximum of 400 streams
which is already excessive for most use cases.
If you want to change the limits on the number of streams, you can change the number of connections
in the gRPC connection pool as shown below:
opts := []option.ClientOption{
option.WithGRPCConnectionPool(8),
option.WithGRPCConnectionPool(2),
}
client, err := pubsub.NewClient(ctx, projID, opts...)
Expand Down
5 changes: 2 additions & 3 deletions pubsub/subscription.go
Original file line number Diff line number Diff line change
Expand Up @@ -690,9 +690,8 @@ type ReceiveSettings struct {
// The default is false.
UseLegacyFlowControl bool

// NumGoroutines is the number of goroutines that each datastructure along
// the Receive path will spawn. Adjusting this value adjusts concurrency
// along the receive path.
// NumGoroutines sets the number of StreamingPull streams to pull messages
// from the subscription.
//
// NumGoroutines defaults to DefaultReceiveSettings.NumGoroutines.
//
Expand Down

0 comments on commit 8ac4432

Please sign in to comment.