Dockerfiles for installing, configuring and using the NYC Department of City Planning's Geosupport application from a Docker container.
Version 2.0.23 release notes.
Provides distribution image built from scratch
which contains only a patched and repackaged version of Geosupport allowing for full control and configuration from an unrelated Dockerfile. E.g., simplified creation of volumes and "data-packed volume containers".
FROM someimage:latest
# Get the Geosupport distro
COPY --from=mlipper/geosupport-docker:latest-dist \
/dist/geosupport.tgz \
/opt/geosupport/geosupport.tgz
# Do whatever I want with it...
...
Provides a fully functional Geosupport installation which, by default, is built from image ubuntu:jammy
. This Dockerfile
unpacks, installs and configures Geosupport.
The default CMD
simply prints Geosupport and geosupport-docker version information.
docker run -it --rm geosupport-docker:latest
To run DCP's CLI application for interacting with Geosupport from the command line, use the geosupport
command with the goat
argument:
docker run -it --rm geosupport-docker:latest geosupport goat
------------------------------------------------------------------------------------------
***** Enter a function code or 'X' to exit: hr
You entered hr
Function HR GRC = 00
...etc.
To see what other functionality the geosupport
command provides, run:
docker run -it --rm geosupport-docker:latest geosupport help
However, the most common usage of this Dockerfile
is for creating a volume containing a complete Geosupport installation directory.
# Create a named volume using the Docker CLI
$ docker volume create geosupport-23c_23.3
geosupport-23c_23.3
# Populate the volume with the contents of GEOSUPPORT_BASE (replace the default CMD with a simple no-op command)
$ docker run -it --rm --mount source=geosupport-23c_23.3,target=/opt/geosupport geosupport-docker:latest /bin/true
# Run an interactive bash shell in a new container to test the named volume
$ docker run -it --rm --mount source=geosupport-23c_23.3,target=/opt/geosupport ubuntu:jammy bash
root@fc1d63c26dca# cd /opt/geosupport
root@fc1d63c26dca# ls -l
total 4
lrwxrwxrwx 1 root root 18 Nov 21 18:20 current -> version-23c_23.3
drwxr-xr-x 6 root root 4096 Nov 21 18:55 version-23c_23.3
The Department of City Planning uses the term "release" to refer to data changes and the term "version" to refer to code changes.
The final Geosupport distriubtion is identified as follows:
# Note the underscore and period literals
underscore
|
<major_rel><minor_rel><patch_rel>_<major_ver>.<minor_ver>
|
period
major_rel
- Two-digit yearminor_rel
- Lowercase letterpatch_rel
- Zero or more digits (Optional postfix modifier)major_ver
- Two-digit yearminor_ver
- One or more digits
For example, in the first quarter of 2022, DCP published the distribution for "Geosupport release 22a2 / version 22.11". In this case, the template above has the following values:
22a2_22.11
major_rel
: "22"minor_rel
: "a"patch_rel
: "2"major_ver
: "22"minor_ver
: "11"
This project captures this information in the file <project_dir>/release.conf
. Here are the relevant properties:
# Used for BOTH <major_rel> and <major_ver>
geosupport_major=22
# <minor_rel>
geosupport_release=a
# <patch_rel>
geosupport_patch=2
# <minor_ver>
geosupport_minor=11
NOTE: The geosupport_patch
property in <project_dir>/release.conf
is the only one of these properties that can be (and often is) empty.
For building these images on an architecture other than amd64
, see section Building on platforms other than amd64
below.
This project is built using the release.sh
script in the root project directory (<project_dir>
).
These instructions assume you are using bash
and your current working directory is <project_dir>
:
-
Configure
release.conf
with the correct Geosupport version information. See section "About Geosupport Versions" above for details. -
Create the
dist
directory:mkdir -p dist
-
Download the Linux distribution of Geosupport from the Department of City Planning's Open Data page into the
dist
directory. -
If necessary, rename the downloaded
zip
file to follow the expected naming convention:mv dist/geo23c_23.3.zip dist/linux_geo23c_23_3.zip
-
Verify the configuration:
$ ./release.sh show Property Value ------------------------------ ---------------------------------------- baseimage ubuntu:jammy builddir build buildtimestamp Fri Apr 28 13:28:42 EDT 2023 buildtz America/New_York dcp_distfile linux_geo23c_23_3.zip distdir dist geosupport_basedir /opt/geosupport geosupport_fullversion 23c_23.3 geosupport_major 23 geosupport_minor 2 geosupport_patch geosupport_release b image_name geosupport-docker image_tag 2.0.12 repo_name mlipper vcs_ref e3c2622 Actions ------------------------------ show
-
Generate a clean build:
$ ./release.sh clean generate 2022-12-21 14:43:28 [CLEAN] Removing build directory build... 2022-12-21 14:43:28 [CLEAN] Build directory build removed. 2022-12-21 14:43:28 [GENERATE] Generating source files from templates... 2022-12-21 14:43:29 [GENERATE] Source file generation complete.
-
Review usage of the generated build script in the
build
directory:build/build.sh help
Usage: build.sh COMMAND [OPTIONS] Build images, create or export volumes for mlipper/geosupport-docker v2.0.12. Commands: build Builds image version 2.0.12 of mlipper/geosupport-docker. Options: --variant=<name> (optional) Specifies that only variant "<name>" be built. If the --variant option has not been given, both are built. Builds are always done against the local repository. --variant=dist Builds image mlipper/geosupport-docker:2.0.12-dist --variant=default Builds image mlipper/geosupport-docker:2.0.12 When specifying only the "default" variant, the "dist" variant must be available from the local repository or the build will fail. --latest (optional) When given, tags built variants using the "latest" naming convention. If the "dist" has been built, creates tag mlipper/geosupport-docker:latest-dist. If the "default" has been built, creates tag mlipper/geosupport-docker:latest. createvol Creates a volume from the contents of the $GEOSUPPORT_BASEDIR directory in image mlipper/geosupport-docker:2.0.12 (i.e., the "default" variant). Options: --volname=<name> (optional) The "<name>" to use when creating the volume. If --volname is not given, the name is defaulted to "geosupport-23c_23.3". exportdist Copy repackaged Geosupport distribution file from image mlipper/geosupport-docker:2.0.12-dist to a host directory. Options: --exportdir=<name> (optional) The host directory where the repackaged Geosupport distribution file will be copied when running the "exportdist" command. If not given, defaults to "/Users/mlipper/Workspace/github.com/mlipper/geosupport-docker/out/2.0.12". help Show this usage message and exit.
If you are building this project on a platform other than amd64
(e.g., macOS/Apple M-series chip: arm64
), you may need to configure a new Docker build driver
and update the release.conf
file with it's name.
Here's an example using this project's default build driver name, "container":
docker buildx create --name=container --driver=docker-container --use --bootstrap
If you use a different name, be sure to update the release.conf
file property builddrv_name
.
See Docker container build driver for more details.
Geosupport is the City of New York's official geocoder of record. The Geosupport application (for Linux, Windows and z/OS) is written and maintained by the New York City Department of City Planning.