Reboot container every time host reboots


#1

I may be misunderstanding (I’m pretty new to Docker in general), but it seems as though sometime I cold boot my resin.io manage Raspberry Pi 3b and in the online console, it says the application is already running (and seems to do a “partial” initialization of the application).

I’d like the container to be started anew, every time I cold boot. Is there a setting for this?


#2

Hey, great question, it’s already the way you expect it, we just need to communicate it better in the UI!

When the device boots up, two containers are initiated side by side: your application’s container, and the supervisor that manages the device & communicates with resin.io including your logs. The supervisor needs some time, and we are not holding back your application’s start depending on the supervisor.

The outcome is that there’s an about 30s window, when the application is running (freshly started!), but there are no logs for it on the start, as the supervisor is still catching up. The application already running is to provide feedback to you, that it actually started, otherwise you might wonder (even more), whether it does run (especially if your application does not show much logs).

You could for example test this by deploying this simple Dockerfile:

FROM resin/raspberrypi3-debian

# Echo seconds since container start to the log
CMD i=0; while : ; do echo $i; sleep 1; i=$((i+1)); done

Since the count is low value, it shows the container is started anew on reboot, eg ~17s ago in this test:

We definitely need to document this more, and some of the architecture decisions and behaviour is likely to change in the future to surprise people less (like it did surprise you), but your application should always start from fresh!


Update strategy: Download then update on reboot
#3

That explains a lot. Thank you very very much :slight_smile:


#4

Cheers, :four_leaf_clover:, if any aspect of the service is confusing, please don’t hesitate to ask, we are always working on clarifying stuff. And there’s a lot to, the hardware + software combo is a lot to communicate! :slight_smile: