Docker Swarm 编排及部署 PostGIS,并操作 GIS 数据

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
简介: 本文还是继docker之后的一片更新,只是这次使用 Docker stack 进行容器部署及编排。

本文还是继docker之后的一片更新,只是这次使用 Docker stack 进行容器部署及编排。部分图片来自 Docker 官网。

postgis 镜像的基础是 PostgreSql,所以我们部署了 postgis 镜像也就意味着有了 PostgreSql 数据库,在Docker Hub上已经有人为我们构建好了,我们拉取配置即可使用。

Swarm 是 Docker 官方提供的一款集群管理工具,其主要作用是把若干台Docker主机抽象为一个整体,并且通过一个入口统一管理这些Docker 主机上的各种 Docker 资源。相较与 k8s(Kubernetes), Swarm 的功能也更少一些。但是 Docker 公司已经同时支持了 Swarm 和k8s。 Swarm 的基本架构如下图所示,

docker_swarm_architecture

Docker stack 是一组有关服务的管理组合,是 Docker 关系层级中最高的一级,其作用主要是编排及管理服务(Service)。

目录及文件创建

创建目录

创建的目录用来做容器的数据存储,因为容器秉承的是用完即毁的理念,所以我们应该将我们的数据放在容器之外,生产环境之中,方便下次使用。

$ mkdir pgadmin_data && mkdir postgres_data # pgadmin_data 存储pgadmin的登录即数据库链接信息, postgres_data 存储数据库生产数据
$ tree
.
├── deploy
├── docker-compose.yml
├── pgadmin_data
└── postgres_data

编写 docker-compose.yml 文件

此次部署我们用到容器的编排,所以会有 deploy 里面的各种信息,若有不理解的,还请移步 Docker Compose

version: '3'

services:
  postgis:
    image: kartoza/postgis:9.6-2.4
    ports:
      - "5432:5432"
    environment:
      POSTGRES_USER: sde
      POSTGRES_PASS: sde
      POSTGRES_DBNAME: gis
      ALLOW_IP_RANGE: 0.0.0.0/0
    volumes:
      - ./postgres_data:/var/lib/postgresql
    deploy:
      mode: replicated
      replicas: 1
      restart_policy:
        condition: on-failure
        delay: 5s
        max_attempts: 3
      update_config:
        parallelism: 1
        delay: 10s
      placement:
        constraints:
          - node.role == manager

  pgadmin:
    image: chorss/docker-pgadmin4
    ports:
      - "8888:5050"
    environment:
      PGADMIN_SETUP_EMAIL: guzhongren@live.cn
      PGADMIN_SETUP_PASSWORD: 000000
    volumes:
      - ./pgadmin_data:/data
    deploy:
      mode: replicated
      replicas: 1
      restart_policy:
        condition: on-failure
        delay: 5s
        max_attempts: 3
      update_config:
        parallelism: 1
        delay: 10s
      placement:
        constraints:
          - node.role == manager

swarm 初始化及镜像部署

docker swarm 初始化

$ docker swarm init
Swarm initialized: current node (bvz81updecsj6wjz393c09vti) is now a manager.

To add a worker to this swarm, run the following command:

    docker swarm join \
    --token SWMTKN-1-3pu6hszjas19xyp7ghgosyx9k8atbfcr8p2is99znpy26u2lkl-1awxwuwd3z9j1z3puu7rcgdbx \
    172.17.0.2:2377

To add a manager to this swarm, run 'docker swarm join-token manager' and follow the instructions.

获取及部署镜像

编写启动脚本

$ vim deploy
# 加入如下命令
docker stack deploy --compose-file=docker-compose.yml postgre
# Esc --> wq
$ sudo chmod +x deploy

部署

$ ./deploy
Creating network postgre_default
Creating service postgre_postgis
Creating service postgre_pgadmin

链接 pgAdmin 即 Postgis数据库

访问我的阿里云网址+8888端口即可链接pgAdmin

pgadmin

连接数据库

