nifi/minifi/minifi-docker/dockerhub/README.md

67 lines
3.3 KiB
Markdown

<!--
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You under the Apache License, Version 2.0
(the "License"); you may not use this file except in compliance with
the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
-->
# Docker Image Quickstart
## Building
The Docker image can be built using the following command:
docker build -t apache/nifi-minifi:latest .
This build will result in an image tagged apache/nifi:latest
$ docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
apache/nifi-minifi latest f0f564eed149 A long, long time ago 226MB
**Note**: The default version of NiFi specified by the Dockerfile is typically that of one that is unreleased if working from source.
To build an image for a prior released version, one can override the `MINIFI_VERSION` build-arg with the following command:
docker build --build-arg=MINIFI_VERSION={Desired MiNiFi Version} -t apache/nifi-minifi:latest .
## Running a container
### Supplying configuration to a container
The primary means by which a MiNiFi instance is configured is via the `flow.json.raw` or the `bootstrap.conf`.
This can be accomplished through:
* the use of volumes, and
* overlaying the base image
#### Using volumes to provide configuration
The following example shows the usage of two volumes to provide both a `flow.json.raw` and a `bootstrap.conf` to the container instance. This makes use of configuration files on the host and maps them to be used by the MiNiFi instance. This is helpful in scenarios where a single image is used for a variety of configurations.
docker run -d \
-v ~/minifi-conf/flow.json.raw:/opt/minifi/minifi-current/conf/flow.json.raw \
-v ~/minifi-conf/bootstrap.conf:/opt/minifi/minifi-current/conf/bootstrap.conf \
apache/nifi-minifi:latest
#### Using volumes to provide configuration
Alternatively, it is possible to create a custom image inheriting from the published image. Creating a `Dockerfile` extending from the Apache NiFi MiNiFi base image allows users to overlay the configuration permanently into a newly built and custom image. A simple example follows:
FROM apache/nifi-minifi
ADD flow.json.raw /opt/minifi/minifi-current/conf/flow.json.raw
ADD bootstrap.conf /opt/minifi/minifi-current/conf/bootstrap.conf
Building this `Dockerfile` will result in a custom image with the specified configuration files incorporated into the new image. This is best for applications where configuration is well defined and relatively static.
For more information, please consult [Dockerfile Reference: FROM](https://docs.docker.com/engine/reference/builder/#from)