Skip to content

Latest commit

 

History

History
262 lines (175 loc) · 7.23 KB

README.md

File metadata and controls

262 lines (175 loc) · 7.23 KB

Blimp

The setup scripts for a CloudFleet Blimp.

This process deploys an instance of blimp-engineroom to some box (possibly remotely). Upon reboot, this image will control and auto-update a set of Docker containers which make up the Blimp's functionality.

Follow these steps. Instructions that are specific to a RPI2 install are marked [RPI2], those via Cubox are [CUBOX]. We recommend using the RPI2 procedure if possible, due to better Linux kernel support.

The instructions can generally be performed from any Unixy machine. [Linux] or [OS X] labels are used where commands differ.

Debian arm32 setup

TODO: move this procedure to a separate .md file, since the other sections should work for most Debian-based Linux machines (including amd64 VMs).

The first step is to install Debian on your device. Current hardware tested includes arm32 Cubox or Raspberry Pi 2 Model B devices. We recommend using the Raspberry Pi 2.

Download the image

As a first step, download the image. For an appropriate link, see below. Your working path, url and filename might vary, but the procedure goes something like:

BLIMPWORK=~/Downloads
mkdir -p $BLIMPWORK
cd $BLIMPWORK
wget https://images.collabora.co.uk/rpi2/jessie-rpi2-20150705.img.gz
gunzip jessie-rpi2-20150705.img.gz

Make sure you use the correct filename for the remaining steps.

Cubox Image

[CUBOX]

Version 2.6 of the unofficial Cubox Debian images is known to work. Download the image from here.

TODO: explain the luks drivers patch (or include this in our scripts).

Raspberry Pi 2 image

[RPi2] For the Raspberry Pi 2, supported Debian images are documented here.

Download one of these images.

The https://images.collabora.co.uk/rpi2/jessie-rpi2-20150705.img.gz image is known to work.

Find out where the SD card is

Plug in your micro SD card you want to use for the ARM device.

[OS X] First issue a

    diskutil list

Then insert the SD card

    diskutil list

and compare the two entries.

You're looking for the entry of the form /dev/diskN where 'N' is a number. If the SD disk is pre-formatted, it should show up with a 'Windows_FAT_32' partition type.

Copy the image to the SD card

[OS X] After you have determined the correct disk device, you'll need to umount the media.

If the SD card is the only mounted msdos partition,

    mount | grep msdos | awk  '{print $1}'

should show you the partition to unmount.

    diskutil unmountDisk /dev/<disk-with-partition>

Copy the image (on BSD/OS X):

    sudo dd bs=1m if=$BLIMPWORK/<image-raw-or-img> of=/dev/<device>

Using '/dev/rdiskN' rather than '/dev/diskN' should be quite a bit faster.

Check progress with Ctrl+t.

Apparently, using bmap-tools is supposed to be much faster, as it doesn't copy zeros.

Don't forget to unmount when it's done.

    diskutil unmountDisk /dev/<disk-with-partition>

[Linux] It's bs=1M if you're on Linux for dd:

    sudo dd bs=1M if=$BLIMPWORK/<image-raw-or-img> of=/dev/<device>

When you're done, plug the SD card in your ARM device and boot it up.

Find out the IP address

One option is to look at your router's web interface. If that's not possible, from a UNIX host if you know the interface name (something like 'en0'), one can use:

sudo tcpdump -i en0

to watch the initial ethernet traffic.

Log in

Log in to the unit for the first time via SSH as root and set a new root password.

[Cubox] You'll be prompted to reset the password automatically.

[RPI2] The default password is 'debian'. Call passwd afterwards.

Software prerequirements

[RPI2]

Install the minimal packages on the Blimp (a requirement to run the Ansible playbooks on it in a later stage):

    apt-get install python

Resizing the SD image

[RPi2]

The Debian RPi2 image is initially much smaller (~2.2Gib) than what is available on the 16Gib SD cards we are using, small enough that one can't currently run the Ansible process below successfully.

One must manually resize and grow the partition according to the following instructions:

http://elinux.org/RPi_Resize_Flash_Partitions#Manually_resizing_the_SD_card_on_Raspberry_Pi

Ignore the bit in the instructions about deleting swap space, as our current DPi2 does not have a swap partition. In short:

sudo fdisk /dev/mmcblk0
p # to see the current start of the main partition
d
2 # to delete the main partition
n
p
2 # to create a new primary partition, double-enter to fill start to end
w # write the new partition table

A more sensible process would be to use the rest of the SD as btrfs, moving what is needed over to that. Unknown how btrfs does with SD cards, perhaps better with the copy on write (CoW) semantics?

Run the Ansible scripts

Copy the hosts-remote (i.e. file:blimp/scripts/ansible/hosts-remote.example) file to file:blimp/scripts/ansible/hosts-remote and fill out the the desired values

cd scripts/ansible
cp hosts-remote.example hosts-remote # now edit hosts-remote
# update the env variables below to match your case

Run Ansible to populate the base image with all the tools necessary to run blimp-engineroom:

BLIMP_HOSTNAME=myblimp \
ansible-playbook -k -i hosts-remote blimp-first-time.yml

You'll be prompted for the root password.

Your ssh key is authorized after the first run, so you should be able to ssh without a password and can omit -k. This should be skipped for production deployments with --skip-tags=dev. To speed things up on subsequent runs, you can do --skip-tags=packages.

Reboot the Blimp

After Ansible completes, reboot the Blimp, so that it upgrades itself and starts all the Docker containers

    reboot

[VirtualBox] Installing a Blimp in Virtualbox

Use Debian Jessie

enable root login via password

Edit file:/etc/ssh/sshd_config to change the 'PermitRootLogin' line to read:

PermitRootLogin yes

Restart sshd

/etc/init.d/ssh restart

Setup port forwarding for SSH to localhost:2222

Copy hosts-remote.example to hosts-remote

Copy file:scripts/ansible/hosts-remote.example to file:scripts/ansible/hosts-remote

blimpie ansible_ssh_port=2222 ansible_ssh_user=root ansible_ssh_host=127.0.0.1

Deprecated

Deprecated: this manual workflow is not current any more, while we're transitioning to keeping all the scripts in blimp-engineroom.**

To run the Blimp on an ARM device, install the dependencies:

./scripts/install.sh

Edit /etc/environment and add:

CLOUDFLEET_DOMAIN=subdomain.bonniecloud.com
CLOUDFLEET_SECRET=password
CLOUDFLEET_HOST=blimpyard.cloudfleet.io:443

And start the services:

./scripts/start.sh

Development

To run the it on a desktop in a single Docker container run:

./run_blimp.sh username

TODO

Create a postgres replacement:

https://github.com/docker-library/postgres.git library/postgres /9.4/