Differences between revisions 6 and 15 (spanning 9 versions)
Revision 6 as of 2015-04-16 02:07:21
Size: 1190
Editor: terri
Comment:
Revision 15 as of 2015-04-16 16:37:55
Size: 2112
Editor: terri
Comment: putting some titles in to make the page more formatted.
Deletions are marked like this. Additions are marked like this.
Line 1: Line 1:
This page is a scratchpad for Terri's Dockerfile. It probably does not work at this time. This page is a scratchpad for Terri's Dockerfile, which sets up a very default version of Mailman in your container so that you can try out Mailman 3 suite. Suggestions and instructions for use welcome!
Line 3: Line 3:

== The Mailman 3 Suite Dockerfile ==
Line 13: Line 15:
MAINTAINER Terri MAINTAINER Terri Oda
Line 37: Line 39:
RUN source venv/bin/activate RUN . venv/bin/activate
Line 46: Line 48:
RUN ./bin/mailman-web-django-admin runserver &
# This sets the django webserver up to not only run, but binds it to all interfaces, port 8000
ENTRYPOINT ./bin/mailman-web-django-admin runserver 0.0.0.0:8000
Line 48: Line 52:

== Building the docker image ==

Copy the content above into a file named `Dockerfile` in a directory, and then run the following command:

{{{
  
    sudo docker build -t mailman .
}}}

This will take some time to build a docker image with the required steps.

== Starting the container and mailman3 suite ==

{{{
    sudo docker run mailman
}}}

Then find out the container id by following command

{{{
    sudo docker ps
}}}

This will start the mailman docker container. You can find out the ip from *$ sudo docker inspect hash_of_docker"
For example I can open "http://172.17.0.15:8000/" in my browser to view Mailman3.

This page is a scratchpad for Terri's Dockerfile, which sets up a very default version of Mailman in your container so that you can try out Mailman 3 suite. Suggestions and instructions for use welcome!

The Mailman 3 Suite Dockerfile

#########################################
# Dockerfile to setup GNU Mailman Suite
# Based on Ubuntu
#########################################
# Set the base image to Ubuntu
FROM ubuntu

# File Author / Maintainer
MAINTAINER Terri Oda

# Update the sources and install some basic python stuff
RUN apt-get update
RUN apt-get install -y bzr python3-dev python3-pip python-dev python-pip python-virtualenv

# Get the nodejs stuff
RUN apt-get install -y nodejs npm
RUN npm install -g less
RUN ln -s /usr/bin/nodejs /usr/bin/node

# Set the default directory where CMD will execute
WORKDIR /mailman3

# Get Mailman Bundler
RUN bzr branch lp:mailman-bundler

# Get buildout, go into Mailman Bundler and build
RUN pip install zc.buildout
WORKDIR /mailman3/mailman-bundler
RUN buildout

# Set up virtualenv
RUN virtualenv venv
RUN . venv/bin/activate

# Expose ports
EXPOSE 8000

# Prep some stuff
RUN ./bin/mailman-post-update
RUN ./bin/mailman-web-django-admin createsuperuser
RUN ./bin/mailman start

# This sets the django webserver up to not only run, but binds it to all interfaces, port 8000
ENTRYPOINT ./bin/mailman-web-django-admin runserver 0.0.0.0:8000 

Building the docker image

Copy the content above into a file named Dockerfile in a directory, and then run the following command:

    sudo docker build -t mailman .

This will take some time to build a docker image with the required steps.

Starting the container and mailman3 suite

    sudo docker run mailman

Then find out the container id by following command

    sudo docker ps

This will start the mailman docker container. You can find out the ip from *$ sudo docker inspect hash_of_docker" For example I can open "http://172.17.0.15:8000/" in my browser to view Mailman3.

MailmanWiki: DEV/Mailman 3.0/Mailman 3.0 Suite Dockerfile (last edited 2016-03-03 12:30:41 by SimonHanna)