Migration to Balena

Hey all,

We’ve been testing out Balena and it seems like it is the solution to our problems. Before we go full steam ahead we wanted to see how we can migrate our devices remotely as we have several hundred devices out in the wild.

Our devices are composed of BeagleBone Black components with Debian 9/10.

I found the takeover script, however there is an unmerged PR from 2022 that says that takeover is under limited maintenace as the will be a new method. You can find more about here.. In addition, I have also found several forum posts that support this.

Using the takeover script, the debug logs seem fine however after it reboots, nothing has changed. I connected via serial to see if there is something happening during boot, however there were no clues there either.

The output can be found at the bottom of this post. However I would like to know what the up to date method is to do a brownfield migration.

sudo ./takeover --log-level debug --image beaglebone-black-5.3.4+rev3-v16.1.10.img.gz --no-wifis --no-nwmgr-check -c config.json

2024-06-26 15:17:54 INFO  Detected OS Architecture is ARMHF
2024-06-26 15:17:54 DEBUG [takeover::stage1::device_impl::raspberrypi] raspberrypi::is_rpi: entered with model string: 'TI AM335x BeagleBone Black'
2024-06-26 15:17:54 DEBUG [takeover::stage1::device_impl::raspberrypi] no match for Raspberry PI on: TI AM335x BeagleBone Black
2024-06-26 15:17:54 DEBUG [takeover::stage1::device_impl::beaglebone] match found for BeagleboneBlack
2024-06-26 15:17:54 DEBUG [takeover::common] parse_file: line: 'PRETTY_NAME="Debian GNU/Linux 9 (stretch)"'
2024-06-26 15:17:54 INFO  Detected OS name is Debian GNU/Linux 9 (stretch)
2024-06-26 15:17:54 DEBUG [takeover::common] parse_file: line: 'PRETTY_NAME="Debian GNU/Linux 9 (stretch)"'
2024-06-26 15:17:54 INFO  Detected device type: Beaglebone Black, running Debian GNU/Linux 9 (stretch)
2024-06-26 15:17:54 INFO  Configured for fleet id: 2139641
2024-06-26 15:17:54 DEBUG [reqwest::connect] starting new connection: https://api.balena-cloud.com/
2024-06-26 15:17:54 DEBUG [takeover::stage1::migrate_info::balena_cfg_json] Result = Response { url: Url { scheme: "https", cannot_be_a_base: false, username: "", password: None, host: Some(Domain("api.balena-cloud.com")), port: None, path: "/ping", query: None, fragment: None }, status: 200, headers: {"date": "Wed, 26 Jun 2024 12:17:55 GMT", "content-type": "text/plain; charset=utf-8", "content-length": "2", "connection": "keep-alive", "etag": "maybesecret", "cf-cache-status": "DYNAMIC", "strict-transport-security": "max-age=15552000", "server": "cloudflare", "cf-ray": "maybesecret", "alt-svc": "h3=\":443\"; ma=86400"} }
2024-06-26 15:17:55 INFO  connection to api: https://api.balena-cloud.com is ok
2024-06-26 15:17:55 INFO  connection to vpn: cloudlink.balena-cloud.com:443 is ok
2024-06-26 15:17:55 INFO  config.json is for device type beaglebone-black
2024-06-26 15:17:55 DEBUG [takeover::stage1::migrate_info] image path: '/home/user/balena/beaglebone-black-5.3.4+rev3-v16.1.10.img.gz'
2024-06-26 15:17:55 WARN  [takeover::stage1::migrate_info] No Network manager files were found, the device might not be able to come online
2024-06-26 15:17:55 INFO  Writing hostname to config.json: 'hostname-bbb-X'
2024-06-26 15:17:55 DEBUG [takeover::common] parse_file: line: 'PRETTY_NAME="Debian GNU/Linux 9 (stretch)"'
2024-06-26 15:17:55 DEBUG [takeover::common] parse_file: line: 'PRETTY_NAME="Debian GNU/Linux 9 (stretch)"'
2024-06-26 15:17:55 DEBUG [takeover::stage1::block_device_info::mount] from_mtab: processing mount Mount { mountpoint: "/", fs_type: "ext4" }
2024-06-26 15:17:55 DEBUG [takeover::stage1::block_device_info] new: Root device number is: 179:1
2024-06-26 15:17:55 DEBUG [takeover::common] call: output: Output { status: ExitStatus(unix_wait_status(0)), stdout: "/dev/mmcblk0p1: LABEL=\"rootfs\" UUID=\"40cf2ffa-cfbc-40ad-adef-1ec63fe6d175\" TYPE=\"ext4\" PARTUUID=\"517c1cdf-01\"\n", stderr: "" }
2024-06-26 15:17:55 DEBUG [takeover::stage1::block_device_info::partition] PartitionInfo::new: /dev/mmcblk0p1 got param name: LABEL, value: rootfs
2024-06-26 15:17:55 WARN  [takeover::stage1::block_device_info::partition] unexpected parameter name found: 'LABEL'
2024-06-26 15:17:55 DEBUG [takeover::stage1::block_device_info::partition] PartitionInfo::new: /dev/mmcblk0p1 got param name: UUID, value: 40cf2ffa-cfbc-40ad-adef-1ec63fe6d175
2024-06-26 15:17:55 DEBUG [takeover::stage1::block_device_info::partition] PartitionInfo::new: /dev/mmcblk0p1 got param name: TYPE, value: ext4
2024-06-26 15:17:55 DEBUG [takeover::stage1::block_device_info::partition] PartitionInfo::new: /dev/mmcblk0p1 got param name: PARTUUID, value: 517c1cdf-01
2024-06-26 15:17:55 DEBUG [takeover::stage1::block_device_info::partition] PartitionInfo::new: for /dev/mmcblk0p1 got PartitionInfo { uuid: Some("40cf2ffa-cfbc-40ad-adef-1ec63fe6d175"), block_size: None, fs_type: Some("ext4"), label: None, part_uuid: Some("517c1cdf-01") }
2024-06-26 15:17:55 DEBUG [takeover::stage1::block_device_info] found  partition '"mmcblk0p1"' in '/sys/block/mmcblk0/mmcblk0p1'
2024-06-26 15:17:55 DEBUG [takeover::stage1::block_device_info] new: got device: BlockDevice { name: "mmcblk0", device_num: DeviceNum { major: 179, minor: 0 }, mounted: None, parent: "None" }
2024-06-26 15:17:55 INFO  Early checks passed
takeover will prepare your device for migration. Are you sure you want to migrate this device: [Y/n]
y
2024-06-26 15:20:07 INFO  Preparing for takeover..
2024-06-26 15:20:07 DEBUG [takeover::common] call: output: Output { status: ExitStatus(unix_wait_status(0)), stdout: "", stderr: "" }
2024-06-26 15:20:07 DEBUG [takeover::stage1] Space required for commands: 8076 KiB
2024-06-26 15:20:07 INFO  Found 484 MiB total, 93 MiB free memory
2024-06-26 15:20:07 DEBUG [takeover::common::system] mkdir: '/tmp/balena-takeover'
2024-06-26 15:20:07 INFO  Using '/tmp/balena-takeover' as takeover directory on 'Debian GNU/Linux 9 (stretch)'
2024-06-26 15:20:07 INFO  Mounted tmpfs file system on '/tmp/balena-takeover'
2024-06-26 15:20:07 INFO  Created mtab in  '/tmp/balena-takeover/etc/mtab'
2024-06-26 15:20:07 INFO  Mounted proc file system on '/tmp/balena-takeover/proc'
2024-06-26 15:20:07 INFO  Mounted tmpfs file system on '/tmp/balena-takeover/tmp'
2024-06-26 15:20:07 INFO  Mounted sys file system on '/tmp/balena-takeover/sys'
2024-06-26 15:20:07 INFO  Mounted dev file system on '/tmp/balena-takeover/dev'
2024-06-26 15:20:07 DEBUG [takeover::common::debug] After dev mount
2024-06-26 15:20:07 DEBUG [takeover::common::debug] check if /dev/loop-control exists in new /dev: true
2024-06-26 15:20:07 DEBUG [takeover::common::debug] open /dev/loop-control succeeded
2024-06-26 15:20:07 INFO  Mounted devpts file system on '/tmp/balena-takeover/dev/pts'
2024-06-26 15:20:07 INFO  Created directory '/tmp/balena-takeover/mnt/old_root'
2024-06-26 15:20:07 DEBUG [takeover::stage1::exe_copy] copy_file: copying '/lib/ld-linux-armhf.so.3' to '/tmp/balena-takeover/lib/ld-linux-armhf.so.3'
2024-06-26 15:20:07 DEBUG [takeover::stage1::exe_copy] copy_file: copying '/lib/arm-linux-gnueabihf/libc.so.6' to '/tmp/balena-takeover/lib/arm-linux-gnueabihf/libc.so.6'
2024-06-26 15:20:07 DEBUG [takeover::stage1::exe_copy] copy_file: copying '/lib/arm-linux-gnueabihf/ld-linux-armhf.so.3' to '/tmp/balena-takeover/lib/arm-linux-gnueabihf/ld-linux-armhf.so.3'
2024-06-26 15:20:07 INFO  Copied '/bin/dd' to '/tmp/balena-takeover/bin/dd'
2024-06-26 15:20:07 INFO  Copied '/home/oruba/balena/takeover' to '/tmp/balena-takeover/bin/takeover'
2024-06-26 15:20:07 INFO  Copied config.json to '/home/oruba/balena/config.rJlD4lIENx.json'
2024-06-26 15:20:07 DEBUG [takeover::common] parse_file: line: 'PRETTY_NAME="Debian GNU/Linux 9 (stretch)"'
2024-06-26 15:20:07 DEBUG [takeover::stage1::block_device_info::mount] from_mtab: processing mount Mount { mountpoint: "/", fs_type: "ext4" }
2024-06-26 15:20:07 DEBUG [takeover::stage1::block_device_info] new: Root device number is: 179:1
2024-06-26 15:20:08 DEBUG [takeover::common] call: output: Output { status: ExitStatus(unix_wait_status(0)), stdout: "/dev/mmcblk0p1: LABEL=\"rootfs\" UUID=\"40cf2ffa-cfbc-40ad-adef-1ec63fe6d175\" TYPE=\"ext4\" PARTUUID=\"517c1cdf-01\"\n", stderr: "" }
2024-06-26 15:20:08 DEBUG [takeover::stage1::block_device_info::partition] PartitionInfo::new: /dev/mmcblk0p1 got param name: LABEL, value: rootfs
2024-06-26 15:20:08 WARN  [takeover::stage1::block_device_info::partition] unexpected parameter name found: 'LABEL'
2024-06-26 15:20:08 DEBUG [takeover::stage1::block_device_info::partition] PartitionInfo::new: /dev/mmcblk0p1 got param name: UUID, value: 40cf2ffa-cfbc-40ad-adef-1ec63fe6d175
2024-06-26 15:20:08 DEBUG [takeover::stage1::block_device_info::partition] PartitionInfo::new: /dev/mmcblk0p1 got param name: TYPE, value: ext4
2024-06-26 15:20:08 DEBUG [takeover::stage1::block_device_info::partition] PartitionInfo::new: /dev/mmcblk0p1 got param name: PARTUUID, value: 517c1cdf-01
2024-06-26 15:20:08 DEBUG [takeover::stage1::block_device_info::partition] PartitionInfo::new: for /dev/mmcblk0p1 got PartitionInfo { uuid: Some("40cf2ffa-cfbc-40ad-adef-1ec63fe6d175"), block_size: None, fs_type: Some("ext4"), label: None, part_uuid: Some("517c1cdf-01") }
2024-06-26 15:20:08 DEBUG [takeover::stage1::block_device_info] found  partition '"mmcblk0p1"' in '/sys/block/mmcblk0/mmcblk0p1'
2024-06-26 15:20:08 DEBUG [takeover::stage1::block_device_info] new: got device: BlockDevice { name: "mmcblk0", device_num: DeviceNum { major: 179, minor: 0 }, mounted: None, parent: "None" }
2024-06-26 15:20:08 INFO  No stage 2 log device requested
2024-06-26 15:20:08 DEBUG [takeover::stage1] Stage 2 config:
---
log_dev: ~
log_level: DEBUG
flash_dev: /dev/mmcblk0
pretend: false
umount_parts:
  - dev_name: /dev/mmcblk0p1
    mountpoint: /
    fs_type: ext4
