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

Panic on RPC request serving due to concurrent new peer connection #3752

Open
AnnaShaleva opened this issue Dec 13, 2024 · 1 comment
Open
Labels
bug Something isn't working I4 No visible changes network P2P layer S3 Minimally significant U2 Seriously planned
Milestone

Comments

@AnnaShaleva
Copy link
Member

Current Behavior

Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]: INFO        new peer connected        {"addr": "3.112.138.57:61112", "peerCount": 31}
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]: 2024/12/13 09:56:08 http: panic serving 127.0.0.1:43214: runtime error: invalid memory address or nil pointer dereference
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]: goroutine 25293644 [running]:
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]: net/http.(*conn).serve.func1()
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]:         net/http/server.go:1947 +0xbe
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]: panic({0x1193140?, 0x1f51a00?})
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]:         runtime/panic.go:785 +0x132
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]: github.com/nspcc-dev/neo-go/pkg/network.(*Server).ConnectedPeers(0xc000f44a08)
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]:         github.com/nspcc-dev/neo-go/pkg/network/server.go:459 +0x254
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]: github.com/nspcc-dev/neo-go/pkg/services/rpcsrv.(*Server).getPeers(0xc000ea2a08, {0xc000312330?, 0xc000a833d0?, 0x8?})
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]:         github.com/nspcc-dev/neo-go/pkg/services/rpcsrv/server.go:904 +0x8d
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]: github.com/nspcc-dev/neo-go/pkg/services/rpcsrv.(*Server).handleIn(0xc000ea2a08, 0xc002a7ddb0, 0x0)
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]:         github.com/nspcc-dev/neo-go/pkg/services/rpcsrv/server.go:645 +0x60a
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]: github.com/nspcc-dev/neo-go/pkg/services/rpcsrv.(*Server).handleRequest(0xc000ea2a08, 0xc00b47c140, 0x0)
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]:         github.com/nspcc-dev/neo-go/pkg/services/rpcsrv/server.go:571 +0xd1
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]: github.com/nspcc-dev/neo-go/pkg/services/rpcsrv.(*Server).handleHTTPRequest(0xc000ea2a08, {0x15efb60, 0xc001f20620}, 0xc001f38a00)
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]:         github.com/nspcc-dev/neo-go/pkg/services/rpcsrv/server.go:551 +0x9ea
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]: net/http.HandlerFunc.ServeHTTP(0x410845?, {0x15efb60?, 0xc001f20620?}, 0xc001f20601?)
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]:         net/http/server.go:2220 +0x29
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]: net/http.serverHandler.ServeHTTP({0x15e9970?}, {0x15efb60?, 0xc001f20620?}, 0x6?)
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]:         net/http/server.go:3210 +0x8e
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]: net/http.(*conn).serve(0xc0034c0750, {0x15f1980, 0xc0009bbe90})
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]:         net/http/server.go:2092 +0x5d0
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]: created by net/http.(*Server).Serve in goroutine 782
Dec 13 09:56:08 kaede neogo-mainnet-rpc[1894253]:         net/http/server.go:3360 +0x485
Dec 13 09:56:12 kaede neogo-mainnet-rpc[1894253]: INFO        new peer connected        {"addr": "3.112.138.57:20513", "peerCount": 32}
Dec 13 09:56:13 kaede neogo-mainnet-rpc[1894253]: INFO        peer disconnected        {"addr": "3.112.138.57:20513", "error": "read tcp 157.90.177.38:10333->3.112.138.57:20513: read: connection reset by peer", "peerCount": 31}

Expected Behavior

No panic.

@AnnaShaleva AnnaShaleva added bug Something isn't working network P2P layer U2 Seriously planned S3 Minimally significant I4 No visible changes labels Dec 13, 2024
@AnnaShaleva AnnaShaleva added this to the v0.108.0 milestone Dec 13, 2024
@AnnaShaleva AnnaShaleva changed the title Panic on new peer connection Panic on RPC request serving due to concurrent new peer connection Dec 13, 2024
@roman-khimov
Copy link
Member

2025-01-15 08:50:09	2025/01/15 08:50:09 http: panic serving 127.0.0.1:55938: runtime error: invalid memory address or nil pointer dereference
2025-01-15 08:50:09	goroutine 132625680 [running]:
2025-01-15 08:50:09	net/http.(*conn).serve.func1()
2025-01-15 08:50:09		net/http/server.go:1947 +0xbe
2025-01-15 08:50:09	panic({0x1171600?, 0x1ef0dd0?})
2025-01-15 08:50:09		runtime/panic.go:785 +0x132
2025-01-15 08:50:09	github.com/nspcc-dev/neo-go/pkg/network.(*Server).ConnectedPeers(0xc000e7c008)
2025-01-15 08:50:09		github.com/nspcc-dev/neo-go/pkg/network/server.go:462 +0x254
2025-01-15 08:50:09	github.com/nspcc-dev/neo-go/pkg/services/rpcsrv.(*Server).getPeers(0xc000d7a288, {0xc0000ba210?, 0xc00c1ac520?, 0x8?})
2025-01-15 08:50:09		github.com/nspcc-dev/neo-go/pkg/services/rpcsrv/server.go:907 +0x8d
2025-01-15 08:50:09	github.com/nspcc-dev/neo-go/pkg/services/rpcsrv.(*Server).handleIn(0xc000d7a288, 0xc003e8b450, 0x0)
2025-01-15 08:50:09		github.com/nspcc-dev/neo-go/pkg/services/rpcsrv/server.go:648 +0x60a
2025-01-15 08:50:09	github.com/nspcc-dev/neo-go/pkg/services/rpcsrv.(*Server).handleRequest(0xc000d7a288, 0xc008cbc560, 0x0)
2025-01-15 08:50:09		github.com/nspcc-dev/neo-go/pkg/services/rpcsrv/server.go:574 +0xd1
2025-01-15 08:50:09	github.com/nspcc-dev/neo-go/pkg/services/rpcsrv.(*Server).handleHTTPRequest(0xc000d7a288, {0x15c4a60, 0xc001cb8b60}, 0xc001cb1cc0)
2025-01-15 08:50:09		github.com/nspcc-dev/neo-go/pkg/services/rpcsrv/server.go:554 +0x9ea
2025-01-15 08:50:09	net/http.HandlerFunc.ServeHTTP(0x410845?, {0x15c4a60?, 0xc001cb8b60?}, 0xc001cb8b01?)
2025-01-15 08:50:09		net/http/server.go:2220 +0x29
2025-01-15 08:50:09	net/http.serverHandler.ServeHTTP({0x15bed50?}, {0x15c4a60?, 0xc001cb8b60?}, 0x6?)
2025-01-15 08:50:09		net/http/server.go:3210 +0x8e
2025-01-15 08:50:09	net/http.(*conn).serve(0xc00724ef30, {0x15c6960, 0xc001004c30})
2025-01-15 08:50:09		net/http/server.go:2092 +0x5d0
2025-01-15 08:50:09	created by net/http.(*Server).Serve in goroutine 852
2025-01-15 08:50:09		net/http/server.go:3360 +0x485

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working I4 No visible changes network P2P layer S3 Minimally significant U2 Seriously planned
Projects
None yet
Development

No branches or pull requests

2 participants