docker安装带postgis插件的postgresql 数据库
最初直接拉取的postgresql 数据,在导入 .bakup 文件时始终会报错,最后才想到该数据库默认不带postgis空间组件一、拉取镜像这里我们拉取postgres 和 gis 组合的镜像目前组合的版本有如下几个11.0-2.510.0-2.49.6-2.4这里以 拉取postgresql v9.6 和 postgis v2.4 的镜像为例[root@dex ~]...
最初直接拉取的postgresql 数据,在导入 .bakup 文件时始终会报错,最后才想到该数据库默认不带postgis空间组件
一、拉取镜像
这里我们拉取postgres 和 gis 组合的镜像
目前组合的版本有如下几个
- 11.0-2.5
- 10.0-2.4
- 9.6-2.4
这里以 拉取postgresql v9.6
和 postgis v2.4
的镜像为例
[root@dex ~]# docker pull kartoza/postgis:9.6-2.4
9.6-2.4: Pulling from kartoza/postgis
b422a2cc2545: Pull complete
4aedc9612296: Pull complete
5ce108fcb930: Pull complete
ad73e560a54c: Pull complete
7a58b5f1b933: Pull complete
22b853e0b963: Pull complete
8af838ddf928: Pull complete
be73fabecb29: Pull complete
07a8f9ac9d5a: Pull complete
da15d9ba8084: Pull complete
f53374d86666: Pull complete
54ba75d37f6a: Pull complete
53456450b0c9: Pull complete
270089492e61: Pull complete
Digest: sha256:da963520e7a55a4c61005d3536efb7dd068a2dce169ff76b3fb9f13ef2f8c7e8
Status: Downloaded newer image for kartoza/postgis:9.6-2.4
docker.io/kartoza/postgis:9.6-2.4
【注意】也许会出现如下异常
Error response from daemon: error parsing HTTP 408 response body: invalid character '<' looking for beginning of value: "<html><body><h1>408 Request Time-out</h1>\nYour browser didn't send a complete request in time.\n</body></html>\n"
到时我也纠结很久,找了很多资料,修改无数次,人不见好转,
最后直接使用 ifconfig eno1 mtu 900
竟然解决了,如下
ifconfig eno1 mtu 900
eno1 为ip 网卡名称
可以通过 ipconfig进行查看,也可以到对应的 /etc/sysconfig/network-scripts 去查找,我使用的是eno1
[root@localhost ~]# ll /etc/sysconfig/network-scripts/
total 8
-rw-r--r--. 1 root root 486 Apr 24 13:25 ifcfg-eno1
-rw-r--r--. 1 root root 277 Apr 12 11:12 ifcfg-eno2
想要永久可用,重启系统不变化,需要在ip配置中新增MTU=900, 如 直接vim 进行编译
修改后执行:wq
保存
再重启网卡
systemctl restart network
注意不同系统命令有所不同
centos6命令:service network restart
centos7命令:systemctl restart network
centos8命令:nmcli c reload ens33
二、 查看镜像
[root@dex ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
kartoza/postgis 9.6-2.4 b24beb0be4ff 11 months ago 903MB
三、运行容器
[root@dex ~]# docker run -t --name postgresql --restart always -e POSTGRES_USER='postgres' -e POSTGRES_PASSWORD=123456 -e ALLOW_IP_RANGE=0.0.0.0/0 -p 54321:5432 -v /opt/postgres_data/data:/var/lib/postgresql/data -d kartoza/postgis:9.6-2.4
配置解释:
run,创建并运行一个容器;
–name,指定创建的容器的名字postgresql ;
–restart 当docker启动时自动重启
-e POSTGRES_PASSWORD=123456,设置环境变量,指定数据库的登录口令为123456
-e POSTGRES_USER='postgres 设置环境变量,指定数据库用户名为postgres
-p 54321:5432,端口映射将容器的5432端口映射到外部机器的54321端口;
-d kartoza/postgis:9.6-2.4,允许该容器以守护态(Daemonized)形式运行于后台
-e ALLOW_IP_RANGE=0.0.0.0/0,这个表示允许所有ip访问,如果不加,则非本机 ip 访问不了
-t 让docker分配一个伪终端(pseudo-tty)并绑定到该容器的标准输入上(这是为了在 交互模式下用户可以通过所创建的终端来输入命令)
-v /opt/postgres_data/data:/var/lib/postgresql/data 标识将容器目录/var/lib/postgresql/data中数据挂载到系统目录opt下面
【注意】异常ls: cannot access '/docker-entrypoint-initdb.d/': Operation not permitted
需要增加一个参数--privileged=true
最后执行是这样的了
拉取镜像
docker pull nickblah/postgis
运行容器
docker run -t --name postgresql --restart always -e POSTGRES_USER='postgres' -e POSTGRES_PASSWORD=123456 -e ALLOW_IP_RANGE=0.0.0.0/0 --privileged=true -p 54321:5432 -d nickblah/postgis
这里使用的是nickblah/postgis
镜像这个是用来兼容华为ARM64 鲲鹏系统,否则启动容器一直会处于 Restaring
中
如
【注意】这里安装nickblah/potgis 我未指定tag, 默认安装了一个最新版本,这个在使用Navicat会提示错误
那我们就只好拉一个低版本的镜像了
直接去Docker hub 上面找吧 https://hub.docker.com/r/library/
最后重新下载镜像nickblah/postgis
tag为12-postgis-3
版本的
拉取镜像
docker pull nickblah/postgis:12-postgis-3
运行容器
docker run -t --name postgresql --restart always -e POSTGRES_USER='postgres' -e POSTGRES_PASSWORD=123456 -e ALLOW_IP_RANGE=0.0.0.0/0 --privileged=true -p 54321:5432 -d nickblah/postgis:12-postgis-3
四、查看进程
[root@dex ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
f82e7d3a9755 kartoza/postgis:9.6-2.4 "/bin/sh -c /docker-…" 5 seconds ago Up 4 seconds 0.0.0.0:5432->5432/tcp postgresql
到此 postgresql数据库安装成功,可以使用navicat 通过 ip+54321进行连接测试了。
更多推荐
所有评论(0)