实战篇:GBase 8a MPP Cluster 安装部署过程

目录?

前言☀️

最近参加了 GBase 数据库训练营的培训,学习过程中需要安装部署 GBase 8a MPP Cluster 集群环境,本文仅作记录供参考。官方安装教程:E01 GBase 8a MPP Cluster V95 安装和卸载

环境准备

节点 操作系统 IP地址 内存 gbase版本

gbase01redhat7.310.211.55.1002GRHEL7.3-x86_64-9.5.2.39

gbase02redhat7.310.211.55.1012GRHEL7.3-x86_64-9.5.2.39

gbase03redhat7.310.211.55.1022GRHEL7.3-x86_64-9.5.2.39

? 注意:由于官方提供的安装包版本为 Redhat7.3 版本,因此无法选择其余版本操作系统;安装系统时建议在“软件选择”中勾选“带GUI的服务器”中的“开发工具”选项。

安装介质下载【百度云盘链接】:https://www.php.cn/link/38a647f544eaa16673a5d33b77f942fe 【提取码】:ckrf

安装介质包括:

实战篇:GBase 8a MPP Cluster 安装部署过程

操作系统安装

首先创建并安装一台 gbase01 作为主节点,然后克隆另外两台(gbase02、gbase03)作为数据节点。

虚拟机软件选择可以为 VMWare、Vbox、Parallels 等。

实战篇:GBase 8a MPP Cluster 安装部署过程

? 注意:克隆后需要单独配置每台机器的主机名和网络IP地址。

安装前准备

? 以下操作,三台主机均需执行!截图仅展示主节点。

1、关闭防火墙

systemctl stop firewalld.servicesystemctl disable firewalld.service

实战篇:GBase 8a MPP Cluster 安装部署过程

2、禁用 Selinux

关闭 Selinux 之后需要重启主机才能生效,这里使用 setenforce 0 临时生效。

/usr/sbin/setenforce 0sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config

实战篇:GBase 8a MPP Cluster 安装部署过程

3、创建 gbase 用户

useradd gbaseecho gbase | passwd --stdin gbase

实战篇:GBase 8a MPP Cluster 安装部署过程

4、创建目录并授权

mkdir -p /opt/gbasechown gbase:gbase /opt/gbasechown gbase:gbase /tmp

实战篇:GBase 8a MPP Cluster 安装部署过程

5、重启主机

reboot

实战篇:GBase 8a MPP Cluster 安装部署过程

非必须,建议重启三个节点后进行安装。

❤️ GBase 8a MPP Cluster 安装

确保以上环境均已配置完成,网络IP设置正确,就可以正式开始安装。

主节点上传安装介质

本文主节点为 10.211.55.100,因此上传安装介质到主节点 /opt 目录下。

实战篇:GBase 8a MPP Cluster 安装部署过程

上传介质可以通过 ftp 工具上传。

主节点解压安装包

cd /opttar xfj GBase8a_MPP_Cluster-License-9.5.2.39-redhat7.3-x86_64.tar.bz2

实战篇:GBase 8a MPP Cluster 安装部署过程

解压成功后,/opt 目录会多出一个 gcinstall 的目录。

分发配置文件

这里三台主机均需要配置环境变量,因此需要拷贝配置文件 SetSysEnv.py 到三台主机的 /opt 目录下。

cp gcinstall/SetSysEnv.py /optscp /opt/gcinstall/SetSysEnv.py 10.211.55.101:/optscp /opt/gcinstall/SetSysEnv.py 10.211.55.102:/opt

? 注意:以上命令只需要在主节点执行分发即可。

配置环境变量

以下命令每个节点均需执行:

cd /optpython SetSysEnv.py --dbaUser=gbase --installPrefix=/opt/gbase --cgroup

实战篇:GBase 8a MPP Cluster 安装部署过程实战篇:GBase 8a MPP Cluster 安装部署过程

修改主节点安装配置文件

su - gbasecd /opt/gcinstall/vi demo.options

实战篇:GBase 8a MPP Cluster 安装部署过程

修改内容如下:

installPrefix=/opt/gbasecoordinateHost=10.211.55.100,10.211.55.101,10.211.55.102coordinateHostNodeID=100,101,102dataHost=10.211.55.100,10.211.55.101,10.211.55.102#existCoordinateHost=#existDataHost=dbaUser=gbasedbaGroup=gbasedbaPwd='gbase'rootPwd='gbase'#rootPwdFile=rootPwd.json

实战篇:GBase 8a MPP Cluster 安装部署过程

? 注意:IP地址根据实际环境进行修改,dbaPwdgbase 账户的密码,rootPwdroot 账户的密码。

主节点执行安装命令

