PostgreSQL是一款功能丰富的关系型数据库,类似于MySQL,它也是受欢迎程度非常高的。

今天就来简单分享一下使用Docker安装部署PostgreSQL的过程。

1,拉取镜像

拉取PostgreSQL的最新镜像即可:

docker pull postgres

默认的镜像版本(latest)是基于Debian镜像的,如果你希望拉取体积更小的PostgreSQL镜像可以拉取基于Alpine的:

docker pull postgres:alpine

2,创建数据卷

我们最好是创建一个数据库以持久化PostgreSQL的数据:

docker volume create postgre-data

3,创建并运行容器

执行下列命令:

docker run -id --name=postgresql -v postgre-data:/var/lib/postgresql/data -p 5432:5432 -e POSTGRES_PASSWORD=123456 -e LANG=C.UTF-8 postgres

上述设定了数据卷,以及暴露了端口5432,这是PostgreSQL的默认端口。

除此之外,我们还设定了下列环境变量:

  • POSTGRES_PASSWORD 设定PostgreSQL的超级用户的密码,这里设定为123456,PostgreSQL容器的超级用户用户名postgres

  • LANG 设定语言环境为C.UTF-8以支持中文

除此之外,还可以设定环境变量POSTGRES_USER指定超级用户的用户名,上述没有指定这个环境变量则默认是postgres

4,postgresql可视化工具pgadmin4

  • 拉取postgresql可视化工具pgadmin4:

docker pull dpage/pgadmin4
  • 运行pgadmin4:

docker run -d -p 5433:80 --name pgadmin4 -e PGADMIN_DEFAULT_EMAIL=test@123.com -e PGADMIN_DEFAULT_PASSWORD=123456 dpage/pgadmin4
  • 输入我们设置的邮箱test@123.com和密码123456,点击Login

  • 连接server:

默认username是postgres,password是上面设置的pg123456
注意,因为pgadmin运行在docker里,所以host不能写localhost。host.docker.internal代表宿主机器,或者用宿主机IP。

连接成功,完成!