Awesome
<div align="center"> <img src="https://raw.githubusercontent.com/eclipse/ditto/master/logo/ditto_fordarkbg.svg?sanitize=true#gh-dark-mode-only" alt="Ditto Logo dark" height="250"> <img src="https://raw.githubusercontent.com/eclipse/ditto/master/logo/ditto.svg?sanitize=true#gh-light-mode-only" alt="Ditto Logo light" height="250"> </div>Eclipse Ditto™
Eclipse Ditto™ is a technology in the IoT implementing a software pattern called “digital twins”.
A digital twin is a virtual, cloud based, representation of his real world counterpart (real world “Things”, e.g. devices like sensors, smart heating, connected cars, smart grids, EV charging stations, …).
An ever growing list of adopters makes use of Ditto as part of their IoT platforms - if you're as well using it, it would be super nice to show your adoption here.
Documentation
Find the documentation on the project site: https://www.eclipse.dev/ditto/
Eclipse Ditto™ explorer UI
Find a live version of the latest explorer UI: https://eclipse-ditto.github.io/ditto/
You should be able to work with your locally running default using the local_ditto
environment - and you can add additional environments to also work with e.g. with a deployed installation of Ditto.
Star History
<a href="https://star-history.com/#eclipse-ditto/ditto&Date"> <picture> <source media="(prefers-color-scheme: dark)" srcset="https://api.star-history.com/svg?repos=eclipse-ditto/ditto&type=Date&theme=dark" /> <source media="(prefers-color-scheme: light)" srcset="https://api.star-history.com/svg?repos=eclipse-ditto/ditto&type=Date" /> <img alt="Star History Chart" src="https://api.star-history.com/svg?repos=eclipse-ditto/ditto&type=Date" /> </picture> </a>Getting started
In order to start up Ditto via Docker Compose, you'll need:
- a running Docker daemon
- Docker Compose installed
- for a "single instance" setup on a local machine:
- at least 2 CPU cores which can be used by Docker
- at least 4 GB of RAM which can be used by Docker
You also have other possibilities to run Ditto, please have a look here to explore them.
Start Ditto
In order to start the latest built Docker images from Docker Hub, simply execute:
cd deployment/docker/
docker-compose up -d
Check the logs after starting up:
docker-compose logs -f
Open following URL to get started: http://localhost:8080<br/> Or have a look at the "Hello World"
Additional deployment options are also available, if Docker Compose is not what you want to use.
Development Guide
If you plan to develop extensions in Ditto or to contribute some code, the following steps are of interest for you.
:warning: If you just want to start/use Ditto, please ingore the following sections!
Build and start Ditto locally
In order to build Ditto, you'll need:
- JDK >= 21
- Apache Maven >= 3.9.x installed.
- a running Docker daemon
In order to first build Ditto and then start the built Docker images.
1. Build Ditto with Maven
mvn clean install
Skip tests:
mvn clean install -DskipTests
2. Build local Ditto Docker snapshot images
./build-images.sh
If your infrastructure requires a proxy, its host and port can be set using the -p
option like for example:
./build-images.sh -p 172.17.0.1:3128
Please note that the given host and port automatically applies for HTTP and HTTPS.
3. Start Ditto with local snapshot images
cd ../deployment/docker/
# the "dev.env" file contains the SNAPSHOT number of Ditto, copy it to ".env" so that docker compose uses it:
cp dev.env .env
docker-compose up -d
Check the logs after starting up:
docker-compose logs -f
You have now running:
- a MongoDB as backing datastore of Ditto (not part of Ditto but started via Docker)
- Ditto microservices:
- Policies
- Things
- Things-Search
- Gateway
- Connectivity
- an nginx acting as a reverse proxy performing a simple "basic authentication" listening on port
8080
- including some static HTTP + API documentation on http://localhost:8080