热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

neonserverlesspostgres简单试用

内容来自官方的docker-compose内容,主要是测试试用参考架构  从以上图可以看出,neon应该包含了几个组件,safekeeper,pageserver,计算节点,以及对

内容来自官方的docker-compose 内容,主要是测试试用


参考架构

 

 

从以上图可以看出,neon 应该包含了几个组件,safekeeper,pageserver,计算节点,以及对象存储,运行的服务也是参考此部署的,safekeeper 需要至少3个节点

实现了选举机制,内部试用了


部署docker-compose



  • docker-compose 文件

 

version: '3'

# minio s3 服务

services:

minio:

image: minio/minio:RELEASE.2022-10-20T00-55-09Z

ports:

- 9000:9000

- 9001:9001

environment:

- MINIO_ROOT_USER=minio

- MINIO_ROOT_PASSWORD=password

command: server /data --address :9000 --console-address ":9001"

# 初始化桶创建

minio_create_buckets:

image: minio/mc

environment:

- MINIO_ROOT_USER=minio

- MINIO_ROOT_PASSWORD=password

entrypoint:

- "/bin/sh"

- "-c"

command:

- "until (/usr/bin/mc alias set minio http://minio:9000 $$MINIO_ROOT_USER $$MINIO_ROOT_PASSWORD) do

echo 'Waiting to start minio...' && sleep 1;

done;

/usr/bin/mc mb minio/neon --region=eu-north-1;

exit 0;"

depends_on:

- minio

# pageserver

pageserver:

image: ${REPOSITORY:-neondatabase}/neon:${TAG:-latest}

environment:

- BROKER_ENDPOINT='http://storage_broker:50051'

- AWS_ACCESS_KEY_ID=minio

- AWS_SECRET_ACCESS_KEY=password

#- RUST_BACKTRACE=1

ports:

#- 6400:6400 # pg protocol handler

- 9898:9898 # http endpoints

entrypoint:

- "/bin/sh"

- "-c"

command:

- "/usr/local/bin/pageserver -D /data/.neon/

-c \"broker_endpoint=$$BROKER_ENDPOINT\"

-c \"listen_pg_addr='0.0.0.0:6400'\"

-c \"listen_http_addr='0.0.0.0:9898'\"

-c \"remote_storage={endpoint='http://minio:9000',

bucket_name='neon',

bucket_region='eu-north-1',

prefix_in_bucket='/pageserver/'}\""

depends_on:

- storage_broker

- minio_create_buckets

# safekeeper 服务

safekeeper1:

image: ${REPOSITORY:-neondatabase}/neon:${TAG:-latest}

environment:

- SAFEKEEPER_ADVERTISE_URL=safekeeper1:5454

- SAFEKEEPER_ID=1

- BROKER_ENDPOINT=http://storage_broker:50051

- AWS_ACCESS_KEY_ID=minio

- AWS_SECRET_ACCESS_KEY=password

#- RUST_BACKTRACE=1

ports:

#- 5454:5454 # pg protocol handler

- 7676:7676 # http endpoints

entrypoint:

- "/bin/sh"

- "-c"

command:

- "safekeeper --listen-pg=$$SAFEKEEPER_ADVERTISE_URL

--listen-http='0.0.0.0:7676'

--id=$$SAFEKEEPER_ID

--broker-endpoint=$$BROKER_ENDPOINT

-D /data

--remote-storage=\"{endpoint='http://minio:9000',

bucket_name='neon',

bucket_region='eu-north-1',

prefix_in_bucket='/safekeeper/'}\""

depends_on:

- storage_broker

- minio_create_buckets

# safekeeper 服务

safekeeper2:

image: ${REPOSITORY:-neondatabase}/neon:${TAG:-latest}

environment:

- SAFEKEEPER_ADVERTISE_URL=safekeeper2:5454

- SAFEKEEPER_ID=2

- BROKER_ENDPOINT=http://storage_broker:50051

- AWS_ACCESS_KEY_ID=minio

- AWS_SECRET_ACCESS_KEY=password

#- RUST_BACKTRACE=1

ports:

#- 5454:5454 # pg protocol handler

- 7677:7676 # http endpoints

entrypoint:

- "/bin/sh"

- "-c"

command:

- "safekeeper --listen-pg=$$SAFEKEEPER_ADVERTISE_URL

--listen-http='0.0.0.0:7676'

--id=$$SAFEKEEPER_ID

--broker-endpoint=$$BROKER_ENDPOINT

-D /data

--remote-storage=\"{endpoint='http://minio:9000',

bucket_name='neon',

bucket_region='eu-north-1',

prefix_in_bucket='/safekeeper/'}\""

depends_on:

- storage_broker

- minio_create_buckets

# safekeeper 服务

safekeeper3:

