Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Check if channel is nil before updating it #150

Merged
merged 2 commits into from
Feb 9, 2023

Conversation

julienschmidt
Copy link
Contributor

In observed the following panic in the wild:

panic: runtime error: invalid memory address or nil pointer dereference
[signal SIGSEGV: segmentation violation code=0x1 addr=0x54 pc=0x104cf3c]

goroutine 144 [running]:
github.com/rabbitmq/amqp091-go.(*Channel).setClosed(...)
	/home/runner/go/pkg/mod/github.com/rabbitmq/amqp091-go@v1.5.0/channel.go:94
github.com/rabbitmq/amqp091-go.updateChannel(...)
	/home/runner/go/pkg/mod/github.com/rabbitmq/amqp091-go@v1.5.0/types.go:329
github.com/rabbitmq/amqp091-go.(*Connection).dispatchN(0xc000b2ea00, {0x1d5c150, 0xc00096f1b8?})
	/home/runner/go/pkg/mod/github.com/rabbitmq/amqp091-go@v1.5.0/connection.go:539 +0xbc
github.com/rabbitmq/amqp091-go.(*Connection).demux(0xc00039cf28?, {0x1d5c150, 0xc00096f1b8})
	/home/runner/go/pkg/mod/github.com/rabbitmq/amqp091-go@v1.5.0/connection.go:500 +0x5b
github.com/rabbitmq/amqp091-go.(*Connection).reader(0xc000b2ea00, {0x1d57540?, 0xc0004620c8?})
	/home/runner/go/pkg/mod/github.com/rabbitmq/amqp091-go@v1.5.0/connection.go:600 +0x23d
created by github.com/rabbitmq/amqp091-go.Open
	/home/runner/go/pkg/mod/github.com/rabbitmq/amqp091-go@v1.5.0/connection.go:265 +0x34c

Trying to understand what happens, it turns out the nil pointer deference here https://github.com/rabbitmq/amqp091-go/blob/v1.5.0/channel.go#L94 actually seems the be caused by the map access here https://github.com/rabbitmq/amqp091-go/blob/v1.5.0/connection.go#L538, which returns nil if the key doesn't exist / the map is empty.
Thus, a check whether the channel is nil is missing.

Copy link
Contributor

@lukebakken lukebakken left a comment

Choose a reason for hiding this comment

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

Thanks for your submission.

If channel is nil at this spot, it seems to be indicative of a bug somewhere else that I would like to track down, rather than just checking for nil.

Is there a reliable way to reproduce this scenario?

@lukebakken lukebakken added this to the 1.6.0 milestone Jan 5, 2023
@lukebakken lukebakken self-assigned this Jan 5, 2023
@julienschmidt
Copy link
Contributor Author

julienschmidt commented Jan 5, 2023

I need to investigate a bit further, but telling from the logs, the following might have happened:

  1. An exchange that did not exist on the vhost was accessed, causing an exception: Exception (404) Reason: "NOT_FOUND - no exchange 'XXX' in vhost '/'"
  2. The wrapper library (https://github.com/go-redis/redis https://github.com/wagslane/go-rabbitmq) reconnected (new connection)
  3. Right after establishing the new connection, it received frames it was not quite prepared for?

@michaelklishin
Copy link
Member

I doubt that https://github.com/go-redis/redis is a wrapper for this library. In addition, the 404 exception in your example would not close the connection as it is a channel exception. No new frames would be sent on this channel but it could that there were some in flight.

So the improvement would be: drop frames for channels that are not currently open (that the client knows of) with a warning, several other clients do something like that.

@lukebakken lukebakken removed this from the 1.6.0 milestone Jan 20, 2023
@julienschmidt
Copy link
Contributor Author

Sorry, copied the wrong link 🤦‍♂️
https://github.com/wagslane/go-rabbitmq is the wrapper library

@lukebakken lukebakken added this to the 1.7.0 milestone Feb 8, 2023
@lukebakken
Copy link
Contributor

@julienschmidt thanks again for your pull request. Considering that the channel is checked for nil soon after, it's reasonable to also check where you indicate. I've added @michaelklishin's suggestion to log dropped frames.

@michaelklishin michaelklishin merged commit 30f5d55 into rabbitmq:main Feb 9, 2023
@julienschmidt julienschmidt deleted the patch-1 branch February 11, 2023 08:26
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants