Skip to content

nstoik/farm_device

Repository files navigation

Farm Device

Main documentation for the Farm Device project.

Raspberry Pi Ubuntu 21.04 host setup

Installing Docker and Docker Compose

To install Docker and Docker Compose, follow the steps from the Docker Webpage

Additional Host Setup

Add the required packages by running the following commands.

sudo apt install i2c-tools

Add the following line to /boot/firmware/config.txt

dtoverlay=w1-gpio

First Time Setup

  1. Pull the latest code from the repository.
  2. Copy the .env.example file to .env and edit the values to match your setup.
  3. Pull the docker images down to the host machine (see Production)
  4. Start the docker containers (see Production)
  5. When starting, the fd_device container will check the database if the first time setup has been run.
    • If it has, the application will start normally.
    • If it has not, the application will notify the user to run the first time setup and then exit.
      • To go through the first time setup, run the following docker command (with the other docker containers still running):
        docker run --rm -it --network=farm_device -e "FD_DEVICE_CONFIG=dev" nstoik/fd_device:dev /bin/bash -c "pipenv run fd_device first-setup"
      • Set the FD_DEVICE_CONFIG environment variable to as needed
      • Set the image tag to match the container
      • IF a standalone device, add --standalone to the command
      • Go through the first time setup steps.
      • Restart the containers (see Production)

Environment Variables

There is a set of environment variables that can be used to configure the application. In the GitHub repository, an example configuration file is available in the root directory as .env.example.

There are SECRET variables and there are CONFIGURATION variables.

This file has a FD_GENERAL_CONFIG variable at the top that controls the general configuration of the different mono repos. Hint: change this variable between 'dev', 'prod', or 'test'.

The majority of the docker commands use the .env file by default to configure the containers. Edit the .env file as needed for the specific environment (including setting SECRET and TOKEN variables).

The docker buildx bake commands use configuration variables in the docker-bake.hcl file. These can be overridden as shown below when building images using docker buildx bake.

The containers use environment variables when the stack is brought up (environment variables). Some containers require build-args to be applied at build time instead.

Each monorepo can have its own set of environment variables if applicable. This are used for local development and testing. An example configuration file is available in the monorepo directory as .env.example.

Production

Make sure to set the appropriate environment variables

To run farm_device in production, execute the following docker-compose command from the root of the project:

docker compose -f docker-compose.yml -f docker-compose.prod.yml --env-file .env -p fd_prod up -d --no-build

To bring down the stack, run:

docker compose -f docker-compose.yml -f docker-compose.prod.yml --env-file .env -p fd_prod down

Development

Make sure to set the appropriate environment variables

Remote vs Local Devlopment

Some of the file paths in the development files are configured differently depending on whether you are developing locally (on the same machine) or remotely (eg. a Raspberry Pi). These files include:

  • .vscode\settings.json
  • ..\.devcontainer\devcontainer.json
    • one under the device subfolder
    • one under the 1wire subfolder
  • docker-compose.devcontainer.yml
    • change the workspace mount
  • docker-compose.yml
    • comment out the 1w_bus_master mount on the fd_device container for local development
    • comment out the i2c device on the fd_1wire container for local development

Docker Commands

To run the farm_device in development, execute the following docker-compose command from the root of the project:

Note the different second file paramater, -f docker-compose.dev.yml flag. This is for the development environment.

docker compose -f docker-compose.yml -f docker-compose.dev.yml --env-file .env -p fd_dev up -d

To bring down the stack run:

docker compose -f docker-compose.yml -f docker-compose.dev.yml --env-file .env -p fd_dev down

VS Code Development

VS Code automatically builds the required containers when you launch into a remote container. This uses the docker-compose.devcontainer.yml overrides.

To bring the farm device stack down and remove the containers, run:

docker compose -f docker-compose.yml -f docker-compose.dev.yml -f docker-compose.devcontainer.yml down

Building Docker Containers

There are multiple options for building the docker containers

Login to Docker Hub

To login to docker hub, execute the following command and enter your credentials:

docker login

This is required to push the containers to docker hub.

Build single platform container

To build a single docker container for a single platform, execute the following command:

docker build {PATH} --file {PATH}/Dockerfile --no-cache --pull --build-arg {ENV NAME}={ENV VALUE} --tag nstoik/{module}:{tag}

An example command for building the fd_device container version 1.0.0-rc is:

docker build device --file device/Dockerfile --no-cache --pull --tag nstoik/fd_device:1.0.0-rc
  • {PATH} is the submodule path
  • --build-arg is optional and can pass in environment variables to docker build. It can be repeated for multiple variables.
    • {ENV NAME} is the name of the environment variable
    • {ENV VALUE} is the value of the environment variable
  • {module} is the name of the module
  • {tag} is the tag of the docker image

Bulid multiple containers for a single platform

To build multiple docker containers for a single platform, execute the following command:

docker compose --file {docker-compose file} --env-file {env file} build --no-cache --pull

An example command for building all containers for prod is below. Upddate the FD_TAG variable in the environment file to the tag you want to build.

docker compose --file docker-compose.yml --file docker-compose.prod.yml --env-file .env build --no-cache --pull

To push the containers to the docker hub, execute the following command:

docker compose --file {docker-compose file} --env-file {env file} push
  • {docker-compose file} is the docker-compose file
  • {env file} is the .env file

Building multi platform containers and pushing to a registry

First setup the prequisites. Configure buildx tools

docker buildx create --name fd_buildx

To list the available builders run:

docker buildx ls

Bake all the containers. In the example below, the TAG variable is set to the tag you want to build.

TAG=0.1 docker buildx bake --builder fd_buildx --file docker-bake.hcl --push

To bake a single target or group specified in the docker-bake.hcl configuration file, run the following, replacing "TARGET_NAME" with the target or group name:

TAG=0.1 docker buildx bake --builder fd_buildx --file docker-bake.hcl --push "TARGET_NAME"

Note Overwrite variables defined in the docker-bake.hcl file by specifying them as arguments to the command. Any required ARG in the docker files need to be specified in the docker-bake.hcl file.

The list of available variables are:

  • TAG: The tag of the docker image to build. Defaults to "dev"
  • MULTI_STAGE_TARGET: The target to build. Defaults to "prod-stage"

A few additional comments on the docker-bake.hcl file:

  • print is optional and will print the configuration of the builder
  • push will push the built images to the registry
  • --load is optional and will load the image into docker
    • When using --load, only a sinle platform can be specified. An example of overriding the platform for 'linux/amd64' is --set default.platform=linux/amd64

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Packages

No packages published