序号 名称 备注
1 主机名 47.95.247.* ip
2 端口 5432
3 数据库 gis
4 用户名 sde
5 密码 sde

connect_database

连接效果

database_pg

在 QGIS 中连接 PostGIS 容器

序号 名称 备注
1 主机名 47.95.247.* ip
2 端口 5432
3 数据库 gis
4 用户名 sde
5 密码 sde

qgis

QGIS 连接效果

qgis_connect

用 QGIS 导入 shape 数据

打开QGIS, 将要添加的数据加载到QGIS中,并打开DBManager 插件,点击下图中所示的导入图层按钮。

将 shapefile 数据导入 postgis 中

dbmanager

导入完成

finish_import

在 QGIS 中浏览数据

view_data

在 QGIS 中编辑数据

edit_data

回到 Docker Swarm

使用 Docker swarm 我们可以更好的管理及扩展我们的Service,如扩容等,还可以对已经部署的容器进行无宕机式的“热更新”;docker stack 自带负载均衡,我们无需担心单个节点容器之间的访问是否会超载等,还有 docker stack 会保证service的数量一直和配置文件中的一直,保证其可用性。

总结

此次部署使用 Docker Swarm 来做集群管理,因为是部署在阿里云上,资源有限,不能进行多节点(Node)的创建及管理,只能用一个 Manager 节点来操作;但是不影响优化之前通过 Docker 简单命令创建及管理容器的操作。利用 Docker Stack 的优势,我们可以更好的管理 Service, 如扩容、更新、创建及销毁。k8s(Kubernetes) 有 Docker stack 的各种能力,但其能力远超 Docker Stack, 其使用也非常简单, 现在 Docker 公司已经开始兼容 k8s。

玩 Docker 还是需要多台机器,起码是虚拟机才好玩,一台阿里云ECS真不够,连 GitLab 都装不了。不哭了,真穷。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
3天前
|
Java 应用服务中间件 Linux
【Docker容器化技术】docker安装与部署、常用命令、容器数据卷、应用部署实战、Dockerfile、服务编排docker-compose、私有仓库
本文主要讲解了Docker的安装与部署、常用命令、容器数据卷、应用部署实战、Dockerfile、服务编排docker-compose、私有仓库以及Docker容器虚拟化与传统虚拟机比较。
【Docker容器化技术】docker安装与部署、常用命令、容器数据卷、应用部署实战、Dockerfile、服务编排docker-compose、私有仓库
|
8天前
|
SQL 关系型数据库 数据库
国产数据实战之docker部署MyWebSQL数据库管理工具
【10月更文挑战第23天】国产数据实战之docker部署MyWebSQL数据库管理工具
43 4
国产数据实战之docker部署MyWebSQL数据库管理工具
|
3天前
|
应用服务中间件 PHP nginx
Docker-compose 编排lnmp(dockerfile) 完成Wordpress
通过使用Docker Compose,我们可以轻松编排LNMP环境并部署WordPress。本文详细介绍了各组件的Dockerfile和配置文件编写,并通过docker-compose.yml文件实现了整个环境的自动化部署。这种方法不仅简化了部署过程,还提高了环境的可移植性和一致性。希望本文能帮助你更好地理解和使用Docker Compose来管理和部署复杂的应用程序。
13 3
|
12天前
|
负载均衡 应用服务中间件 网络安全
docker swarm添加更多的服务
【10月更文挑战第16天】
15 6
|
12天前
|
Docker 容器
docker swarm启动服务并连接到网络
【10月更文挑战第16天】
19 5
|
11天前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
33 2
|
12天前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
24 3
|
10天前
|
负载均衡 安全 调度
深入调查研究Docker Swarm
【10月更文挑战第19天】
22 0
|
关系型数据库 MySQL Linux
docker 常用操作命令
docker 镜像的增、查、删、改; docker 容器的增、查、删、改;
docker 常用操作命令
|
应用服务中间件 网络安全 Docker
【Docker】(三)Docker常用操作命令
【Docker】(三)Docker常用操作命令
152 0
【Docker】(三)Docker常用操作命令