31 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			31 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # Using multiple databases with official PostgreSQL Docker image
 | |
| 
 | |
| The [official recommendation](https://hub.docker.com/_/postgres/) for creating
 | |
| multiple databases is as follows:
 | |
| 
 | |
| *If you would like to do additional initialization in an image derived from
 | |
| this one, add one or more `*.sql`, `*.sql.gz`, or `*.sh` scripts under
 | |
| `/docker-entrypoint-initdb.d` (creating the directory if necessary). After the
 | |
| entrypoint calls `initdb` to create the default `postgres` user and database,
 | |
| it will run any `*.sql` files and source any `*.sh` scripts found in that
 | |
| directory to do further initialization before starting the service.*
 | |
| 
 | |
| This directory contains a script to create multiple databases using that
 | |
| mechanism.
 | |
| 
 | |
| ## Usage
 | |
| 
 | |
| Clone the repository, mount its directory as a volume into
 | |
| `/docker-entrypoint-initdb.d` and declare database names separated by commas in
 | |
| `POSTGRES_MULTIPLE_DATABASES` environment variable as follows
 | |
| (`docker-compose` syntax):
 | |
| 
 | |
|     myapp-postgresql:
 | |
|         image: postgres:9.6.2
 | |
|         volumes:
 | |
|             - ../docker-posgresql-multiple-databases:/docker-entrypoint-initdb.d
 | |
|         environment:
 | |
|             - POSTGRES_MULTIPLE_DATABASES=db1,db2
 | |
|             - POSTGRES_USER=myapp
 | |
|             - POSTGRES_PASSWORD=
 |