バグを説明する
edgexファウンドリサーバーが実行されていない場合のランタイムエラー、
level=ERROR ts=2021-01-19T01:51:50.815737266Z app=datastorage source=init.go:154 msg="Get \"http://localhost:48080/api/v1/ping\": dial tcp 127.0.0.1:48080: connect: connection refused"
level=INFO ts=2021-01-19T01:51:51.817181193Z app=datastorage source=init.go:144 msg="Check Metadata service's status by ping..."
level=INFO ts=2021-01-19T01:51:51.818287982Z app=datastorage source=init.go:144 msg="Check Data service's status by ping..."
level=ERROR ts=2021-01-19T01:51:51.822577012Z app=datastorage source=init.go:154 msg="Get \"http://localhost:48081/api/v1/ping\": dial tcp 127.0.0.1:48081: connect: connection refused"
level=ERROR ts=2021-01-19T01:51:51.824049381Z app=datastorage source=init.go:154 msg="Get \"http://localhost:48080/api/v1/ping\": dial tcp 127.0.0.1:48080: connect: connection refused"
level=INFO ts=2021-01-19T01:51:52.825768174Z app=datastorage source=init.go:144 msg="Check Metadata service's status by ping..."
level=INFO ts=2021-01-19T01:51:52.826907105Z app=datastorage source=init.go:144 msg="Check Data service's status by ping..."
level=ERROR ts=2021-01-19T01:51:52.830784824Z app=datastorage source=init.go:154 msg="Get \"http://localhost:48081/api/v1/ping\": dial tcp 127.0.0.1:48081: connect: connection refused"
level=ERROR ts=2021-01-19T01:51:52.83209855Z app=datastorage source=init.go:154 msg="Get \"http://localhost:48080/api/v1/ping\": dial tcp 127.0.0.1:48080: connect: connection refused"
INFO[2021-01-19T01:51:53Z]discovery.go:833 activeDiscovery [discoverymgr] activeDiscovery!!!
INFO[2021-01-19T01:51:53Z]discovery.go:571 func1 [deviceDetectionRoutine] edge-orchestration-3125da9e-1e9a-41aa-ac83-004725eb2d1e
level=ERROR ts=2021-01-19T01:51:53.83359109Z app=datastorage source=init.go:139 msg="dependency Metadata service checking time out"
level=ERROR ts=2021-01-19T01:51:53.834663766Z app=datastorage source=init.go:139 msg="dependency Data service checking time out"
level=INFO ts=2021-01-19T01:51:53.840074015Z app=datastorage source=httpserver.go:116 msg="Web server shutting down"
level=INFO ts=2021-01-19T01:51:53.841736032Z app=datastorage source=httpserver.go:107 msg="Web server stopped"
level=INFO ts=2021-01-19T01:51:54.341966491Z app=datastorage source=httpserver.go:118 msg="Web server shut down"
panic: runtime error: invalid memory address or nil pointer dereference
[signal SIGSEGV: segmentation violation code=0x1 addr=0x20 pc=0x8d1a0e]
goroutine 44 [running]:
github.com/edgexfoundry/device-sdk-go/internal/autoevent.(*manager).StopAutoEvents(0x0)
/home/t25kim/edge-home-orchestration-go/vendor/github.com/edgexfoundry/device-sdk-go/internal/autoevent/manager.go:69 +0x4e
github.com/edgexfoundry/device-sdk-go/pkg/service.(*DeviceService).Stop(0xc0004c2780, 0xc0005ae600)
/home/t25kim/edge-home-orchestration-go/vendor/github.com/edgexfoundry/device-sdk-go/pkg/service/service.go:134 +0x45
github.com/edgexfoundry/device-sdk-go/pkg/service.Main(0xe2dbda, 0xb, 0xe3a91d, 0x1a, 0xda46e0, 0xc0005a5de0, 0xf46e20, 0xc0005ae600, 0xc0000330a0, 0xc0005ac300, ...)
/home/t25kim/edge-home-orchestration-go/vendor/github.com/edgexfoundry/device-sdk-go/pkg/service/main.go:69 +0x6fa
github.com/edgexfoundry/device-sdk-go/pkg/startup.Bootstrap(0xe2dbda, 0xb, 0xe3a91d, 0x1a, 0xda46e0, 0xc0005a5de0)
/home/t25kim/edge-home-orchestration-go/vendor/github.com/edgexfoundry/device-sdk-go/pkg/startup/bootstrap.go:19 +0x117
created by github.com/lf-edge/edge-home-orchestration-go/src/controller/storagemgr.StorageImpl.StartStorage
/home/t25kim/edge-home-orchestration-go/src/controller/storagemgr/storage.go:51 +0xef
再現するには
予想される行動
データストレージを開始する前に、事前にedgexファウンドリサーバーを確認してください。
テスト環境の構成(次の情報を入力してください):
@ suresh-lcPTAL。 前もって感謝します。
こんにちはSunchit、
なぜクラッシュしたのか理解しました。 これはバグであり、修正するのはそれほど難しくありません。
依存関係のタイムアウト(EdgeXコアデータおよびコアメタデータ)によってサービスが停止した場合、AutoEventManagerは初期化されません。
この行では、 https://github.com/edgexfoundry/device-sdk-go/blob/v1.4.0/pkg/service/service.go#L134
StopAutoEventsを呼び出す前に、AutoEventManagerがnilであるかどうかを確認する必要があります。
この問題はV2(アイルランド)で解決されました。
こんにちはジムとイアン、
この問題を修正するためにハノイブランチを作成し、1.4.1にタグを付けることはできますか?
こんにちはSunchit、
なぜクラッシュしたのか理解しました。 これはバグであり、修正するのはそれほど難しくありません。
依存関係のタイムアウト(EdgeXコアデータおよびコアメタデータ)によってサービスが停止した場合、AutoEventManagerは初期化されません。
この行では、 https://github.com/edgexfoundry/device-sdk-go/blob/v1.4.0/pkg/service/service.go#L134
StopAutoEventsを呼び出す前に、AutoEventManagerがnilであるかどうかを確認する必要があります。
この問題はV2(アイルランド)で解決されました。
こんにちはジムとイアン、
この問題を修正するためにハノイブランチを作成し、1.4.1にタグを付けることはできますか?
@ suresh-lc誰がこのメールを書いたのですか?
こんにちはSunchit、
なぜクラッシュしたのか理解しました。 これはバグであり、修正するのはそれほど難しくありません。
依存関係のタイムアウト(EdgeXコアデータおよびコアメタデータ)によってサービスが停止した場合、AutoEventManagerは初期化されません。
この行では、 https://github.com/edgexfoundry/device-sdk-go/blob/v1.4.0/pkg/service/service.go#L134
StopAutoEventsを呼び出す前に、AutoEventManagerがnilであるかどうかを確認する必要があります。
この問題はV2(アイルランド)で解決されました。
こんにちはジムとイアン、
この問題を修正するためにハノイブランチを作成し、1.4.1にタグを付けることはできますか?@ suresh-lc誰がこのメールを書いたのですか?
EdgeX-デバイスサービスチームのCloudTsai
この問題は、edgexfoundryの「アイルランド」バージョンを使用することで解決されますが、正式にはリリースされていません。
これをknown issue
ままにして、アイルランドがリリースされたらedgexfoundryをアップグレードしたいと思います。
EdgeXメンバーとの通信後、彼らはフォークを提供してくれました:github.com/hahattan/device-sdk-go v1.4.1で、Hanoiブランチの修正が行われ、このクラッシュが発生しました。
go.modのreplaceディレクティブを使用して、修正をテストしていました。 それはうまくいくようです。
おっしゃるように、アイルランドがリリースされるまで待つことも、EdgeXがアイルランドをリリースするまでリポジトリに修正を複製することもできます。
同じことについてあなたの考えを共有してください?
@ t25kim
ありがとう !
@ sun-sharmaお知らせいただきありがとうございます。
replace
フラグを使用してgo.mod
ファイルを変更できますか?
これは一時的なものであり、削除されるというメモを追加するとよいでしょう。
最も参考になるコメント
EdgeXメンバーとの通信後、彼らはフォークを提供してくれました:github.com/hahattan/device-sdk-go v1.4.1で、Hanoiブランチの修正が行われ、このクラッシュが発生しました。
go.modのreplaceディレクティブを使用して、修正をテストしていました。 それはうまくいくようです。
おっしゃるように、アイルランドがリリースされるまで待つことも、EdgeXがアイルランドをリリースするまでリポジトリに修正を複製することもできます。
同じことについてあなたの考えを共有してください?
@ t25kim
ありがとう !