In the root folder of the project, run the following command to build the Java applications
$ mvn clean package
Create a new Stream and Topic in your MapR Cluster:
$ maprcli stream create -path /apps/sensors -produceperm p -consumeperm p -topicperm p
$ maprcli stream topic create -path /apps/sensors -topic computer
Create a directory to store application logs
$ mkdir -p /mapr/maprdemo.mapr.io/apps/logs
Sensor Application
$ cd sensor-service
$ docker build -t mapr-sensor-producer .
$ docker run -it -e MAPR_CLDB_HOSTS=host.docker.internal -e MAPR_CLUSTER=maprdemo.mapr.io -e MAPR_CONTAINER_USER=mapr --name producer -i -t mapr-sensor-producer
Web Application
$ cd webserver-service
$ docker build -t mapr-web-consumer .
$ docker run -it --privileged --cap-add SYS_ADMIN --cap-add SYS_RESOURCE --device /dev/fuse -p 8080:8080 -e MAPR_CLDB_HOSTS=host.docker.internal -e MAPR_CLUSTER=maprdemo.mapr.io -e MAPR_CONTAINER_USER=mapr -e MAPR_MOUNT_PATH=/mapr --name web -i -t mapr-web-consumer
Alternatively, after building the Java applications with mvn
, you can use the docker-compose.yml
file to run the Sensor and Web applications running a local instance of the
MapR Container for Developers.
$ docker-compose up
Access the Web application in the host using http://localhost:8080