百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

新发现:一款非常好用的PostgreSQL数据库管理工具

off999 2025-02-15 00:44 16 浏览 0 评论

快速搭建 PostgreSQL 集群

对于新手或开发人员,如何快速搭建一个PostgreSQL数据库集群。以往,设置数据库集群可能需要手动进行繁琐的配置步骤,但是最近发现一款非常好用的PostgreSQL高可用管理工具,与Patroni和Repmgr相比,最让人眼前一亮的是这个工具带有Web页面,不需要在命令行中操作,也不需要搞一堆配置文件,页面上点一点就可以拉起一个集群,对于开发者来说简直就是一大利器。而且这个工具还有开源版本,代码是用Python写的,对于懂Python的PostgreSQL新手来说也是一大利器,既可以快速搭建自己想要的集群,又可以参照源码学习一些PostgreSQL数据库集群的管理方法。

这个PostgreSQL 高可用管理软件叫CLup,参照其官方文档,可以快速部署服务。这里给点个赞,连Apache或Nginx服务都不需要安装,直接执行一个命令就可以了。对了还有一键安装PostgreSQL数据库的命令,好像是他们自己编译好的(操作系统只支持EL7或EL8的),这里再点个赞,连安装数据库的步骤都省了,当然对于新手来说,最好还是要自己动手安装一下。他们有两个版本,一个企业版本,一个开源版本,企业版的功能更全,默认会有20个CPU核心和集群数据库数量的限制,具体的大家可以看下其官方的文档[CLup简介](
https://www.csudata.com/clup/manual)。安装哪个版本,需要根据自己需求确定。我把两个版本都安装了试用了一下,都是一键安装,安装速度很快也不费事,都试试。

测试环境说明:

名称

说明

操作系统

RockyLinux8

主机1

4核心虚拟机,4GB内存

主机2

4核心虚拟机,4GB内存

CLup企业版

参考文档:
https://www.csudata.com/clup/manual/5.x/10147

先附上部署后搭建的一个集群:

安装Server 端

使用一键安装命令(这里需要ssh连接到虚拟机上)

wget -qO /tmp/clup.sh --no-check-certificate https://get.csudata.com/csuinst/clup.sh && bash /tmp/clup.sh clup install

简单看了下安装步骤,里面好像安装了两个程序包,一个csumdb(官方说的是CLup服务所用到的数据库,是PostgreSQL12版本的),一个主服务程序CLup。

======== begin install csumdb1.1.2.el8.x86_64.bin ...
== Installation is starting ...
=== Installation is complete.
install csumdb1.1.2.el8.x86_64.bin success!
...

======== begin install clup5.1.5.el8.x86_64.bin ...
==== Installation is starting ...
...
==== register systemd service ...
register service clup sucessfully.
==== register systemd service ok.
==== Installation is complete.
install clup5.1.5.el8.x86_64.bin success!

盲猜数据库用户是放到/home下的,去看了下还真是

[root@Server01 home]# ll
total 4
drwx------ 4 csumdb csumdb 4096 Mar 12 03:14 csumdb

先看下服务是否正常(安装步骤里有注册systemctl的系统服务)

[root@Server01 ~]# systemctl status clup
● clup.service - clup
   Loaded: loaded (/etc/systemd/system/clup.service; enabled; vendor preset: disabled)
  Drop-In: /run/systemd/system/clup.service.d
           └─zzz-lxc-service.conf
   Active: active (running) since Mon 2024-08-26 10:05:24 CST; 5h 49min ago
 Main PID: 2488 (clupserver)
    Tasks: 20 (limit: 182297)
   Memory: 51.7M
   CGroup: /system.slice/clup.service
           ├─2488 /opt/clup/bin/clupserver start
           └─2489 /opt/clup/bin/clupserver start

Aug 26 10:05:23 CLup-Server01 systemd[1]: Starting clup...
Aug 26 10:05:24 CLup-Server01 clupserver[2484]: clup not running
Aug 26 10:05:24 CLup-Server01 clupserver[2486]: 2024-08-26 02:05:24,282 INFO ========== CLup starting ==========
Aug 26 10:05:24 CLup-Server01 su[2490]: (to csumdb) root on none
Aug 26 10:05:24 CLup-Server01 su[2490]: pam_unix(su-l:session): session opened for user csumdb by (uid=0)
Aug 26 10:05:24 CLup-Server01 systemd[1]: Started clup.
Aug 26 10:05:24 CLup-Server01 su[2490]: pam_unix(su-l:session): session closed for user csumdb

看到了active,应该是起来了,登录Web页面(http://IP:8090 用户名admin,密码cstech)

安装Agent端

使用一键安装命令

wget -qO /tmp/clup.sh --no-check-certificate https://get.csudata.com/csuinst/clup.sh && bash /tmp/clup.sh clup-agent install

安装的步骤

======== begin install clup-agent5.1.5.el8.x86_64.bin ...
==== Installation is starting ...
What is your ip?
...
==== register systemd service ...
2024-08-26 02:21:03,312 INFO clup-agent v5.1.5 Copyright (c) 2018-2023 CSUDATA.COM All rights reserved.
Created symlink /etc/systemd/system/multi-user.target.wants/clup-agent.service → /etc/systemd/system/clup-agent.service.
register service clup-agent sucessfully.
==== register systemd service ok.
==== Installation is complete.
install clup-agent5.1.5.el8.x86_64.bin success!
======== begin clean PACKAGE ...
rm -rf /tmp/clup-agent5.1.5.el8.x86_64.bin
begin install database software ...

需要选择一个IP和输入Server端的IP。

安装步骤里也注册了systemctl的系统服务,查看下服务的状态

[root@Server01 ~]# systemctl status clup-agent
● clup-agent.service - clup-agent
   Loaded: loaded (/etc/systemd/system/clup-agent.service; enabled; vendor preset: disabled)
  Drop-In: /run/systemd/system/clup-agent.service.d
           └─zzz-lxc-service.conf
   Active: active (running) since Mon 2024-08-26 15:52:23 CST; 3min 22s ago
  Process: 7258 ExecStop=/opt/clup-agent/bin/clup-agent stop (code=exited, status=0/SUCCESS)
  Process: 7262 ExecStart=/opt/clup-agent/bin/clup-agent start (code=exited, status=0/SUCCESS)
  Process: 7260 ExecStartPre=/opt/clup-agent/bin/clup-agent stop (code=exited, status=0/SUCCESS)
 Main PID: 7264 (clup-agent)
    Tasks: 13 (limit: 182297)
   Memory: 16.9M
   CGroup: /system.slice/clup-agent.service
           └─7264 /opt/clup-agent/bin/clup-agent start

Aug 26 15:52:23 CLup-Server01 systemd[1]: Starting clup-agent...
Aug 26 15:52:23 CLup-Server01 clup-agent[7260]: clup-agent not running
Aug 26 15:52:23 CLup-Server01 clup-agent[7262]: 2024-08-26 07:52:23,651 INFO clup-agent v5.1.5 Copyright (c) 2018-2023 CSUDATA.COM All rights reserved.
Aug 26 15:52:23 CLup-Server01 systemd[1]: Started clup-agent.

看到了active,应该是可以了。

在另外一台机器上也执行下安装clup-agent,操作步骤如上。

安装PostgreSQL数据库

PostgreSQL官方是有安装文档的,不过如果需要快速安装多个版本的话,还是比较麻烦的,所以这里试下CLup提供的一键安装命令,安装PostgreSQL12和14的版本。

wget -qO /tmp/clup.sh --no-check-certificate https://get.csudata.com/csuinst/clup.sh && bash /tmp/clup.sh db install

安装过程中可以看到,先是安装了一堆的依赖,后面选择下数据库的版本,很快就安装好了

请选择要安装的数据库:
1) PostgreSQL 11
2) PostgreSQL 12
3) PostgreSQL 13
4) PostgreSQL 14
5) PolarDB
按 'q' 退出
请输入选择: 2
...
install csupg-12.16.el8.x86_64.bin success!
请选择要安装的数据库:
1) PostgreSQL 11
2) PostgreSQL 12
3) PostgreSQL 13
4) PostgreSQL 14
5) PolarDB
按 'q' 退出
请输入选择: 4
...
install csupg-14.9.el8.x86_64.bin success!

