Skip to content

Commit

Permalink
fix(op-node/op-batcher/op-proposer): the fallback client should alway…
Browse files Browse the repository at this point in the history
…s try recover (ethereum-optimism#118)

Co-authored-by: Welkin <[email protected]>
  • Loading branch information
welkin22 and Welkin authored Mar 7, 2024
1 parent 5c5bf63 commit 2fbabc7
Show file tree
Hide file tree
Showing 4 changed files with 46 additions and 35 deletions.
44 changes: 22 additions & 22 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,15 +15,15 @@ jobs:
uses: actions/checkout@v3

- name: Set up Go
uses: actions/setup-go@v2
uses: actions/setup-go@v5
with:
go-version-file: go.mod
go-version: '1.20.13'

- name: golangci-lint
uses: golangci/golangci-lint-action@v3
uses: golangci/golangci-lint-action@v4
with:
working-directory: op-node
version: latest
version: v1.55.2
args: -E goimports,sqlclosecheck,bodyclose,asciicheck,misspell,errorlint --timeout 5m -e "errors.As" -e "errors.Is"

op-batcher-lint:
Expand All @@ -34,15 +34,15 @@ jobs:
uses: actions/checkout@v3

- name: Set up Go
uses: actions/setup-go@v2
uses: actions/setup-go@v5
with:
go-version-file: go.mod
go-version: '1.20.13'

- name: golangci-lint
uses: golangci/golangci-lint-action@v3
uses: golangci/golangci-lint-action@v4
with:
working-directory: op-batcher
version: latest
version: v1.55.2
args: -E goimports,sqlclosecheck,bodyclose,asciicheck,misspell,errorlint --timeout 5m -e "errors.As" -e "errors.Is"

op-proposer-lint:
Expand All @@ -53,15 +53,15 @@ jobs:
uses: actions/checkout@v3

- name: Set up Go
uses: actions/setup-go@v2
uses: actions/setup-go@v5
with:
go-version-file: go.mod
go-version: '1.20.13'

- name: golangci-lint
uses: golangci/golangci-lint-action@v3
uses: golangci/golangci-lint-action@v4
with:
working-directory: op-proposer
version: latest
version: v1.55.2
args: -E goimports,sqlclosecheck,bodyclose,asciicheck,misspell,errorlint --timeout 5m -e "errors.As" -e "errors.Is"

op-node-test:
Expand All @@ -73,9 +73,9 @@ jobs:
uses: actions/checkout@v3

- name: Set up Go
uses: actions/setup-go@v2
uses: actions/setup-go@v5
with:
go-version-file: go.mod
go-version: '1.20.13'

- name: Install gotestsum
uses: autero1/[email protected]
Expand All @@ -102,9 +102,9 @@ jobs:
uses: actions/checkout@v3

- name: Set up Go
uses: actions/setup-go@v2
uses: actions/setup-go@v5
with:
go-version-file: go.mod
go-version: '1.20.13'

- name: Install gotestsum
uses: autero1/[email protected]
Expand All @@ -131,9 +131,9 @@ jobs:
uses: actions/checkout@v3

- name: Set up Go
uses: actions/setup-go@v2
uses: actions/setup-go@v5
with:
go-version-file: go.mod
go-version: '1.20.13'

- name: Install gotestsum
uses: autero1/[email protected]
Expand All @@ -160,9 +160,9 @@ jobs:
uses: actions/checkout@v3

- name: Set up Go
uses: actions/setup-go@v2
uses: actions/setup-go@v5
with:
go-version-file: go.mod
go-version: '1.20.13'

- name: Install gotestsum
uses: autero1/[email protected]
Expand Down Expand Up @@ -191,9 +191,9 @@ jobs:
uses: actions/checkout@v3

- name: Set up Go
uses: actions/setup-go@v2
uses: actions/setup-go@v5
with:
go-version-file: go.mod
go-version: '1.20.13'

- name: Install gotestsum
uses: autero1/[email protected]
Expand Down
7 changes: 4 additions & 3 deletions op-e2e/actions/fallback_client_test.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
package actions

import (
"math/big"
"testing"
"time"

"github.com/ethereum-optimism/optimism/op-e2e/e2eutils"
"github.com/ethereum-optimism/optimism/op-node/client"
"github.com/ethereum-optimism/optimism/op-node/eth"
Expand All @@ -12,9 +16,6 @@ import (
"github.com/ethereum/go-ethereum/log"
"github.com/ethereum/go-ethereum/params"
"github.com/stretchr/testify/require"
"math/big"
"testing"
"time"
)

func setupFallbackClientTest(t Testing, sd *e2eutils.SetupData, log log.Logger, l1Url string) (*L1Miner, *L1Replica, *L1Replica, *L2Engine, *L2Sequencer, *sources.FallbackClient) {
Expand Down
15 changes: 10 additions & 5 deletions op-node/sources/fallback_client.go
Original file line number Diff line number Diff line change
Expand Up @@ -157,6 +157,13 @@ func (l *FallbackClient) switchCurrentRpc() {
}

func (l *FallbackClient) switchCurrentRpcLogic() error {
//Use defer to ensure that recoverIfFirstRpcHealth will always be executed regardless of the circumstances.
defer func() {
if !l.isInFallbackState {
l.isInFallbackState = true
l.recoverIfFirstRpcHealth()
}
}()
url := l.urlList[l.currentIndex]
newRpc, err := l.rpcInitFunc(url)
if err != nil {
Expand All @@ -179,10 +186,6 @@ func (l *FallbackClient) switchCurrentRpcLogic() error {
}
}
l.log.Info("switched current rpc to new url", "url", url)
if !l.isInFallbackState {
l.isInFallbackState = true
l.recoverIfFirstRpcHealth()
}
return nil
}

Expand Down Expand Up @@ -221,7 +224,9 @@ func (l *FallbackClient) recoverIfFirstRpcHealth() {
}
lastRpc := *l.currentRpc.Load()
l.currentRpc.Store(&l.firstRpc)
lastRpc.Close()
if lastRpc != l.firstRpc {
lastRpc.Close()
}
l.lastMinuteFail.Store(0)
l.currentIndex = 0
l.isInFallbackState = false
Expand Down
15 changes: 10 additions & 5 deletions op-service/client/fallback_client.go
Original file line number Diff line number Diff line change
Expand Up @@ -240,6 +240,13 @@ func (l *FallbackClient) switchCurrentClient() {
if l.lastMinuteFail.Load() <= l.fallbackThreshold {
return
}
//Use defer to ensure that recoverIfFirstRpcHealth will always be executed regardless of the circumstances.
defer func() {
if !l.isInFallbackState {
l.isInFallbackState = true
l.recoverIfFirstRpcHealth()
}
}()
l.currentIndex++
if l.currentIndex >= len(l.urlList) {
l.log.Error("the fallback client has tried all urls")
Expand All @@ -259,10 +266,6 @@ func (l *FallbackClient) switchCurrentClient() {
}
l.lastMinuteFail.Store(0)
l.log.Info("switched current rpc to new url", "url", url)
if !l.isInFallbackState {
l.isInFallbackState = true
l.recoverIfFirstRpcHealth()
}
}

func (l *FallbackClient) recoverIfFirstRpcHealth() {
Expand All @@ -287,7 +290,9 @@ func (l *FallbackClient) recoverIfFirstRpcHealth() {
}
lastClient := *l.currentClient.Load()
l.currentClient.Store(&l.firstClient)
lastClient.Close()
if lastClient != l.firstClient {
lastClient.Close()
}
l.lastMinuteFail.Store(0)
l.currentIndex = 0
l.isInFallbackState = false
Expand Down

0 comments on commit 2fbabc7

Please sign in to comment.