ViiTor实时翻译 ViiTor实时翻译

AI实时多语言翻译专家!强大的语音识别、AR翻译功能。

ViiTor实时翻译 116 查看详情 ViiTor实时翻译

只需要在主节点执行安装命令即可。

cd /opt/gcinstall./gcinstall.py --silent=demo.options

实战篇:GBase 8a MPP Cluster 安装部署过程实战篇:GBase 8a MPP Cluster 安装部署过程实战篇:GBase 8a MPP Cluster 安装部署过程

截图只截取重要部分,其余内容过多不作展示。

检查集群状态

gbase 用户下,新打开一个窗口或者手动生效环境变量:

source ~/.bash_profilegcadmin

实战篇:GBase 8a MPP Cluster 安装部署过程

? 可以看到此时集群状态和节点状态都是 CLOSE,原因是因为没有注册 License 授权,属于正常现象。

申请和导入授权

① 导出集群各节点的指纹信息

进入 /opt/gcinstall 目录下,执行导出指纹命令,IP和密码根据实际情况修改:

cd /opt/gcinstall./gethostsid -n 10.211.55.100,10.211.55.101,10.211.55.102 -u root -p gbase -f /tmp/finger.txt

实战篇:GBase 8a MPP Cluster 安装部署过程

② 邮件申请授权

发邮件给:license@gbase.cn;抄送给 shenliping@gbase.cn;附件为指纹信息文件finger.txt;邮件标题:GBase 8a MPP Cluster v95 license 申请

邮件正文:

客户名称: 学员公司名称项目名称: 2021年X月认证培训申请人: 填写自己姓名申请原因: 培训学习有效期: 3个月操作系统名称及版本: Red Hat Enterprise Linux Server release 7.3 (Maipo)8a集群版本: GBase8a_MPP_Cluster-License-9.5.2.39-redhat7.3-x86_64.tar.bz2

实战篇:GBase 8a MPP Cluster 安装部署过程

授权申请处理时间点为工作日 9:00、13:30和17:30。学员收到授权文件(20210817-08.lic)后上传到主节点的 /tmp 下。

③ 主节点导入授权

cd /opt/gcinstall./License -n 10.211.55.100,10.211.55.101,10.211.55.102 -f /tmp/20210817-08.lic -u gbase -p gbase

实战篇:GBase 8a MPP Cluster 安装部署过程

④ 检查授权情况

cd /opt/gcinstall./chkLicense -n 10.211.55.100,10.211.55.101,10.211.55.102 -u gbase -p gbase

实战篇:GBase 8a MPP Cluster 安装部署过程

可以看到,三个节点均已授权成功。

License 状态说明:

is_exist 用于标识 license 文件是否存在: yes 代表存在,no 代表不存在;version 用于标识 license 类型: trial为试用版, business 为商用版;expire_time 用于标识试用版 license 的到期日期,只在检测试用版license 时才会显示;is_valid 用于标识 license 是否有效: yes 代表 license 有效,no代表 license 失效;

? 注意:授权有效期为 3 个月,如果没超出 license 有效期,CPU、内存、网卡等机器配置没变更过,可以重复使用。虚拟机系统重装之后,就需要重新申请。

所有节点启动集群服务

su - gbasegcluster_services all startgcadmin

实战篇:GBase 8a MPP Cluster 安装部署过程实战篇:GBase 8a MPP Cluster 安装部署过程

确认集群状态均已 OPEN ,运行正常。

主节点设置分片信息

gcadmin distribution gcChangeInfo.xml p 2 d 1 pattern 1

实战篇:GBase 8a MPP Cluster 安装部署过程

执行完之后,在 /opt/gcinstall 目录下会生成 gcChangeInfo.xml 文件:

实战篇:GBase 8a MPP Cluster 安装部署过程

再次检查集群状态:

gcadmin

实战篇:GBase 8a MPP Cluster 安装部署过程

gcadmin showdistribution node

实战篇:GBase 8a MPP Cluster 安装部署过程

数据库初始化

在管理节点上执行如下命令(数据库root密码默认为空)

gccli -u root -p密码为空,直接回车initnodedatamap;

实战篇:GBase 8a MPP Cluster 安装部署过程

创建库表

create database lucifer;show database;user lucifer;create table lucifer(id int ,name varchar(20));show tables;insert into lucifer values(1,'lucifer');select * from lucifer;

实战篇:GBase 8a MPP Cluster 安装部署过程实战篇:GBase 8a MPP Cluster 安装部署过程实战篇:GBase 8a MPP Cluster 安装部署过程

❄️ 集群卸载

关闭所有集群服务

3台主机均需执行关闭命令:

gcluster_services all stop