PostgreSQL官方默认的安装路径是在/usr下面,这里的一键安装脚本也是

[root@CLup-Server01 usr]# ll
total 88
dr-xr-xr-x  2 root root 20480 Aug 26 02:31 bin
drwxr-xr-x  6 root root  4096 Aug 21  2023 csupg-12.16
drwxr-xr-x  6 root root  4096 Aug 22  2023 csupg-14.9
...

搭建集群

官方文档说需要先创建一个VIP池,原因是PostgreSQL流复制集群需要使用VIP(虚拟IP),那就建一个(选一段没有使用的IP就行了):

现在就搭建一套集群试下,操作步骤HA集群->集群定义->创建集群->创建PostgreSQL流复制集群

点击下一步后,需要输入集群名称和选择一个vip池,然后分配一个vip,其他的就按默认值好了:

默认的数据库用户密码为postgres,这个看自己需求,想改就改一下。

点击下一步后,就出现了提交按钮,如果需要调整参数,则继续点击下一步,这里就跳过了。

点击提交后就是创建过程的日志,这里就不细看了。

看下创建的结果,HA管理->详情

CLup 开源版本

开源版的安装提供有一键安装的命令,安装过程跟企业版基本上一样,就是多了Python的环境,有两个目录:

  • /opt/csupy3.9.16:Python3的软件
  • /opt/csu_pyenv: Python3的虚拟环境,里面安装了所需的工具包

安装Server端

wget -qO /tmp/clup.sh --no-check-certificate https://get.csudata.com/csuinst/clup.sh && bash /tmp/clup.sh openclup install

安装Agent端

wget -qO /tmp/clup.sh --no-check-certificate https://get.csudata.com/csuinst/clup.sh && bash /tmp/clup.sh openclup-agent install

