Descreva o bug
Um erro de tempo de execução quando os servidores de fundição edgex não estão em execução,
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
Reproduzir
Comportamento esperado
Verifique o servidor de fundição edgex com antecedência antes de iniciar o armazenamento de dados.
Configuração do ambiente de teste (preencha as seguintes informações):
@ suresh-lc PTAL. Agradeço antecipadamente.
Oi Sunchit,
Eu descobri por que ele travou. É um bug e não é tão difícil de consertar.
O AutoEvent Manager não é inicializado quando o Serviço é interrompido pelo tempo limite de dependência (EdgeX Core Data e Core Metadata).
Nesta linha, https://github.com/edgexfoundry/device-sdk-go/blob/v1.4.0/pkg/service/service.go#L134
Devemos verificar se o AutoEvent Manager é nulo antes de chamar StopAutoEvents.
Resolvemos esse problema na V2 (Irlanda).
Olá Jim e Iain,
Podemos criar um branch hanoi para corrigir esse problema e marcar 1.4.1 para eles?
Oi Sunchit,
Eu descobri por que ele travou. É um bug e não é tão difícil de consertar.
O AutoEvent Manager não é inicializado quando o Serviço é interrompido pelo tempo limite de dependência (EdgeX Core Data e Core Metadata).
Nesta linha, https://github.com/edgexfoundry/device-sdk-go/blob/v1.4.0/pkg/service/service.go#L134
Devemos verificar se o AutoEvent Manager é nulo antes de chamar StopAutoEvents.
Resolvemos esse problema na V2 (Irlanda).
Olá Jim e Iain,
Podemos criar um branch hanoi para corrigir esse problema e marcar 1.4.1 para eles?
@ suresh-lc Quem escreveu este e-mail?
Oi Sunchit,
Eu descobri por que ele travou. É um bug e não é tão difícil de consertar.
O AutoEvent Manager não é inicializado quando o Serviço é interrompido pelo tempo limite de dependência (EdgeX Core Data e Core Metadata).
Nesta linha, https://github.com/edgexfoundry/device-sdk-go/blob/v1.4.0/pkg/service/service.go#L134
Devemos verificar se o AutoEvent Manager é nulo antes de chamar StopAutoEvents.
Resolvemos esse problema na V2 (Irlanda).
Olá Jim e Iain,
Podemos criar um branch hanoi para corrigir esse problema e marcar 1.4.1 para eles?@ suresh-lc Quem escreveu este e-mail?
Cloud Tsai da equipe EdgeX- Device Service
Esse problema será resolvido usando a versão edgexfoundry 'Ireland', mas ela não foi lançada oficialmente.
Eu gostaria de deixar isso como known issue
e atualizar o edgexfoundry quando a Irlanda for lançada.
Após a comunicação com os membros do EdgeX, eles nos forneceram um fork: github.com/hahattan/device-sdk-go v1.4.1 com a correção no branch de Hanoi, causando esta falha.
Eu estava testando a correção usando a diretiva replace em nosso go.mod. Isso parece funcionar bem.
Como você mencionou, podemos esperar até o lançamento na Irlanda ou também podemos clonar a correção em nosso repositório até o momento em que o EdgeX lançar a Irlanda.
Por favor, compartilhe seus pensamentos sobre o mesmo?
@ t25kim
Obrigado !
@ sun-sharma Obrigado por nos informar.
Você poderia modificar o arquivo go.mod
com o sinalizador replace
?
Seria bom adicionar uma observação de que é temporário e será removido.
Comentários muito úteis
Após a comunicação com os membros do EdgeX, eles nos forneceram um fork: github.com/hahattan/device-sdk-go v1.4.1 com a correção no branch de Hanoi, causando esta falha.
Eu estava testando a correção usando a diretiva replace em nosso go.mod. Isso parece funcionar bem.
Como você mencionou, podemos esperar até o lançamento na Irlanda ou também podemos clonar a correção em nosso repositório até o momento em que o EdgeX lançar a Irlanda.
Por favor, compartilhe seus pensamentos sobre o mesmo?
@ t25kim
Obrigado !