work_dir: /home/user/balena
image_path: /home/user/balena/beaglebone-black-5.3.4+rev3-v16.1.10.img.gz
config_path: /home/user/balena/config.rJlD4lIENx.json
backup_path: ~
device_type: "Beaglebone Black,,"
tty: /dev/pts/0

2024-06-26 15:20:08 INFO  Wrote stage2 config to '/tmp/balena-takeover/stage2-config.yml'
2024-06-26 15:20:08 DEBUG [takeover::stage1] Found telinit at '/sbin/telinit'
2024-06-26 15:20:08 DEBUG [takeover::stage1] telinit is a symlink with canonical path '/bin/systemctl'
2024-06-26 15:20:08 INFO  telinit (/sbin/telinit) is a symlink (to /bin/systemctl), but it does not point to init (/lib/systemd/systemd), no need to make a safe copy
2024-06-26 15:20:08 INFO  Bind-mounted new init as '/tmp/balena-takeover/bin/takeover'
2024-06-26 15:20:08 DEBUG [takeover::stage1] calling '/sbin/telinit u'
2024-06-26 15:20:08 DEBUG [takeover::common] call: output: Output { status: ExitStatus(unix_wait_status(0)), stdout: "", stderr: "" }
2024-06-26 15:20:08 INFO  Restarted init
2024-06-26 15:20:08 INFO  Takeover initiated successfully, please wait for the device to be reflashed and reboot
Connection to 192.168.15.11 closed by remote host.
Connection to 192.168.15.11 closed.
1 Like

Hello @aslansutu let me ask to the OS team how to help you more with the takeover script or further initiatives we are working on.

In the meantime, if you do any other successful (or not) test, let us know!

Hey @aslansutu is it possible that you could share the logs of the stage2?

Read more about the stage 2 here in the README

Feel free to share the next steps!

Thanks, Marc. Also see the Logging section of the README to specify stage2 logging. Let us know how it goes.

1 Like

Thanks for pointing out the stage2 logs. It looks like I overlooked that part. Here are the logs

# stage2-init.log

2024-06-28 10:38:34 INFO  [takeover::init] Init entered
2024-06-28 10:38:34 INFO  [takeover::init] Init check pid success!
2024-06-28 10:38:34 INFO  [takeover::init] Stage 2 config was read successfully
2024-06-28 10:38:34 INFO  [takeover::init] Stage 2 closed 35 fd's
2024-06-28 10:38:34 INFO  [takeover::init] Now logging to '/tmp/balena-takeover/mnt/log/stage2-init.log' on '/dev/sdb1'
2024-06-28 10:38:34 INFO  [takeover::init] Stage 2 setup_log success!, ext_log: true
2024-06-28 10:38:42 DEBUG [takeover::common] call: output: Output { status: ExitStatus(unix_wait_status(0)), stdout: "", stderr: "" }
2024-06-28 07:38:47 DEBUG [takeover::common] call: output: Output { status: ExitStatus(unix_wait_status(0)), stdout: "", stderr: "" }
2024-06-28 07:38:47 INFO  [takeover::init] Stage 2 migrate worker spawned
# stage2.log