安装成功后登录Web页面(http://IP:8090 用户名admin,密码openclup):

创建集群的页面跟企业版不太一样,不过也是先创建一个VIP池:

然后再创建集群,这里建一套PostgreSQL14版本的,需要添加两台机器:

这里的信息需要手工填入:

之后就是一路点击下一步就可以了,其中有修改参数的页面,有需要改的就改一下。

看下创建的结果,HA管理->详情

OK,到此两个版本的安装都没问题,都可以很快的创建集群,然后如果需要启动高可用,需要集群上线,这样如果主库坏了,就会自动切换到备库上。高可用我们下次再探索。

相关推荐

如何理解python中面向对象的类属性和实例属性?

类属性和实例属性类属性就是给类对象中定义的属性通常用来记录与这个类相关的特征类属性不会用于记录具体对象的特征类属性的理解:类属性是与类自身相关联的变量,而不是与类的实例关联。它们通...

Java程序员,一周Python入门:面向对象(OOP) 对比学习

Java和Python都是**面向对象编程(OOP)**语言,无非是类、对象、继承、封装、多态。下面我们来一一对比两者的OOP特性。1.类和对象Java和Python都支持面向对象...

松勤技术精选:Python面向对象魔术方法

什么是魔术方法相信大家在使用python的过程中经常会看到一些双下划线开头,双下划线结尾的方法,我们把它统称为魔术方法魔术方法的特征魔术方法都是双下划线开头,双下划线结尾的方法魔术方法都是pytho...

[2]Python面向对象-【3】方法(python3 面向对象)

方法的概念在Python中,方法是与对象相关联的函数。方法可以访问对象的属性,并且可以通过修改对象的属性来改变对象的状态。方法定义在类中,可以被该类的所有对象共享。方法也可以被继承并重载。方法的语法如...

一文带你理解python的面向对象编程(OOP)

面向对象编程(OOP,Object-OrientedProgramming)是一个较难掌握的概念,而Python作为一门面向对象的语言,在学习其OOP特性时,许多人都会对“继承”和“多态”等...

简单学Python——面向对象1(编写一个简单的类)

Python是一种面向对象的编程语言(ObjectOrientedProgramming),在Python中所有的数据类型都是对象。在Python中,也可以自创对象。什么是类呢?类(Class)是...

python进阶突破面向对象——四大支柱

面向对象编程(OOP)有四大基本特性,通常被称为"四大支柱":封装(Encapsulation)、继承(Inheritance)、多态(Polymorphism)和抽象(Abstrac...

Python学不会来打我(51)面向对象编程“封装”思想详解

在面向对象编程(Object-OrientedProgramming,简称OOP)中,“封装(Encapsulation)”是四大核心特性之一(另外三个是继承、多态和抽象),它通过将数据(属性)和...

Python之面向对象:对象属性解析:MRO不够用,补充3个方法

引言在前面的文章中,我们谈及Python在继承关系,尤其是多继承中,一个对象的属性的查找解析顺序。由于当时的语境聚焦于继承关系,所以只是简要提及了属性解析顺序同方法的解析顺序,而方法的解析顺序,在Py...

Python之面向对象:通过property兼顾属性的动态保护与兼容性

引言前面的文章中我们简要提及过关于Python中私有属性的使用与内部“名称混淆”的实现机制,所以,访问私有属性的方法至少有3种做法:1、使用实例对象点操作符的方式,直接访问名称混淆后的真实属性名。2、...

Python之面向对象:私有属性是掩耳盗铃还是恰到好处

引言声明,今天的文章中没有一行Python代码,更多的是对编程语言设计理念的思考。上一篇文章中介绍了关于Python面向对象封装特性的私有属性的相关内容,提到了Python中关于私有属性的实现是通过“...

Python中的私有属性与方法:解锁面向对象编程的秘密

Python中的私有属性与方法:解锁面向对象编程的秘密在Python的广阔世界里,面向对象编程(OOP)是一种强大而灵活的方法论,它帮助我们更好地组织代码、管理状态,并构建可复用的软件组件。而在这个框...

Python 面向对象:掌握类的继承与组合,让你的代码更高效!

引言:构建高效代码的基石Python以其简洁强大的特性,成为众多开发者首选的编程语言。而在Python的面向对象编程(OOP)范畴中,类的继承和组合无疑是两大核心概念。它们不仅能帮助我们实现代码复用,...

python进阶-Day2: 面向对象编程 (OOP)

以下是为Python进阶Day2设计的学习任务,专注于面向对象编程(OOP)的核心概念和高阶特性。代码中包含详细注释,帮助理解每个部分的实现和目的。任务目标:复习OOP基础:类、对象、继...

外婆都能学会的Python教程(二十八):Python面向对象编程(二)

前言Python是一个非常容易上手的编程语言,它的语法简单,而且功能强大,非常适合初学者学习,它的语法规则非常简单,只要按照规则写出代码,Python解释器就可以执行。下面是Python的入门教程介绍...

取消回复欢迎 发表评论: