Configure a running Bugzilla system using Docker
- Running latest Centos
- Preconfigured with initial data and test product
- Running Apache2 and MySQL Community Server 5.6
- Openssh server so you can ssh in to the system to make changes
- Code resides in
/home/bugzilla/devel/htdocs/bugzilla
and can be updated, diffed, and branched using standard git commands
-
Visit Docker and get docker up and running on your system.
-
Visit Fig to install Fig for managing Docker containers.
-
Visit Docker and get docker up and running on your system.
-
Visit Fig to install Fig for managing multiple related Docker containers.
-
Start boot2docker in a terminal once it is installed. Ensure that you run the export DOCKER_HOST=... lines when prompted:
$ boot2docker start
$ export DOCKER_HOST=tcp://192.168.59.103:2375
- Install the Windows boot2docker installer
- Run the "Boot2Docker Start" shortcut on the startmenu (this inits the VM, starts it and connects to it)
- Run the following in the boot2docker VM as a one-off:
echo 'alias fig='"'"'docker run --rm -it \
-v $(pwd):/app \
-v /var/run/docker.sock:/var/run/docker.sock \
-e FIG_PROJECT_NAME=$(basename $(pwd)) \
dduportal/fig'"'" >> /home/docker/.ashrc
- Logout from the VM (ctrl+D)
Then all you need to do on later occasions is:
- Re-run "Boot2Docker Start" or from the console just enter:
boot2docker start && boot2docker ssh
- cd
/c/Users/Username/src/bugzilla/contrib/docker
(paths under c:\Users are automatically mapped by boot2docker from the client into the VM) fig build
(and so on)`
Due to an issue with installation of certain packages in Centos7 and the
default storage driver (AUFS) used by boot2docker, we need to change the
driver to devicemapper
for the image build process to complete properly.
To do so, once you have boot2docker installed and the VM running, but before performing the build process, do:
$ boot2docker ssh
Boot2Docker version 1.4.1, build master : 86f7ec8 - Tue Dec 16 23:11:29 UTC 2014
Docker version 1.4.1, build 5bc2ff8
docker@boot2docker:~$ echo 'EXTRA_ARGS="--storage-driver=devicemapper"' | sudo tee -a /var/lib/boot2docker/profile
docker@boot2docker:~$ sudo /etc/init.d/docker restart
Also before building, you will need to change value in the
checksetup_answers.txt
file to match the IP address of the boot2docker VM.
You can find the IP address by running boot2docker ip
.
For example, using a text editor, change the following line in
checksetup_answers.txt
from:
$answer{'urlbase'} = 'http://localhost:8080/bugzilla/';
to
$answer{'urlbase'} = 'http://192.168.59.103:8080/bugzilla/';
To build a fresh image, just change to the directory containing the checked out files and run the below command:
$ fig build
To start a new container (or rerun your last container) you simply do:
$ fig up
This will stay in the foreground and you will see the output from supervisord
. You
can use the -d
option to run the container in the background.
To stop, start or remove the container that was created from the last run, you can do:
$ fig stop
$ fig start
$ fig rm
If you are using Linux, you can simply point your browser to
http://localhost:8080/bugzilla
to see the the Bugzilla home page.
If using boot2docker, you will need to use the IP address of the VM. You can
find the IP address using the boot2docker ip
command. For example:
$ boot2docker ip
192.168.59.103
So would then point your browser to http://192.168.59.103:8080/bugzilla
.
The Administrator username is admin@bugzilla.org
and the password is password
.
You can use the Administrator account to creat other users, add products or
components, etc.
You can also ssh into the container using ssh bugzilla@localhost -p2222
command.
The password is bugzilla
. You can run multiple containers but you will need
to give each one a different name/hostname as well as non-conflicting ports
numbers for ssh and httpd.
- Enable SSL support.
- Enable memcached