theme: scrolls-light
这是我参与11月更文挑战的第6天,活动详情查看:2021最后一次更文挑战
借助于容器技术,我们能够方便的创建运行测试环境,今天这篇文章手把手教你们使用Docker Compose快速启动Postgres。
一、创建Docker Compose文件
首先创建一个文件夹来存储我们的文件:
shell mkdir ~/postgres-demo && cd ~/postgres-demo
然后创建一个 docker-compose. yml 文件: shell touch docker-compose.yml
在文件中添加以下内容: ``` version: '3'
services: postgres: image: postgres:13.1 healthcheck: test: [ "CMD", "pgisready", "-q", "-d", "postgres", "-U", "root" ] timeout: 45s interval: 10s retries: 10 restart: always environment: - POSTGRESUSER=root - POSTGRESPASSWORD=password - APPDBUSER=docker - APPDBPASS=docker - APPDB_NAME=docker volumes: - ./db:/docker-entrypoint-initdb.d/ ports: - 5432:5432 `` -
image,指定使用何种 Docker 映像,包括版本号 -
healthcheck,用于确保 Postgres 正在运行,然后依赖于它的其他服务才能运行 -
restart`,重新启动总是确保 DB 在系统启动时启动
下面的环境变量用于分配 Postgres 主数据库的用户名和密码:
-
POSTGRES_USER
用户 -
POSTGRES_PASSWORD
密码
init
脚本使用以下环境变量创建数据库用户和数据库供应用程序使用:
-
APP_DB_USER
应用程序数据库 -
APP_DB_PASS
应用程序数据库通过 -
APP_DB_NAME
应用程序数据库名
对于volume
选项,我们将在/docker-entrypoint-initdb.d/
中将名为db的本地文件夹映射到容器中的文件夹,这是我们将在下一步中放置数据库init脚本的地方。
我们还通过将Postgres
端口分配给端口选项,将端口暴露于我们的服务器,这将允许我们从本地机器连接到数据库。
二、创建数据库init脚本
创建一个名为 db
的文件夹来存储 init
脚本。 shell mkdir db
创建一个名为01-init.sh
的脚本。 shell touch db/01-init.sh
添加以下内容: ```postgres
!/bin/bash
set -e export PGPASSWORD=$POSTGRESPASSWORD; psql -v ONERRORSTOP=1 --username "$POSTGRESUSER" --dbname "$POSTGRESDB" <<-EOSQL CREATE USER $APPDBUSER WITH PASSWORD '$APPDBPASS'; CREATE DATABASE $APPDBNAME; GRANT ALL PRIVILEGES ON DATABASE $APPDBNAME TO $APPDBUSER; \connect $APPDBNAME $APPDBUSER BEGIN; CREATE TABLE IF NOT EXISTS event ( id CHAR(26) NOT NULL CHECK (CHARLENGTH(id) = 26) PRIMARY KEY, aggregateid CHAR(26) NOT NULL CHECK (CHARLENGTH(aggregateid) = 26), eventdata JSON NOT NULL, version INT, UNIQUE(aggregateid, version) ); CREATE INDEX idxeventaggregateid ON event (aggregateid); COMMIT; EOSQL `` 这个脚本将: - 创建一个新用户,其名称分配给
appdbuser,密码分配给
appdbpass - 用分配给
APPdb_name的任何名称创建一个数据库 - 为数据库上的用户授予所有权限 - 连接到数据库并创建一个名为
event` 的表
三、docker-compose up
运行docker compose
以启动 Postgres
数据库并运行数据库 init
脚本。 docker-compose up