2024-06-28 07:38:47 INFO  [takeover::stage2] Stage 2 migrate_worker entered
2024-06-28 07:38:47 INFO  [takeover::stage2] Stage 2 config was read successfully
2024-06-28 07:38:47 INFO  [takeover::stage2] Set logfile to /mnt/log/stage2.log
2024-06-28 07:38:47 DEBUG [takeover::stage2] active processes:
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:      1 name: systemd	 executable: /mnt/old_root/lib/systemd/systemd	 ppid: 0
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:      2 name: '[kthreadd]'	 executable: -	 ppid: 0
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:      3 name: '[ksoftirqd/0]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:      5 name: '[kworker/0:0H]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:      7 name: '[rcu_preempt]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:      8 name: '[rcu_sched]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:      9 name: '[rcu_bh]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     10 name: '[migration/0]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     11 name: '[lru-add-drain]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     12 name: '[watchdog/0]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     13 name: '[cpuhp/0]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     14 name: '[kdevtmpfs]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     16 name: '[netns]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     17 name: '[khungtaskd]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     18 name: '[oom_reaper]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     19 name: '[writeback]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     20 name: '[kcompactd0]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     21 name: '[ksmd]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     22 name: '[crypto]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     23 name: '[kintegrityd]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     24 name: '[bioset]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     25 name: '[kblockd]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     26 name: '[ata_sff]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     27 name: '[irq/171-4802a00]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     28 name: '[irq/172-4819c00]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     29 name: '[devfreq_wq]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     30 name: '[watchdogd]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     31 name: '[rpciod]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     32 name: '[xprtiod]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     33 name: '[kswapd0]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     34 name: '[vmstat]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     35 name: '[nfsiod]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     36 name: '[bioset]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     37 name: '[xfsalloc]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     38 name: '[xfs_mru_cache]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     67 name: '[kthrotld]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     68 name: '[kapmd]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     71 name: '[irq/41-48060000]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     73 name: '[53500000.aes-en]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     87 name: '[irq/191-TI-am33]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     88 name: '[irq/195-4803800]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     89 name: '[irq/194-4803800]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     90 name: '[ipv6_addrconf]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:     91 name: '[bioset]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    100 name: '[bioset]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    101 name: '[irq/170-44e0b00]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    103 name: '[mmcqd/0]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    104 name: '[irq/200-tps6521]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    260 name: '[kworker/0:1H]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    435 name: '[jbd2/mmcblk0p1-]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    436 name: '[ext4-rsv-conver]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    464 name: systemd-journal	 executable: /mnt/old_root/lib/systemd/systemd-journald	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    470 name: '[kauditd]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    484 name: systemd-udevd	 executable: /lib/systemd/systemd-udevd	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    527 name: systemd-timesyn	 executable: /lib/systemd/systemd-timesyncd	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    546 name: '[ptp0]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    551 name: cron	 executable: /mnt/old_root/usr/sbin/cron	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    554 name: rsyslogd	 executable: /mnt/old_root/usr/sbin/rsyslogd	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    555 name: node	 executable: /mnt/old_root/home/user/.nvm/versions/node/v6.9.2/bin/node	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    559 name: systemd-logind	 executable: /mnt/old_root/lib/systemd/systemd-logind	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    561 name: dbus-daemon	 executable: /mnt/old_root/usr/bin/dbus-daemon	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    586 name: python2	 executable: /mnt/old_root/usr/bin/python2.7	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    590 name: python2	 executable: /mnt/old_root/usr/bin/python2.7	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    595 name: avahi-daemon	 executable: /mnt/old_root/usr/sbin/avahi-daemon	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    602 name: avahi-daemon	 executable: /mnt/old_root/usr/sbin/avahi-daemon	 ppid: 595
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    650 name: dhclient	 executable: /mnt/old_root/sbin/dhclient	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    776 name: login	 executable: /mnt/old_root/bin/login	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:    780 name: sshd	 executable: /mnt/old_root/usr/sbin/sshd	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:   1116 name: python2	 executable: /mnt/old_root/usr/bin/python2.7	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:   1187 name: agetty	 executable: /mnt/old_root/sbin/agetty	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:   1216 name: login	 executable: /mnt/old_root/bin/login	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:   1227 name: systemd	 executable: /mnt/old_root/lib/systemd/systemd	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:   1229 name: (sd-pam)	 executable: /mnt/old_root/lib/systemd/systemd	 ppid: 1227
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:   1233 name: startx	 executable: /mnt/old_root/bin/dash	 ppid: 1216
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:   1262 name: xinit	 executable: /mnt/old_root/usr/bin/xinit	 ppid: 1233
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:   1264 name: Xorg	 executable: /mnt/old_root/usr/lib/xorg/Xorg	 ppid: 1262
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:   1284 name: fluxbox	 executable: /mnt/old_root/usr/bin/fluxbox	 ppid: 1262
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:   1298 name: dbus-daemon	 executable: /mnt/old_root/usr/bin/dbus-daemon	 ppid: 1227
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:   1345 name: unclutter	 executable: /mnt/old_root/usr/bin/unclutter	 ppid: 1284
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:   1346 name: ssh-agent	 executable: /mnt/old_root/usr/bin/ssh-agent	 ppid: 1284
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:   1355 name: midori	 executable: /mnt/old_root/usr/bin/midori	 ppid: 1284
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:   1476 name: bash	 executable: /mnt/old_root/bin/bash	 ppid: 776
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  13769 name: sshd	 executable: /mnt/old_root/usr/sbin/sshd	 ppid: 780
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  13779 name: sshd	 executable: /mnt/old_root/usr/sbin/sshd	 ppid: 13769
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  13780 name: bash	 executable: /mnt/old_root/bin/bash	 ppid: 13779
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  14235 name: '[kworker/u2:2]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  14395 name: '[scsi_eh_0]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  14396 name: '[scsi_tmf_0]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  14397 name: '[usb-storage]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  14403 name: '[bioset]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  14404 name: '[bioset]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  14510 name: '[kworker/0:3]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  16699 name: '[kworker/u2:0]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  16779 name: '[kworker/0:0]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17191 name: '[kworker/u2:1]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17344 name: '[kworker/0:1]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17531 name: '[kworker/0:2]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17637 name: bash	 executable: /mnt/old_root/bin/bash	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17644 name: sudo	 executable: /mnt/old_root/usr/bin/sudo	 ppid: 17637
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17645 name: python2	 executable: /mnt/old_root/usr/bin/python2.7	 ppid: 17644
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17651 name: sudo	 executable: /mnt/old_root/usr/bin/sudo	 ppid: 13780
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17652 name: takeover	 executable: /mnt/old_root/home/user/balena/takeover	 ppid: 17651
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17667 name: '[bioset]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17669 name: '[bioset]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17670 name: '[bioset]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17671 name: '[bioset]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17672 name: '[bioset]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17673 name: '[bioset]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17674 name: '[bioset]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17676 name: '[bioset]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17687 name: '[jbd2/sdb1-8]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17688 name: '[ext4-rsv-conver]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17689 name: '[ext4lazyinit]'	 executable: -	 ppid: 2
2024-06-28 07:38:47 DEBUG [takeover::stage2] pid:  17705 name: takeover	 executable: /bin/takeover	 ppid: 1
2024-06-28 07:38:47 DEBUG [takeover::common::system] looking at pid: 1, fd 0, file: '/proc/1/fd/0' -> 'pipe:[1213351]'
2024-06-28 07:38:47 DEBUG [takeover::common::system] looking at pid: 1, fd 1, file: '/proc/1/fd/1' -> '/stdout.log'
2024-06-28 07:38:47 DEBUG [takeover::common::system] looking at pid: 1, fd 2, file: '/proc/1/fd/2' -> '/stderr.log'
2024-06-28 07:38:47 DEBUG [takeover::common::system] looking at pid: 1, fd 3, file: '/proc/1/fd/3' -> '/mnt/log/stage2-init.log'
2024-06-28 07:38:47 DEBUG [takeover::common::system] looking at pid: 1, fd 4, file: '/proc/1/fd/4' -> 'pipe:[1213351]'
2024-06-28 07:38:47 DEBUG [takeover::common::system] looking at pid: 464, fd 0, file: '/proc/464/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:47 DEBUG [takeover::common::system] sending signal 15 to 464
2024-06-28 07:38:47 DEBUG [takeover::common::system] looking at pid: 484, fd 0, file: '/proc/484/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:47 DEBUG [takeover::common::system] sending signal 15 to 484
2024-06-28 07:38:47 DEBUG [takeover::common::system] looking at pid: 527, fd 0, file: '/proc/527/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:47 DEBUG [takeover::common::system] sending signal 15 to 527
2024-06-28 07:38:47 DEBUG [takeover::common::system] looking at pid: 551, fd 0, file: '/proc/551/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:47 DEBUG [takeover::common::system] sending signal 15 to 551
2024-06-28 07:38:47 DEBUG [takeover::common::system] looking at pid: 554, fd 0, file: '/proc/554/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:47 DEBUG [takeover::common::system] sending signal 15 to 554
2024-06-28 07:38:47 DEBUG [takeover::common::system] looking at pid: 555, fd 0, file: '/proc/555/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:47 DEBUG [takeover::common::system] sending signal 15 to 555
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 559, fd 0, file: '/proc/559/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 559
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 561, fd 0, file: '/proc/561/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 561
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 586, fd 0, file: '/proc/586/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 586
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 590, fd 0, file: '/proc/590/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 590
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 595, fd 0, file: '/proc/595/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 595
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 602, fd 0, file: '/proc/602/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 602
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 650, fd 0, file: '/proc/650/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 650
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 776, fd 0, file: '/proc/776/fd/0' -> '/mnt/old_root/dev/ttyS0'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 776
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 780, fd 0, file: '/proc/780/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 780
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 1116, fd 0, file: '/proc/1116/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 1116
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 1187, fd 0, file: '/proc/1187/fd/0' -> '/mnt/old_root/dev/ttyGS0'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 1187
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 1216, fd 0, file: '/proc/1216/fd/0' -> '/mnt/old_root/dev/tty1'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 1216
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 1227, fd 0, file: '/proc/1227/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 1227
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 1229, fd 0, file: '/proc/1229/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 1229
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 1233, fd 0, file: '/proc/1233/fd/0' -> '/mnt/old_root/dev/tty1'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 1233
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 1262, fd 0, file: '/proc/1262/fd/0' -> '/mnt/old_root/dev/tty1'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 1262
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 1264, fd 0, file: '/proc/1264/fd/0' -> '/mnt/old_root/dev/tty1'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 1264
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 1284, fd 0, file: '/proc/1284/fd/0' -> '/mnt/old_root/dev/tty1'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 1284
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 1298, fd 0, file: '/proc/1298/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 1298
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 1346, fd 0, file: '/proc/1346/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 1346
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 1355, fd 0, file: '/proc/1355/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 1355
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 13769, fd 0, file: '/proc/13769/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 13769
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 13780, fd 0, file: '/proc/13780/fd/0' -> '/mnt/old_root/dev/pts/0'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 13780
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 17637, fd 0, file: '/proc/17637/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 17637
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 17644, fd 0, file: '/proc/17644/fd/0' -> '/mnt/old_root/dev/null'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 17644
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 17651, fd 0, file: '/proc/17651/fd/0' -> '/mnt/old_root/dev/pts/0 (deleted)'
2024-06-28 07:38:48 DEBUG [takeover::common::system] sending signal 15 to 17651
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 17705, fd 0, file: '/proc/17705/fd/0' -> 'pipe:[1213351]'
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 17705, fd 1, file: '/proc/17705/fd/1' -> '/stdout.log'
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 17705, fd 2, file: '/proc/17705/fd/2' -> '/stderr.log'
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 17705, fd 3, file: '/proc/17705/fd/3' -> '/mnt/log/stage2.log'
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 17705, fd 4, file: '/proc/17705/fd/4' -> 'pipe:[1213351]'
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 17705, fd 5, file: '/proc/17705/fd/5' -> '/proc'
2024-06-28 07:38:48 DEBUG [takeover::common::system] looking at pid: 17705, fd 6, file: '/proc/17705/fd/6' -> '/proc/17705/fd'
2024-06-28 07:38:51 WARN  [takeover::common::system] process still alive after signal 15, pid: 1284, '/mnt/old_root/usr/bin/fluxbox'
2024-06-28 07:38:56 DEBUG [takeover::common::system] looking at pid: 1, fd 0, file: '/proc/1/fd/0' -> 'pipe:[1213351]'
2024-06-28 07:38:56 DEBUG [takeover::common::system] looking at pid: 1, fd 1, file: '/proc/1/fd/1' -> '/stdout.log'
2024-06-28 07:38:56 DEBUG [takeover::common::system] looking at pid: 1, fd 2, file: '/proc/1/fd/2' -> '/stderr.log'
2024-06-28 07:38:56 DEBUG [takeover::common::system] looking at pid: 1, fd 3, file: '/proc/1/fd/3' -> '/mnt/log/stage2-init.log'
2024-06-28 07:38:56 DEBUG [takeover::common::system] looking at pid: 1, fd 4, file: '/proc/1/fd/4' -> 'pipe:[1213351]'
2024-06-28 07:38:56 DEBUG [takeover::common::system] looking at pid: 1284, fd 0, file: '/proc/1284/fd/0' -> '/mnt/old_root/dev/tty1'
2024-06-28 07:38:56 DEBUG [takeover::common::system] sending signal 9 to 1284
2024-06-28 07:38:56 DEBUG [takeover::common::system] looking at pid: 17705, fd 0, file: '/proc/17705/fd/0' -> 'pipe:[1213351]'
2024-06-28 07:38:56 DEBUG [takeover::common::system] looking at pid: 17705, fd 1, file: '/proc/17705/fd/1' -> '/stdout.log'
2024-06-28 07:38:56 DEBUG [takeover::common::system] looking at pid: 17705, fd 2, file: '/proc/17705/fd/2' -> '/stderr.log'
2024-06-28 07:38:56 DEBUG [takeover::common::system] looking at pid: 17705, fd 3, file: '/proc/17705/fd/3' -> '/mnt/log/stage2.log'
2024-06-28 07:38:56 DEBUG [takeover::common::system] looking at pid: 17705, fd 4, file: '/proc/17705/fd/4' -> 'pipe:[1213351]'
2024-06-28 07:38:56 DEBUG [takeover::common::system] looking at pid: 17705, fd 5, file: '/proc/17705/fd/5' -> '/proc'
2024-06-28 07:38:56 DEBUG [takeover::common::system] looking at pid: 17705, fd 6, file: '/proc/17705/fd/6' -> '/proc/17705/fd'
2024-06-28 07:38:59 INFO  [takeover::stage2] Found 484 MiB total, 253 MiB free memory
2024-06-28 07:38:59 ERROR [takeover::stage2] Not enough memory space found to copy files to RAMFS, required size is 287 MiB free memory is 253 MiB
2024-06-28 07:38:59 ERROR [takeover::stage2] Failed to copy files to RAMFS, error: Error { kind: Displayed, cause: None, context: None }
# df -h

Filesystem      Size  Used Avail Use% Mounted on
udev            215M     0  215M   0% /dev
tmpfs            49M  3.6M   45M   8% /run
/dev/mmcblk0p1   26G  2.3G   23G  10% /
tmpfs           243M     0  243M   0% /dev/shm
tmpfs           5.0M  4.0K  5.0M   1% /run/lock
tmpfs           243M     0  243M   0% /sys/fs/cgroup
tmpfs            49M  4.0K   49M   1% /run/user/1001
/dev/sdb1       3.7G   15M  3.4G   1% /mnt

If I understand correctly, the RAMFS is /tmp/balena-takeover, or am I mistaken?

1 Like

Hello @aslansutu the takeover script needs to copy the required files (including the balenaOS image) to the RAM memory, because storage (disk, SD, etc.) will be fully overwritten when the device is reflashed.

What is surprising is that the logs say Found 484 MiB total, 253 MiB free memory. It’s odd to see the device with only 253MB of RAM free even after we killed all the other running processes.

Could you please share more details of the model and the application that you are running currently? Our team is researching to enable you with the takeover script!

Thanks

Absolutely.

The device is a Beagle Bone Black Rev. C. We are currently using the Debian image provided by BeagleBoard. Some are Debian 9.3, some are be Debian 8. The one I was trying with was Debian 9.3.