image: ${REPOSITORY:-neondatabase}/neon:${TAG:-latest}

environment:

- SAFEKEEPER_ADVERTISE_URL=safekeeper3:5454

- SAFEKEEPER_ID=3

- BROKER_ENDPOINT=http://storage_broker:50051

- AWS_ACCESS_KEY_ID=minio

- AWS_SECRET_ACCESS_KEY=password

#- RUST_BACKTRACE=1

ports:

#- 5454:5454 # pg protocol handler

- 7678:7676 # http endpoints

entrypoint:

- "/bin/sh"

- "-c"

command:

- "safekeeper --listen-pg=$$SAFEKEEPER_ADVERTISE_URL

--listen-http='0.0.0.0:7676'

--id=$$SAFEKEEPER_ID

--broker-endpoint=$$BROKER_ENDPOINT

-D /data

--remote-storage=\"{endpoint='http://minio:9000',

bucket_name='neon',

bucket_region='eu-north-1',

prefix_in_bucket='/safekeeper/'}\""

depends_on:

- storage_broker

- minio_create_buckets

# 存储broker,safekeeper 需要依赖此服务

storage_broker:

image: ${REPOSITORY:-neondatabase}/neon:${TAG:-latest}

ports:

- 50051:50051

command:

- "storage_broker"

- "--listen-addr=0.0.0.0:50051"

# 计算节点,实际进行查询的入口,依赖pageserver以及safekeeper

compute:

build:

context: ./compute_wrapper/

args:

- COMPUTE_IMAGE=compute-node-v${PG_VERSION:-14}

- TAG=${TAG:-latest}

- http_proxy=$http_proxy

- https_proxy=$https_proxy

environment:

- PG_VERSION=${PG_VERSION:-14}

#- RUST_BACKTRACE=1

# Mount the test files directly, for faster editing cycle.

volumes:

- ./compute_wrapper/var/db/postgres/specs/:/var/db/postgres/specs/

- ./compute_wrapper/shell/:/shell/

ports:

- 55433:55433 # pg protocol handler

- 3080:3080 # http endpoints

entrypoint:

- "/shell/compute.sh"

depends_on:

- safekeeper1

- safekeeper2

- safekeeper3

- pageserver

# 测试客户端

compute_is_ready:

image: postgres:latest

entrypoint:

- "/bin/bash"

- "-c"

command:

- "until pg_isready -h compute -p 55433 ; do

echo 'Waiting to start compute...' && sleep 1;

done"

depends_on:

- compute

使用

可以直接基于pg 客户端链接



  • 效果

 

 


说明

以上是一个简单的试用,实际上neon 还支持分支,以及不少其他pg 扩展,后边试用下


参考资料

https://neon.tech/docs/introduction/architecture-overview/

https://github.com/neondatabase/neon/blob/main/docs/docker.md

https://github.com/rongfengliang/neon-docker-compose-learning

https://github.com/neondatabase/neon

https://neon.tech/docs/reference/compatibility/



推荐阅读
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细介绍了macOS系统的核心组件,包括如何管理其安全特性——系统完整性保护(SIP),并探讨了不同版本的更新亮点。对于使用macOS系统的用户来说,了解这些信息有助于更好地管理和优化系统性能。 ... [详细]
  • Scala 实现 UTF-8 编码属性文件读取与克隆
    本文介绍如何使用 Scala 以 UTF-8 编码方式读取属性文件,并实现属性文件的克隆功能。通过这种方式,可以确保配置文件在多线程环境下的一致性和高效性。 ... [详细]
  • QUIC协议:快速UDP互联网连接
    QUIC(Quick UDP Internet Connections)是谷歌开发的一种旨在提高网络性能和安全性的传输层协议。它基于UDP,并结合了TLS级别的安全性,提供了更高效、更可靠的互联网通信方式。 ... [详细]
  • 本文详细介绍了Java中org.neo4j.helpers.collection.Iterators.single()方法的功能、使用场景及代码示例,帮助开发者更好地理解和应用该方法。 ... [详细]
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • 本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 本文详细解析了Python中的os和sys模块,介绍了它们的功能、常用方法及其在实际编程中的应用。 ... [详细]
  • VPX611是北京青翼科技推出的一款采用6U VPX架构的高性能数据存储板。该板卡搭载两片Xilinx Kintex-7系列FPGA作为主控单元,内置RAID控制器,支持多达8个mSATA盘,最大存储容量可达8TB,持续写入带宽高达3.2GB/s。 ... [详细]
  • 本文详细介绍了如何在Ubuntu系统中下载适用于Intel处理器的64位版本,涵盖了不同Linux发行版对64位架构的不同命名方式,并提供了具体的下载链接和步骤。 ... [详细]
author-avatar
琪琪格
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有