This repository contains scripts and configuration for building version 2 of the OneBusAway Application Suite for use with Docker.
To build bundles and run the webapp server with your own GTFS feed, use the Docker Compose services in this repository.
To build a bundle, use the oba_bundler
service:
GTFS_URL=https://www.soundtransit.org/GTFS-rail/40_gtfs.zip docker-compose up oba_bundler
This process will create all necessary bundle files and metadata, and all will be accessible in your local repo's ./bundle
directory.
When the GTFS_URL is unspecified, oba_bundler
will download and use the GTFS data for Davis, CA's Unitrans service. This can be used with the bin/validate.sh
script to verify that the stack is working correctly.
docker-compose up oba_bundler
Once you have a built OBA bundle inside ./bundle
, you can run the OBA server and make it accessible on your host machine with:
docker-compose up oba_app
You will then have three webapps available:
- API, hosted at
http://localhost:8080/onebusaway-api-webapp/api?key=TEST
- an example call could be to
http://localhost:8080/onebusaway-api-webapp/api/where/agencies-with-coverage.json?key=TEST
, which should show metadata about the agency you loaded - the test/demo API key is automatically handled in
oba/bootstrap.sh
, you can change it by setting theTEST_API_KEY
build args in theoba_app
service indocker-compose.yml
- an example call could be to
When done using this web server, you can use the shell-standard ^C
to exit out and turn it off. If issues persist across runs, you can try using docker-compose down -v
and then docker-compose up oba_app
to refresh the Docker containers and services.
The MySQL database Docker Compose service should remain up after a call of docker-compose up oba_app
. Otherwise, you can always invoke it using docker-compose up oba_database
.
A database port is open to your host machine, so you can connect to it programmatically using mysql
:
mysql -u oba_user -p -h localhost:3306
You can find the latest published Docker images on Docker Hub:
- onebusaway-bundle-builder - This image is built from the
bundler
directory and contains the functionality needed to create a transit data bundle from a GTFS feed. - onebusaway-api-webapp - This image is built from the
oba
directory and contains the functionality needed to run the OBA API webapp.
- Database
JDBC_URL
- The JDBC connection URL for your MySQL database.JDBC_USER
- The username for your MySQL database.JDBC_PASSWORD
- The password for your MySQL database.
- GTFS-RT Support (Optional)
ALERTS_URL
- Service Alerts URL for GTFS-RT.TRIP_UPDATES_URL
- Trip Updates URL for GTFS-RT.VEHICLE_POSITIONS_URL
- Vehicle Positions URL for GTFS-RT.REFRESH_INTERVAL
- Refresh interval in seconds. Usually 10-30.AGENCY_ID
- Your GTFS-RT agency ID. Ostensibly the same as your GTFS agency ID.- Authentication (Optional)
- Example: Specifying
FEED_API_KEY
=X-API-KEY
andFEED_API_VALUE
=12345
will result inX-API-KEY: 12345
being passed on every call to your GTFS-RT URLs. FEED_API_KEY
- If your GTFS-RT API requires you to pass an authentication header, you can represent the key portion of it by specifying this value.FEED_API_VALUE
- If your GTFS-RT API requires you to pass an authentication header, you can represent the value portion of it by specifying this value.
- Example: Specifying
You will also need to create a transit data bundle from a GTFS Zip file. This needs more documentation, but this README does a decent job of outlining the process. The only tricky part is that you need to get it into your running container. Currently, we recommend building it locally, uploading the contents of the ./bundle
directory to S3 or another publicly accessible website, and then downloading it into your container. Obviously, this needs some improvement.
Render is an easy-to-use Platform-as-a-Service (PaaS) provider. You can host OneBusAway on Render by either manually configuring it or by clicking the button below.
- Build the bundler image:
docker build ./bundler -t oba/bundler:test
- Build the app image:
docker build ./oba -t oba/app:test
Apply the Kubernetes resources in oba.yaml
kubectl apply -f oba.yaml
The YAML file deploys the OneBusAway application and a MySQL database within a dedicated oba namespace in Kubernetes. It also sets up a secret for sensitive data and a ConfigMap for GTFS data URL, while exposing the database as a service for other pods to access.
You can portforward the oba app to your localhost using:
kubectl port-forward deploy/oba-app-deployment -n oba 8080:8080
You can portforward the service to your localhost using:
kubectl port-forward service/oba-database -n oba 3306:3306
Then you can connect to it programmatically using mysql
:
mysql -u oba_user -p -h localhost:3306