There are no complex changes to the system. It has a simple frontend and backend (Python) and communicates with other external components via its pins.

I will go ahead and try with a fresh Debian image in the meantime to check if it has something to do with any changes we made. Also thanks in advance for the help.

1 Like

@aslansutu very soon one of my colleagues is going to test in one of his Beagle Bone Black and we will let you know more!

Please do test on another Beagle Bone with a different Debian version and feel free to share the logs here!

Thanks!

1 Like

Thanks for reporting the failure with takeover @aslansutu. I was able to migrate a Beaglebone Black running Debian 9.5 using the 5.3.4+rev3 image. Let’s see if my experience helps your effort.

I see you specified the image as beaglebone-black-5.3.4+rev3-v16.1.10.img.gz Are you sure this image is a raw image and not a flasher image? The download from balenaCloud provides a flasher image. You need to extract the raw image from it. The raw image is stored in the /opt directory of the flash-rootA partition. See the balena-image-flasher-unwrap repo for a straightforward way to extract the raw image.

On my device, Apache2 was running. The takeover script apparently was unable to dispose of some process related to it. Once I manually stopped Apache before running takeover, the device migrated as expected.

I have attached the logs from my success run. Let us know how it goes.

stage1.log (53.3 KB)
stage2-init.log (3.4 KB)
stage2.log (26.0 KB)