实战篇:GBase 8a MPP Cluster 安装部署过程

主节点执行卸载命令

cd /opt/gcinstall./unInstall.py --silent=demo.options

这里我还要学习,就不演示卸载了?!

以上就是实战篇:GBase 8a MPP Cluster 安装部署过程的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/464445.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 04:54:52
下一篇 2025年11月8日 04:55:20

相关推荐

  • 使用 Go 语言将字符串映射到 JSON 对象中的多种类型

    本文介绍了如何在 Go 语言中创建能够转换为 JSON 对象的 map,该 map 可以包含字符串到不同类型的映射,例如字符串到字符串、字符串到数字等。核心在于使用 `interface{}` 类型作为 map 的值类型,使其能够存储任意类型的数据,并利用 `encoding/json` 包进行 J…

    好文分享 2025年12月16日
    000
  • Go Goroutine 上下文切换机制详解

    本文深入探讨 Go 语言中 goroutine 的调度机制,重点解析 goroutine 上下文切换的时机。目前,Go 尚未实现抢占式调度,上下文切换主要发生在 I/O 操作期间。我们将详细解释这一机制,并展望未来 Go 版本中抢占式调度的发展。 Go 语言的并发模型基于 goroutine,它是一…

    2025年12月16日
    000
  • 在 Go (Golang) 中枚举注册表值

    本文介绍了如何在 Go (Golang) 中枚举 Windows 注册表中的值。通过使用 `golang.org/x/sys/windows/registry` 包,我们可以安全有效地读取注册表键值,并将它们转换为字符串,以便在应用程序中使用。文章提供了详细的代码示例,展示了如何打开注册表键、读取键…

    2025年12月16日
    000
  • 在 Gorilla Mux 中创建带可选 URL 变量的路由

    本文详细介绍了如何在 Go 语言的 Gorilla Mux 路由库中实现带有可选 URL 变量的路由。核心策略是通过注册两个独立的路由来处理有变量和无变量的两种情况,并在相应的处理器函数中利用 `mux.Vars` 检查变量是否存在,从而灵活地响应不同的 URL 模式,确保应用程序能够优雅地处理动态…

    2025年12月16日
    000
  • Go 并发修改结构体切片:从切片语义到并发安全机制

    本文深入探讨了在 go 语言中并发修改结构体切片时遇到的两大核心问题:切片操作的语义行为(尤其是 `append` 导致的切片重分配)以及并发环境下的数据竞争。文章详细介绍了通过返回新切片、传递结构体指针来正确处理切片修改,并提供了使用 channel、内嵌 `sync.mutex` 或全局 `sy…

    2025年12月16日
    000
  • Go 协程调度机制详解:何时发生上下文切换?

    本文深入探讨 Go 语言的协程调度机制,重点解析协程上下文切换发生的时机。当前 Go 版本采用协作式调度,上下文切换主要发生在 I/O 操作期间,而非 CPU 密集型计算。文章将详细解释这一机制,并展望未来 Go 版本中可能引入的抢占式调度。 Go 协程调度机制 Go 语言的协程(goroutine…

    2025年12月16日
    000
  • Go语言条件编译:利用构建约束实现跨平台代码管理

    go语言通过构建约束(build constraints)提供了一种优雅的机制,允许开发者根据目标操作系统、架构、编译器或自定义标签,有条件地编译特定源文件。这对于处理平台特有依赖,如cgo与windows api的集成,或在不同系统上模拟功能,提供了强大的支持,确保代码在多种环境中高效且无缝地运行…

    2025年12月16日
    000
  • 获取Go语言切片底层数组的方法

    本文旨在阐明Go语言中切片与底层数组的关系,重点解释为何以及如何(虽然实际上并不能直接)从切片访问其底层数组。文章将通过示例代码和逻辑分析,帮助读者深入理解Go语言切片的本质特性,并避免在实际开发中产生误解。 Go语言的切片(slice)是一种动态数组,它提供了对底层数组片段的引用。理解切片与底层数…

    2025年12月16日
    000
  • Golang解析动态键名JSON数据

    本文旨在解决go语言中解析具有动态顶层键的json字符串的挑战。我们将介绍如何利用go的`map[string]struct`结构来优雅地处理这类数据,从而实现对嵌套固定字段(如`name`和`age`)的提取,并提供详细的代码示例和最佳实践,确保解析过程的健壮性和可读性。 在Go语言中处理JSON…

    2025年12月16日
    000
  • 使用Go语言将字符串映射到多种类型的JSON对象

    本文旨在讲解如何使用Go语言创建能够将字符串映射到多种类型的JSON对象。由于Go语言的强类型特性,直接创建 `map[string]string` 或 `map[string]int` 类型的映射无法满足需求。本文将介绍如何利用 `interface{}` 类型来实现动态类型的JSON对象构建,并…

    2025年12月16日
    000
  • 在 Go 中实现 JSON Marshaller 处理嵌入式结构体

    本文将介绍如何在 Go 语言中高效地将包含嵌入式结构体的结构体进行 JSON 编码,特别是当嵌入式结构体实现了 `Marshaler` 接口时。我们将通过示例代码演示如何手动控制 JSON 序列化的过程,以确保所有字段都能正确地被编码。 在 Go 语言中,使用 encoding/json 包可以方便…

    2025年12月16日
    000
  • Go 语言 Goroutine 的上下文切换机制详解

    本文深入探讨 Go 语言中 Goroutine 的上下文切换机制。当前版本的 Go 语言调度器并非抢占式,Goroutine 的切换主要发生在 I/O 操作期间,例如网络请求、文件读写以及内存访问(如果数据不在寄存器中)。 了解这些机制对于编写高效的并发 Go 程序至关重要。本文将详细介绍相关原理,…

    2025年12月16日
    000
  • Go语言JSON解码:处理数字字符串键到整数键映射的策略

    本文探讨了在go语言中处理json数据时,如何将以数字字符串作为键的json对象有效转换为以整数作为键的go `map`类型。由于json规范仅支持字符串键,go的`encoding/json`包无法直接解码为`map[int]type`。文章详细介绍了先解码为`map[string]type`,然…

    2025年12月16日
    000
  • Go语言指针操作:如何正确修改通过指针传递的字符串值

    本文深入探讨go语言中通过指针修改字符串值的两种常见操作:`*dest = src` 和 `dest = &src`。我们将详细解析这两种赋值方式的底层机制和作用域影响,阐明为何前者能成功修改原始字符串,而后者仅在函数局部生效,旨在帮助开发者避免常见的指针误用,掌握go语言中指针的正确使用姿…

    2025年12月16日
    000
  • 如何在Golang中实现HTTP请求限流

    使用golang.org/x/time/rate包中的rate.Limiter可基于令牌桶算法实现HTTP请求限流,支持全局限流或按客户端IP独立限流,结合中间件和定期清理机制保障服务稳定性。 在Golang中实现HTTP请求限流,主要是为了防止服务被过多请求压垮,保障系统稳定性。常用的方式是使用令…

    2025年12月16日
    000
  • Go语言中如何扩展或修改第三方包函数:替代方案与实践

    在go语言中,无法直接覆盖或重写已导入第三方包的函数。本文将探讨当需要修改或扩展现有包功能时,可采用的几种实用策略,包括代码分支(forking)、创建包装器函数以及重新评估依赖,以实现对外部库行为的定制化需求。 Go语言以其简洁、高效和强类型闻名,其包管理和编译机制也体现了这些设计哲学。与某些动态…

    2025年12月16日
    000
  • Google App Engine Go运行时与CGo兼容性探讨

    本文深入探讨了cgo在google app engine (gae) go运行时中的支持情况。由于gae作为paas平台的严格隔离性要求,cgo目前不受支持,且未来支持的可能性较低。这意味着依赖cgo进行系统级交互或高性能计算的go应用程序无法直接部署在gae上。开发者需考虑优化纯go代码、寻求替代…

    2025年12月16日
    000
  • Golang 并发编程:安全地向共享切片追加元素

    本文深入探讨了在go语言中,多个goroutine并发地向同一个切片追加元素时可能遇到的竞态条件问题。文章提供了三种主要的并发安全解决方案:使用`sync.mutex`进行互斥访问、通过通道(channel)收集结果,以及在已知最终大小的情况下,通过预分配切片并按索引写入。通过详细的代码示例和解释,…

    2025年12月16日
    000
  • 使用 Go 语言判断 Web 应用的访问来源并限制外部访问

    本文旨在介绍如何使用 Go 语言判断 Web 应用的访问来源(本地或外部),并根据访问来源实现功能限制或完全禁止外部访问。我们将探讨如何获取客户端 IP 地址,并利用该信息进行访问控制,以及如何通过绑定服务到本地接口来彻底隐藏 Web 应用。 识别 Web 应用的访问来源 在 Web 应用开发中,有…

    2025年12月16日
    000
  • Go语言反射:从指针类型实例化并修改结构体

    本文深入探讨go语言中如何利用反射机制,从一个指向结构体的指针类型(如`*model.company`)获取其底层结构体类型,并进而实例化一个新的结构体对象,修改其字段。通过`type().elem()`和`reflect.new().elem()`的组合使用,我们可以动态地创建和操作复杂数据结构,…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信