centos7下docker安装postgresql+postgis

时间:2024-03-01 17:28:55

环境:centos7/docker

最初直接拉取的postgresql数据,在导入.bakup文件时始终会报错,最后才想到该数据库默认不带postgis空间组件

###一、拉取镜像

这里我们拉取postgres和gis组合的镜像

目前组合的版本有如下几个

-11.0-2.5
-10.0-2.4
-9.6-2.4

这里以拉取postgresqlv11.0postgisv2.5的镜像为例

docker pull kartoza/postgis:11.0-2.5

###二、查看镜像


[root@dex~]#dockerimages
REPOSITORYTAGIMAGEIDCREATEDSIZE
kartoza/postgis9.6-2.4b24beb0be4ff11monthsago903MB


###三、运行容器

docker run -t --name postgresql1125 
--restartalways-ePOSTGRES_USER='postgres'
-e POSTGRES_PASSWORD=postgres -e ALLOW_IP_RANGE=0.0.0.0/0 
-p  5432:5432  -d  kartoza/postgis:11.0-2.5

#指定本地目录运行
docker run -d --name postgresql1125 --restart always  \
-e POSTGRES_USER=postgres   -e POSTGRES_PASS='postgres'  \
-e ALLOW_IP_RANGE=0.0.0.0/0   \
-v postgresql_data:/var/lib/postgresql/   \
-v postgresql_tmp:/tmp/tmp -p 5432:5432  \
-t kartoza/postgis:11.0-2.5

配置解释:
run,创建并运行一个容器;
–name,指定创建的容器的名字postgresql1125;
-e POSTGRES_PASSWORD=123456,设置环境变量,指定数据库的登录口令为postgres
-e POSTGRES_USER='postgres设置环境变量,指定数据库用户名为postgres
-p 54321:5432,端口映射将容器的5432端口映射到外部机器的54321端口;
-dkartoza/postgis:9.6-2.4,允许该容器以守护态(Daemonized)形式运行于后台
-e ALLOW_IP_RANGE=0.0.0.0/0,这个表示允许所有ip访问,如果不加,则非本机ip访问不了
-t 让docker分配一个伪终端(pseudo-tty)并绑定到该容器的标准输入上(这是为了在交互模式下用户可以通过所创建的终端来输入命令)

###四、查看进程


[root@dex~]#docker ps
CONTAINERIDIMAGECOMMANDCREATEDSTATUSPORTSNAMES
f82e7d3a9755kartoza/postgis:9.6-2.4"/bin/sh-c/docker-…"5secondsagoUp4seconds0.0.0.0:5432->5432/tcppostgresql


到此postgresql数据库安装成功,可以同ip:5432进行连接了。