1 Like

So I finally got a chance to retry. I had initially tried downloading the image and passing it over to the script because without it, I would get the error that can be found in stage1-failed.log

I dunno why, but after trying again it seemed to work better. This time the issue seems to stem from the fact that it is unable to remount because the file system is readonly. The device I was using had a fresh Debian image flashed that can be found here (bone-debian-9.3-iot-armhf-2018-03-05-4gb.img.xz). I am going to try a couple more things to see if I can get it to work.

However the original issue was about not enough memory, that could mean I will have to manually kill some of the processes that we have started. I just wanted to update my journey in case anyone else also gets stuck. I have also went ahead and attached my logs as well.

stage1-failed.log (8.1 KB)
stage1.log (17.3 KB)
stage2-init.log (816 Bytes)
stage2.log (28.4 KB)

1 Like

I experienced the same divide by zero with the image download as you report in stage1-failed.log. That was fixed with PR #82.

Your stage1.log got past that point, but it reported a 404 failure on the download and only downloaded 37 bytes. Been there, done that. :slight_smile: See Issue #83. That one has not been fixed yet.

Your stage2.log fails with an inability to unmount a partition. I see traces of Apache2 logs, so I expect this problem is the same as I encountered. See Issue #84.

Suggestions:

I don’t see evidence that you have the required balenaOS image because the download within the takeover script failed. Be sure to verify from my last message on how to collect the raw image. The gzipped raw image is around 185 MB, while the gzipped flasher image is around 290 MB.

