Skip to content
This repository has been archived by the owner on Nov 24, 2023. It is now read-only.

master: fix panic when etcd member not started #967

Merged
merged 2 commits into from
Sep 1, 2020

Conversation

lance6716
Copy link
Collaborator

@lance6716 lance6716 commented Sep 1, 2020

What problem does this PR solve?

panic: runtime error: index out of range [0] with length 0

goroutine 758 [running]:
github.com/pingcap/dm/dm/master.(*Server).listMemberMaster(0xc0002fe3c0, 0x24dcde0, 0xc001af5a70, 0x0, 0x0, 0x0, 0x0, 0x1, 0xc001af5cb0)
        /home/jenkins/agent/workspace/build_dm_multi_branch_master/go/src/github.com/pingcap/dm/dm/master/server.go:1870 +0x6aa
github.com/pingcap/dm/dm/master.(*Server).ListMember(0xc0002fe3c0, 0x24dcde0, 0xc001af5a70, 0xc001ae2cc0, 0xc0002fe3c0, 0x24f6200, 0xc00093d080)
        /home/jenkins/agent/workspace/build_dm_multi_branch_master/go/src/github.com/pingcap/dm/dm/master/server.go:1989 +0x568
github.com/pingcap/dm/dm/pb._Master_ListMember_Handler.func1(0x24dcde0, 0xc001af5a70, 0x1fe7c20, 0xc001ae2cc0, 0x15, 0xc001aed7c0, 0xc002728701, 0x21b6250)
        /home/jenkins/agent/workspace/build_dm_multi_branch_master/go/src/github.com/pingcap/dm/dm/pb/dmmaster.pb.go:4057 +0x86
github.com/grpc-ecosystem/go-grpc-prometheus.(*ServerMetrics).UnaryServerInterceptor.func1(0x24dcde0, 0xc001af5a70, 0x1fe7c20, 0xc001ae2cc0, 0xc001ae2ce0, 0xc001ae2d00, 0xc001b409a0, 0x3c420d0, 0x1ed52c0, 0xc001af5980)
        /go/pkg/mod/github.com/grpc-ecosystem/[email protected]/server_metrics.go:107 +0xad
github.com/grpc-ecosystem/go-grpc-middleware.ChainUnaryServer.func1.1.1(0x24dcde0, 0xc001af5a70, 0x1fe7c20, 0xc001ae2cc0, 0x3c438c0, 0x1, 0x0, 0x11)
        /go/pkg/mod/github.com/grpc-ecosystem/[email protected]/chain.go:25 +0x63
go.etcd.io/etcd/etcdserver/api/v3rpc.newUnaryInterceptor.func1(0x24dcde0, 0xc001af5a70, 0x1fe7c20, 0xc001ae2cc0, 0xc001ae2ce0, 0xc001ae2d20, 0x4870e6, 0x5f4dbb2f, 0x1b8723f8, 0x9bf4b8b520b)
        /go/pkg/mod/go.etcd.io/[email protected]/etcdserver/api/v3rpc/interceptor.go:64 +0x108
github.com/grpc-ecosystem/go-grpc-middleware.ChainUnaryServer.func1.1.1(0x24dcde0, 0xc001af5a70, 0x1fe7c20, 0xc001ae2cc0, 0x8, 0x2, 0x0, 0x203000)
        /go/pkg/mod/github.com/grpc-ecosystem/[email protected]/chain.go:25 +0x63
go.etcd.io/etcd/etcdserver/api/v3rpc.newLogUnaryInterceptor.func1(0x24dcde0, 0xc001af5a70, 0x1fe7c20, 0xc001ae2cc0, 0xc001ae2ce0, 0xc001ae2d40, 0x0, 0x0, 0x0, 0x0)
        /go/pkg/mod/go.etcd.io/[email protected]/etcdserver/api/v3rpc/interceptor.go:71 +0xba
github.com/grpc-ecosystem/go-grpc-middleware.ChainUnaryServer.func1.1.1(0x24dcde0, 0xc001af5a70, 0x1fe7c20, 0xc001ae2cc0, 0xc001b64500, 0x0, 0xc0016caac0, 0x40cad8)
        /go/pkg/mod/github.com/grpc-ecosystem/[email protected]/chain.go:25 +0x63
