热门标签 | 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/



推荐阅读
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社区 版权所有