Skip to content
Snippets Groups Projects
development.md 2.04 KiB
Newer Older
Andrew Kapuscinski's avatar
Andrew Kapuscinski committed
# Development Guide

## Overview
Workspaces' services run on Docker containers. These containers can be all started at once using Docker Compose.

### Setup
Build the base image:
```sh
docker build -t brooks.aoc.nrao.edu:5000/ssa-docker/workspaces/base:local -f Dockerfile.base .
Andrew Kapuscinski's avatar
Andrew Kapuscinski committed
```

This builds a local Docker image tagged as `brooks.aoc.nrao.edu:5000/ssa-docker/workspaces/base:local` on your machine
using the `Dockerfile.base` Dockerfile. Once the image has been built, Docker will save this image on your machine.
Andrew Kapuscinski's avatar
Andrew Kapuscinski committed

Next, you will need to run a similar command for the cache image:
```sh
docker build --no-cache -t brooks.aoc.nrao.edu:5000/ssa-docker/workspaces/cache:local -f Dockerfile.cache . --build-arg BASE_IMAGE_TAG=local --build-arg BASE_REGISTRY_URL="brooks.aoc.nrao.edu:5000/ssa-docker/workspaces"
```
Andrew Kapuscinski's avatar
Andrew Kapuscinski committed

### Starting Workspaces
To start a dev version of Workspaces as foreground process, run:
Andrew Kapuscinski's avatar
Andrew Kapuscinski committed
```sh
docker compose -f docker-compose.yml -f docker-compose.local.yml up
Andrew Kapuscinski's avatar
Andrew Kapuscinski committed
```

To start a porduction version of Workspaces as background process, run:
Andrew Kapuscinski's avatar
Andrew Kapuscinski committed
```sh
docker compose -f docker-compose.yml up -d
Andrew Kapuscinski's avatar
Andrew Kapuscinski committed
```

### Stopping Workspaces
To stop Workspaces, run:
```sh
docker compose -f docker-compose.local.yml down
Andrew Kapuscinski's avatar
Andrew Kapuscinski committed
```

### Starting Individual Services
To start Workspaces as foreground process, run:
```sh
docker compose -f docker-compose.local.yml up <service_name>
Andrew Kapuscinski's avatar
Andrew Kapuscinski committed
```

### List Containers
To get a list of running containers:
```sh
docker container ls
```
Or:
```sh
docker ps
```

### Show Container Logs
To output logs of a specific container:
```sh
docker logs <container_name>
```

To continuously tail logs of a specific container:
```sh
docker logs -f <container_name>
```

### Open a Shell on a Running Container
Using Docker:
```sh
docker exec -it <container_name> bash
```

Using Docker Compose:
```sh
docker compose -f docker-compose.local.yml exec <service_name> bash
Andrew Kapuscinski's avatar
Andrew Kapuscinski committed
```

### Run a command on a Running Container
Using Docker:
```sh
docker exec <container_name> pwd
```

Using Docker Compose:
```sh
docker compose -f docker-compose.local.yml exec <service_name> pwd
Andrew Kapuscinski's avatar
Andrew Kapuscinski committed
```