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

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

off999 2025-02-15 00:44 19 浏览 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,到此两个版本的安装都没问题,都可以很快的创建集群,然后如果需要启动高可用,需要集群上线,这样如果主库坏了,就会自动切换到备库上。高可用我们下次再探索。

相关推荐

大文件传不动?WinRAR/7-Zip 入门到高手,这 5 个技巧让你效率翻倍

“这200张照片怎么传给女儿?微信发不了,邮箱附件又超限……”62岁的张阿姨对着电脑犯愁时,儿子只用了3分钟就把照片压缩成一个文件,还教她:“以后用压缩软件,比打包行李还方便!”职场人更懂这...

电脑解压缩软件推荐——7-Zip:免费、高效、简洁的文件管理神器

在日常工作中,我们经常需要处理压缩文件。无论是下载软件包、接收文件,还是存储大量数据,压缩和解压缩文件都成为了我们日常操作的一部分。而说到压缩解压软件,7-Zip绝对是一个不可忽视的名字。今天,我就来...

设置了加密密码zip文件要如何打开?这几个方法可以试试~

Zip是一种常见的压缩格式文件,文件还可以设置密码保护。那设置了密码的Zip文件要如何打开呢?不清楚的小伙伴一起来看看吧。当我们知道密码想要打开带密码的Zip文件,我们需要用到适用于Zip格式的解压缩...

大文件想要传输成功,怎么把ZIP文件分卷压缩

不知道各位小伙伴有没有这样的烦恼,发送很大很大的压缩包会受到限制,为此,想要在压缩过程中将文件拆分为几个压缩包并且同时为所有压缩包设置加密应该如何设置?方法一:使用7-Zip免费且强大的文件管理工具7...

高效处理 RAR 分卷压缩包:合并解压操作全攻略

在文件传输和存储过程中,当遇到大文件时,我们常常会使用分卷压缩的方式将其拆分成多个较小的压缩包,方便存储和传输。RAR作为一种常见的压缩格式,分卷压缩包的使用频率也很高。但很多人在拿到RAR分卷...

2个方法教你如何删除ZIP压缩包密码

zip压缩包设置了加密密码,每次解压文件都需要输入密码才能够顺利解压出文件,当压缩包文件不再需要加密的时候,大家肯定想删除压缩包密码,或是忘记了压缩包密码,想要通过删除操作将压缩包密码删除,就能够顺利...

速转!漏洞预警丨压缩软件Winrar目录穿越漏洞

WinRAR是一款功能强大的压缩包管理器,它是档案工具RAR在Windows环境下的图形界面。该软件可用于备份数据,缩减电子邮件附件的大小,解压缩从Internet上下载的RAR、ZIP及其它类...

文件解压方法和工具分享_文件解压工具下载

压缩文件减少文件大小,降低文件失效的概率,总得来说好处很多。所以很多文件我们下载下来都是压缩软件,很多小伙伴不知道怎么解压,或者不知道什么工具更好,所以今天做了文件解压方法和工具的分享给大家。一、解压...

[python]《Python编程快速上手:让繁琐工作自动化》学习笔记3

1.组织文件笔记(第9章)(代码下载)1.1文件与文件路径通过importshutil调用shutil模块操作目录,shutil模块能够在Python程序中实现文件复制、移动、改名和删除;同时...

Python内置tarfile模块:读写 tar 归档文件详解

一、学习目标1.1学习目标掌握Python内置模块tarfile的核心功能,包括:理解tar归档文件的原理与常见压缩格式(gzip/bz2/lzma)掌握tar文件的读写操作(创建、解压、查看、过滤...

使用python展开tar包_python拓展

类Unix的系统,打包文件经常使用的就是tar包,结合zip工具,可以方便的打包并解压。在python的标准库里面有tarfile库,可以方便实现生成了展开tar包。使用这个库最大的好处,可能就在于不...

银狐钓鱼再升级:白文件脚本化实现GO语言后门持久驻留

近期,火绒威胁情报中心监测到一批相对更为活跃的“银狐”系列变种木马。火绒安全工程师第一时间获取样本并进行分析。分析发现,该样本通过阿里云存储桶下发恶意文件,采用AppDomainManager进行白利...

ZIP文件怎么打开?2个简单方法教你轻松搞定!

在日常工作和生活中,我们经常会遇到各种压缩文件,其中最常见的格式之一就是ZIP。ZIP文件通过压缩数据来减少文件大小,方便我们进行存储和传输。然而,对于初学者来说,如何打开ZIP文件可能会成为一个小小...

Ubuntu—解压多个zip压缩文件.zip .z01 .z02

方法将所有zip文件放在同一目录中:zip_file.z01,zip_file.z02,zip_file.z03,...,zip_file.zip。在Zip3.0版本及以上,使用下列命令:将所有zi...

如何使用7-Zip对文件进行加密压缩

7-Zip是一款开源的文件归档工具,支持多种压缩格式,并提供了对压缩文件进行加密的功能。使用7-Zip可以轻松创建和解压.7z、.zip等格式的压缩文件,并且可以通过设置密码来保护压缩包中的...

取消回复欢迎 发表评论: