Skip to content
This repository has been archived by the owner on Dec 4, 2021. It is now read-only.

Latest commit

 

History

History
120 lines (67 loc) · 3.83 KB

README.md

File metadata and controls

120 lines (67 loc) · 3.83 KB

docker-chicagoboss

Dockerized Chicago Boss web framework

What is it?

Docker container images that include Chicago Boss

What can I use it for?

Use it to build and deploy web apps using Dockerized Chicago Boss. Use it to develop an Erlang web app using Chicago Boss without worrying about any of the setup.

Developing with an already existent Chicago Boss web app

(Scaffolding for the following exists in sample_app. It's meant to serve as an example, but IS NOT FUNCTIONAL, because I didn't want to include the 23MB of Chicago Boss web app in my Dockerfile repo.)
  1. Make a directory on your local machine that looks like the sample_app directory in this repo

  2. Create a supervisord.conf file:

[supervisord]
nodaemon=true

[program:app]
command=/app/init-dev.sh
autostart=true
autorestart=true
priority=0
stderr_logfile=/var/log/supervisor_logs/app.err.log
stdout_logfile=/var/log/supervisor_logs/app.out.log

NOTE: This is probably not ideal, but I'm not sure how else to keep the instance alive throughout development.

  1. Create a Dockerfile that looks like the following:
FROM artburkart/docker-chicagoboss

# INSTALL APP
COPY ./app /app  # `make app PROJECT=app`

WORKDIR /app

EXPOSE 8001

# INSTALL SUPERVISOR
RUN apt-get update \
  && apt-get install -y supervisor \
  && mkdir /var/log/supervisor_logs
COPY ./supervisor.conf /etc/supervisor/conf.d/supervisor.conf

CMD ["/usr/bin/supervisord"]
  1. Move your existing project's code into the app directory

  2. Build the Dockerfile

docker build -t app-image .

  1. Run the container

docker run -v /path/to/your/app:/app -p 8001:8001 -d --name app app-image

  1. From here you can connect to the Docker container directly

docker exec -it app /bin/bash

  1. Or you can edit the files in your /path/to/your/app directory and see that your changes are reflected in the container

Developing an app from scratch

I assume we have a folder named after your project and it contains your Dockerfile and a folder named 'app' (your project's code)
  1. Follow steps 1-3 above

  2. Create an empty folder and name it app

  3. Build the Dockerfile

docker build -t app-image .

  1. Initialize your app inside a throwaway container (this creates the base web server on your local machine without requiring Erlang or Chicago Boss to be installed on it)

docker run -v $(pwd)/app:/app --entrypoint /bin/bash app-image -c 'cd /ChicagoBoss && make app PROJECT=app'

  1. Fire up a daemonized container named app with your web server running in it

docker run -v $(pwd)/app:/app -p 8001:8001 -d --name app app-image

  1. If you go to http://localhost:8001, you should see a message that says "No routes matched the requested URL."
  • Cash money!
  1. Now that your container is running, you can open your favorite text editor and edit any file in the app folder on your local machine
  • All changes will be reflected in your container immediately, so you can develop just like you normally would if the web server was running directly on your local machine
  1. If, for some reason, you need to gain access to the container's terminal, you can run the following:

docker exec -it app bash

  1. Unless you create a startup script to start your Docker container, you will need to turn it back on when you reboot your machine.

docker start app

If you're on OSX

  1. Since docker can't run natively in OSX, it runs inside a vagrant instance. I use Boot2Docker, but its setup is outside the scope of this README.

  2. If you have it running and all the above worked for you, then the last step is to run boot2docker ip