Base docker image to run a PostgreSQL database server in azk
- debian:wheezy
- PostgreSQL
Example of using this image with azk:
/**
* Documentation: http://docs.azk.io/Azkfile.js
*/
// Adds the systems that shape your system
systems({
postgres: {
// Dependent systems
depends: [], // postgres, postgres, mongodb ...
// More images: http://images.azk.io
image: {"docker": "azukiapp/postgres"},
shell: "/bin/bash",
wait: {"retry": 25, "timeout": 1000},
mounts: {
'/var/lib/postgresql/data': persistent("postgresql-#{system.name}"),
'/var/log/postgresql': path("./log/postgresql"),
},
ports: {
// exports global variables
data: "5432/tcp",
},
envs: {
// set instances variables
POSTGRES_USER: "azk",
POSTGRES_PASS: "azk",
POSTGRES_DB : "#{manifest.dir}",
},
export_envs: {
// check this gist to configure your database
// https://gist.github.com/gullitmiranda/62082f2e47c364ef9617
DATABASE_URL: "postgres://#{envs.POSTGRES_USER}:#{envs.POSTGRES_PASS}@#{net.host}:#{net.port.data}/${envs.POSTGRES_DB}",
},
},
});To create the image azukiapp/postgres, execute the following command on the docker-postgres folder:
$ docker build -t azukiapp/postgres ./9.4To run the image and bind to port 5432:
$ docker run -d -p 5432:5432 azukiapp/postgresObs: Very slow process
$ make test
# with azk
$ azk logs postgres
# with docker
$ docker logs <CONTAINER_ID>POSTGRES_USER or POSTGRESQL_USER: Set a specific username for the admin account. (default 'azk')
POSTGRES_PASS or POSTGRESQL_PASS: Set a specific password for the admin account. (default 'azk')
POSTGRES_DB or POSTGRESQL_DB : Set a specific database name
Azuki Dockerfiles distributed under the Apache License.