github.com/grpc-ecosystem/go-grpc-middleware.ChainUnaryServer.func1(0x24dcde0, 0xc001af5a70, 0x1fe7c20, 0xc001ae2cc0, 0xc001ae2ce0, 0xc001ae2d00, 0xc0016cab30, 0x4907a8, 0x1f2b4e0, 0xc001af5a70)
        /go/pkg/mod/github.com/grpc-ecosystem/[email protected]/chain.go:34 +0xd5
github.com/pingcap/dm/dm/pb._Master_ListMember_Handler(0x20c42e0, 0xc0002fe3c0, 0x24dcde0, 0xc001af5a70, 0xc00093cf60, 0xc0024e68a0, 0x24dcde0, 0xc001af5a70, 0xc0008c73f0, 0x2)
        /home/jenkins/agent/workspace/build_dm_multi_branch_master/go/src/github.com/pingcap/dm/dm/pb/dmmaster.pb.go:4059 +0x14b
google.golang.org/grpc.(*Server).processUnaryRPC(0xc002490600, 0x25015a0, 0xc001abd800, 0xc001b64500, 0xc002562750, 0x3bca8f0, 0x0, 0x0, 0x0)
        /go/pkg/mod/google.golang.org/[email protected]/server.go:1024 +0x4f4
google.golang.org/grpc.(*Server).handleStream(0xc002490600, 0x25015a0, 0xc001abd800, 0xc001b64500, 0x0)
        /go/pkg/mod/google.golang.org/[email protected]/server.go:1313 +0xd97
google.golang.org/grpc.(*Server).serveStreams.func1.1(0xc0008c6cf0, 0xc002490600, 0x25015a0, 0xc001abd800, 0xc001b64500)
        /go/pkg/mod/google.golang.org/[email protected]/server.go:722 +0xbb
created by google.golang.org/grpc.(*Server).serveStreams.func1
        /go/pkg/mod/google.golang.org/[email protected]/server.go:720 +0xa1

What is changed and how it works?

when etcd member not started, its ClientURLs will be empty. check length to avoid panic

Check List

Tests

  • Seems corrent and hard to test

Code changes

Side effects

Related changes

  • Need to cherry-pick to the release branch
  • Need update release note:
    修复了新启动的 DM-master 导致 list-member panic 的问题

@lance6716 lance6716 added needs-cherry-pick-release-1.0 This PR should be cherry-picked to release-1.0. Remove this label after cherry-picked to release-1.0 needs-cherry-pick-release-2.0 This PR should be cherry-picked to release-2.0. Remove this label after cherry-picked to release-2.0 priority/unimportant Really minor change, requires approval from secondary reviewers status/PTAL This PR is ready for review. Add this label back after committing new changes labels Sep 1, 2020
@lance6716
Copy link
Collaborator Author

PTAL @lichunzhu @csuzhangxc

Copy link
Contributor

@lichunzhu lichunzhu left a comment

Choose a reason for hiding this comment

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

LGTM

Copy link
Member

@csuzhangxc csuzhangxc left a comment

Choose a reason for hiding this comment

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

LGTM

@csuzhangxc csuzhangxc added status/LGT2 Two reviewers already commented LGTM, ready for merge and removed status/PTAL This PR is ready for review. Add this label back after committing new changes labels Sep 1, 2020
@csuzhangxc csuzhangxc added this to the v2.0.0 RC.2 milestone Sep 1, 2020
@lance6716 lance6716 merged commit 04f9c27 into pingcap:master Sep 1, 2020
@lance6716 lance6716 deleted the fix-panic branch September 1, 2020 04:02
@ti-srebot
Copy link

cherry pick to release-1.0 failed

@ti-srebot
Copy link

cherry pick to release-2.0 in PR #970

@ti-srebot ti-srebot added already-cherry-pick-2.0 The related PR is already cherry-picked to release-2.0. Add this label once the PR is cherry-picked and removed needs-cherry-pick-release-2.0 This PR should be cherry-picked to release-2.0. Remove this label after cherry-picked to release-2.0 labels Sep 1, 2020
@lance6716 lance6716 removed the needs-cherry-pick-release-1.0 This PR should be cherry-picked to release-1.0. Remove this label after cherry-picked to release-1.0 label Sep 1, 2020
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
already-cherry-pick-2.0 The related PR is already cherry-picked to release-2.0. Add this label once the PR is cherry-picked priority/unimportant Really minor change, requires approval from secondary reviewers status/LGT2 Two reviewers already commented LGTM, ready for merge
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants