Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add containerization for samples w/ container documentation #64

Merged
merged 7 commits into from
Nov 6, 2023
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions .accepted_words.txt
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ chariott
com
config
containerized
Containerization
Ctrl
dev
digitaltwins
Expand Down Expand Up @@ -48,6 +49,7 @@ libfontconfig
libsdl
localhost
loopback
md
microsoft
minimalistic
mosquitto
Expand Down
2 changes: 2 additions & 0 deletions .github/workflows/check-spelling.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,10 @@ jobs:
- name: Check spelling
run: |
./tools/check_spelling.sh ./README.md
./tools/check_spelling.sh ./container/README.md
./tools/check_spelling.sh ./core/common/README.md
./tools/check_spelling.sh ./dtdl-parser/README.md
./tools/check_spelling.sh ./docs/design/README.md
./tools/check_spelling.sh ./samples/container/README.md
./tools/check_spelling.sh ./samples/managed_subscribe/README.md
shell: bash
6 changes: 2 additions & 4 deletions Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,6 @@
# Licensed under the MIT license.
# SPDX-License-Identifier: MIT

# syntax=docker/dockerfile:1

# Comments are provided throughout this file to help you get started.
# If you need more help, visit the Dockerfile reference guide at
# https://docs.docker.com/engine/reference/builder/
Expand Down Expand Up @@ -63,13 +61,13 @@ USER appuser
WORKDIR /sdv

# Set home environment variable.
ENV IBEJI_HOME=/sdv
ENV IBEJI_HOME=/sdv/config

# Copy the executable from the "build" stage.
COPY --from=build /sdv/service /sdv/

# Copy configuration for service.
COPY --from=build /sdv/container/config/standalone/ /sdv/
COPY --from=build /sdv/container/config/standalone/ /sdv/config

# Expose the port that the application listens on.
EXPOSE 5010
Expand Down
6 changes: 2 additions & 4 deletions Dockerfile.integrated
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,6 @@
# Licensed under the MIT license.
# SPDX-License-Identifier: MIT

# syntax=docker/dockerfile:1

# Comments are provided throughout this file to help you get started.
# If you need more help, visit the Dockerfile reference guide at
# https://docs.docker.com/engine/reference/builder/
Expand Down Expand Up @@ -63,13 +61,13 @@ USER appuser
WORKDIR /sdv

# Set home environment variable.
ENV IBEJI_HOME=/sdv
ENV IBEJI_HOME=/sdv/config

# Copy the executable from the "build" stage.
COPY --from=build /sdv/service /sdv/

# Copy configuration for service.
COPY --from=build /sdv/container/config/integrated/ /sdv/
COPY --from=build /sdv/container/config/integrated/ /sdv/config

# Expose the port that the application listens on.
EXPOSE 5010
Expand Down
83 changes: 4 additions & 79 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,9 +20,6 @@
- [Streaming Sample](#streaming-sample)
- [Using Chariott](#using-chariott)
- [Running in a Container](#running-in-a-container)
- [Dockerfile](#dockerfile)
- [Docker](#docker)
- [Podman](#podman)
- [Trademarks](#trademarks)

## <a name="introduction">Introduction</a>
Expand Down Expand Up @@ -75,7 +72,8 @@ sudo apt install -y protobuf-compiler

### <a name="install-sdl2-library">Install SDL2 library</a>

You will need to install the libsdl2-dev library. This can be done by executing:
You will need to install the libsdl2-dev library. This is used by the streaming sample to view
wilyle marked this conversation as resolved.
Show resolved Hide resolved
images. Install the libsdl2-dev library by executing:

```shell
sudo apt install -y libsdl2-dev
Expand Down Expand Up @@ -299,82 +297,9 @@ rather than having it statically provided in their respective config file, then

## <a name="running-in-a-container">Running in a Container</a>

Below are the steps for running the service in a container. Note that the configuration files used
by the containerized service are cloned from [container/config](./container/config/) defined in the
project's root.
To run the In-Vehicle Digital Twin Service in a container, please refer to [Ibeji Containerization](./container/README.md).

### <a name="dockerfile">Dockerfile</a>

There are currently two dockerfiles provided in the root directory of the project that can be built:

- Dockerfile - A standalone version of the In-Vehicle Digital Twin Service
- Dockerfile.integrated - A version of the In-Vehicle Digital Twin Service that communicates with
the [Chariott Service](https://github.com/eclipse-chariott/chariott) and the
[Agemo Service](https://github.com/eclipse-chariott/Agemo).

### <a name="docker">Docker</a>

<b>Prerequisites</b>

[Install Docker](https://docs.docker.com/engine/install/)

<b>Running in Docker</b>

To run the service in a Docker container:

1. Run the following command in the project's root directory to build the docker container from the
Dockerfile:

```shell
docker build -t invehicle_digital_twin -f Dockerfile .
```

1. Once the container has been built, start the container in interactive mode with the following
command in the project's root directory:

```shell
docker run --name invehicle_digital_twin -p 5010:5010 --env-file=./container/config/docker.env --add-host=host.docker.internal:host-gateway -it --rm invehicle_digital_twin
```

1. To detach from the container, enter:

<kbd>Ctrl</kbd> + <kbd>p</kbd>, <kbd>Ctrl</kbd> + <kbd>q</kbd>

1. To stop the container, enter:

```shell
docker stop invehicle_digital_twin
```

### <a name="podman">Podman</a>

<b>Prerequisites</b>

[Install Podman](https://podman.io/docs/installation)

<b>Running in Podman</b>

To run the service in a Podman container:

1. Run the following command in the project's root directory to build the podman container from the
Dockerfile:

```shell
podman build -t invehicle_digital_twin:latest -f Dockerfile .
```

1. Once the container has been built, start the container with the following command in the
project's root directory:

```shell
podman run -p 5010:5010 --env-file=./container/config/podman.env --network=slirp4netns:allow_host_loopback=true localhost/invehicle_digital_twin
```

1. To stop the container, run:

```shell
podman ps -f ancestor=localhost/invehicle_digital_twin:latest --format="{{.Names}}" | xargs podman stop
```
To run the samples in a container, please refer to [Samples Containerization](./samples/container/README.md).

## <a name="trademarks">Trademarks</a>

Expand Down
91 changes: 91 additions & 0 deletions container/.accepted_words.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,91 @@
Agemo
agemo
br
build
cargo
cd
CHARIOTT
Chariott
Chariott's
chariott
com
config
containerize
containerized
Containerization
Ctrl
dev
digitaltwins
dir
Dockerfile
dockerfile
dockerfiles
dotnet
dst
dt
dtdl
DTDL
en
env
fontconfig
gcc
gcc's
github
hardcheese
haudebourg
https
ibeji
Ibeji
Ibeji's
intellectualproperty
invehicle
io
iot
js
json
JSON
kbd
ld
LD
libfontconfig
libsdl
localhost
loopback
md
microsoft
minimalistic
mosquitto
Mosquitto
mqtt
MQTT
netns
opendigitaltwins
plugandplay
Podman
podman
protobuf
Protobuf
ps
repo
Repo
rm
ro
rustup
sdk
sdl
SDL
sdv
slirp
snapd
src
standalone
sudo
timothee
toml
Tonic
toolchain
uri
URI
www
xargs
yaml
117 changes: 117 additions & 0 deletions container/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,117 @@
# Ibeji Containerization

This document covers how to containerize the In-Vehicle Digital Twin Service. To run the samples as
a container please refer to [Samples Containerization](../samples/container/README.md).

## Running the In-Vehicle Digital Twin Service in a Container

Below are the steps for running the service in a container. Note that the configuration files used
by the containerized service are cloned from [/container/config](./config/) defined in the
project's root.

### Dockerfile

There are currently two dockerfiles provided in the root directory of the project that can be built:

- Dockerfile - A standalone version of the In-Vehicle Digital Twin Service
- Dockerfile.integrated - A version of the In-Vehicle Digital Twin Service that communicates with
the [Chariott Service](https://github.com/eclipse-chariott/chariott) and the
[Agemo Service](https://github.com/eclipse-chariott/Agemo).

### Docker

#### Prerequisites

[Install Docker](https://docs.docker.com/engine/install/)

#### Running in Docker

To run the service in a Docker container:

1. Run the following command in the project's root directory to build the docker container from the
Dockerfile:

```shell
docker build -t invehicle_digital_twin -f Dockerfile .
```

1. Once the container has been built, start the container in interactive mode with the following
command in the project's root directory:

```shell
docker run --name invehicle_digital_twin -p 5010:5010 --env-file=./container/config/docker.env --add-host=host.docker.internal:host-gateway -it --rm invehicle_digital_twin
```

1. To detach from the container, enter:

<kbd>Ctrl</kbd> + <kbd>p</kbd>, <kbd>Ctrl</kbd> + <kbd>q</kbd>

1. To stop the container, enter:

```shell
docker stop invehicle_digital_twin
```

#### Running in Docker with overridden configuration

Follow the steps in [Running in Docker](#running-in-docker) to build the container.

1. To run the container with overridden configuration, create your config file and set an
environment variable called IBEJI_HOME to the path to the config file:

```shell
export IBEJI_HOME={path to directory containing config file}
```

1. Then run the container with the following command:

```shell
docker run -v ${IBEJI_HOME}:/sdv/config --name invehicle_digital_twin -p 5010:5010 --env-file=./container/config/docker.env --add-host=host.docker.internal:host-gateway -it --rm invehicle_digital_twin
```

### Podman

#### Prerequisites

[Install Podman](https://podman.io/docs/installation)

#### Running in Podman

To run the service in a Podman container:

1. Run the following command in the project's root directory to build the podman container from the
Dockerfile:

```shell
podman build -t invehicle_digital_twin:latest -f Dockerfile .
```

1. Once the container has been built, start the container with the following command in the
project's root directory:

```shell
podman run -p 5010:5010 --env-file=./container/config/podman.env --network=slirp4netns:allow_host_loopback=true localhost/invehicle_digital_twin
```

1. To stop the container, run:

```shell
podman ps -f ancestor=localhost/invehicle_digital_twin:latest --format="{{.Names}}" | xargs podman stop
```

#### Running in Podman with overridden configuration

Follow the steps in [Running in Podman](#running-in-podman) to build the container.

1. To run the container with overridden configuration, create your config file and set an
environment variable called IBEJI_HOME to the path to the config file:

```shell
export IBEJI_HOME={path to directory containing config file}
jorchiu marked this conversation as resolved.
Show resolved Hide resolved
```

1. Then run the container with the following command:

```shell
podman run --mount=type=bind,src=${IBEJI_HOME},dst=/sdv/config,ro=true -p 5010:5010 --env-file=./container/config/podman.env --network=slirp4netns:allow_host_loopback=true localhost/invehicle_digital_twin:latest
```
Loading
Loading