Inserts a superuser in the database. The start script will use two environment variables to set USERNAME
and PASSWORD
.
USERNAME=docker
PASSWORD=docker
The pre built image can be downloaded using docker directly. After that you do not need to use this command again, you will have the image on your machine.
$ docker pull jacksoncage/postgres
If you prefer you can easily build the docker image by yourself. After this the image is ready for use on your machine and can be used for multiple starts.
$ cd postgres-docker
$ docker build -t jacksoncage/postgres .
The container has all pre requisites set up to run a postgres server.
$ docker run -i -d -p 5432 -e USERNAME=docker -e PASSWORD=docker -v `pwd`/postgres:/var/lib/postgresql:rw jacksoncage/postgres
The command above starts the container in deamon mode (-d) and runs in the background. If you want to start it by yourself just to see what happens use this command:
$ docker run -i -d -p 5432 -e USERNAME=docker -e PASSWORD=docker -v `pwd`/postgres:/var/lib/postgresql:rw -v /etc/localtime:/etc/localtime jacksoncage/postgres bash
Notice the two changes made here, first we replaced the deamon switch (-d) with the tty switch (-t) which pipes the std in and std out to your terminal.
You now end up as a root user in the docker container and can do simple things like ls, cd and more. More complex things can be achieved after a apt-get install
of one or more software(s) of choice.
The first command inspects your created container and get the IPv4 address. Second command docker exported port for 5432.
$ docker inspect <container_id> | grep IPAddress | cut -d '"' -f 4
$ docker port <container_id> 5432 | cut -d ":" -f2
Now go to <your container's ip>:<container's port>
in your browser
Stopping a running container is possible via the docker api. If only one instance of this container is running this command will stop it:
$ docker stop `docker ps |grep jacksoncage/postgres |cut -d\ -f1`