Once you are sure you have the right image, follow #84 to stop the Apache2 process, and give it another try. I expect from start to finish takeover will require 5 or 10 minutes to complete. Once the stage1 log display finishes, eventually you should see the blink patterns on the BBB stop as it reboots, then the next indication is the device showing on the balenaCloud dashboard in the fleet you defined in config.json.

You’re making progress. Thanks for your patience as we get this working.

After finally finding time to work on this again I was able to migrate it following @kb2ma’s steps. Just so if anyone else get stuck, I want to document what I did.

Takeover Script

The take over script can be found here in its repo. No need to clone the repo, just download the relevant release. For the BeagleBone Black, it was takeover-armv7-unknown-linux-musleabihf.tar.gz . Extract and you should have the takeover script.

Config

Using the Balena dashboard, once you create a fleet, you can add a device. On the bottom right hand corner, you can choose to only download the config file.

Image

Using the dashboard again, instead of choosing to download the config I downloaded the balena-os image. I believe you can also use the images found in Balena’s website.

You will also need to clone the Balena Image Flasher Unwrap.

The Balena image you have downloaded should have the extension .img.gz so go ahead and unzip that. Copy the .img file to the Balena Image Flasher Unwrap folder. In that folder you can find instructions on how to use it. But essentially it is
./docker-run /absolute/path/to/balena-os.img
Once executed, you can find the file in the output folder. Navigate to the output folder and you will see an img file. We need to now gz zip that. gzip balena-os.img which should output a file with the extension .img.gz.

Execution

Copy the config.json, takeover, and (newly zipped) balena-os.img.gz files to your device.

In order to not leave everything to the script, I wrote a small script that should kill all non essential process. Here is the script if anyone wants to use it.

#!/bin/bash

# Get the process IDs of essential services
ESSENTIAL_PIDS=$(pgrep -f 'sshd|bash|sh')

# Print all processes except the essential ones
ps aux | grep -v -E 'sshd|bash|sh' | awk '{print $2}' | while read pid; do
  if [[ ! "$ESSENTIAL_PIDS" =~ "$pid" ]]; then
    echo "Killing process ID $pid"
    kill -9 $pid
  fi
done

Afterwards I just ran the following commands;
sudo su -
./takeover -c config.json -i balena-cloud-auto-flow-beaglebone-black-5.3.4+rev3-v16.1.10.img.gz --no-nwmgr-check --no-wifis --log-file /root/migrate/stage1.log --log-level trace -l /dev/sdb1 --s2-log-level trace

Obviously, make sure that the paths are correct. (I dunno if having the files in /root and running from there has an effect). The first time I ran it, I ran into some issues. Turns out I had tar.gz zipped my image instead of just gz. The second time I was told that there is not enough memory. However third time worked like a charm.

The only thing I do not know is where to get the config file if one is using openBalena instead of the dashboard. But I guess that problem is for another day. To anyone needing help with this, let me know if anything I’ve said is vauge, I can try to elaborate more.

2 Likes