作者:杨涛涛

资深数据库专家,专研 MySQL 十余年。擅长 MySQL、PostgreSQL、MongoDB 等开源数据库相关的备份恢复、SQL 调优、监控运维、高可用架构设计等。目前任职于爱可生,为各大运营商及银行金融企业提供 MySQL 相关技术支持、MySQL 相关课程培训等工作。

本文来源:原创投稿

*爱可生开源社区出品,原创内容未经授权不得随意使用,转载请联系小编并注明来源。


OceanBase 在官方文档中提到支持的 OS 列表包括 CENTOS 、UBUNTU 、DEBIAN 等等,但是软件源只提供 CENTOS 版本,无法直接在其他平台远程自动部署。但是对于我这种喜欢用 UBUNTU / DEBIAN 系统的用户来讲,就稍感欠缺!

目前部署 OceanBase 有以下几种方式:
1. OCP 平台部署:

OCP 平台本身对硬件(官方文档推荐配置CPU为32C,内存为128GB,磁盘为1.5TB ,并且要求 SSD)要求极高,故个人把玩的概率不大。

2. OBD 方式部署:

通过这种方式部署,只要满足 OceanBase 本身对硬件的要求即可。比如可以用最低 2C ,8GB 的配置来玩,普通笔记本都可以,堪称贫民玩法!

3. DOCKER 方式部署:

对硬件要求更低,不限制 OS 平台,更加贫民化。

4. 下载安装包来手动部署:

可以下载官方的 RPM 包来手动部署。 缺点是需要手动启动脚本、手动初始化等步骤,比较繁琐(比如在 UBUNTU 下,需要安装 Alien 来对 RPM 包进行转化,而且可能因为各种原因不成功,比如 KEY 过期等)!

本篇我来基于第二种贫民部署方法:在 UBUNTU 上用 OBD 工具来部署 OceanBase !为了节省资源,我选择1-0-0的方式,也即:只有一个 zone ,一台 Server ,一个obproxy(odp)实例。

我的 UBUNTU 版本为 22.04.1 LTS ,OceanBase 版本为最新版 4.0 。选择 4.0 版本是因为比 3.0 版本部署来的简单。4.0 版本把所有安装包打包在一起,命名为 oceanbase-all-in-one.tar.gz ,里面包含了一个 shell 自动化脚本,便于一键安装!

此处省去 OS 配置参数、NTP 服务配置、创建用户以及属主等步骤, 只列举一些重要的步骤(不推荐生产使用,仅限自己把玩!)。

接下来我来演示下如何在 UBUNTU 上部署 OceanBase 。

1.创建数据目录、REDO 目录:

root@ytt-pc:/home# mkdir -p /data/1 /data/log1
root@ytt-pc:/home# chown -R admin.admin /data/1 /data/log1/

2. 解压 oceanbase-all-in-one.tar.gz ,然后进入子目录,执行 install.sh 脚本即可安装本地软件包以及禁止 OBD 远程安装源。以下结果没出错,代表 OBD 环境初始化成功。

root@ytt-pc-super:/home/ytt/下载/oceanbase-all-in-one/bin# ./install.sh
   
...
   
add /home/ytt/下载/oceanbase-all-in-one/rpms/prometheus-2.37.1-10000102022110211.el7.x86_64.rpm to local mirror
Disable remote ok
   
#####################################################################
   
Install Finished 
=====================================================================
   
Setup Environment:     source ~/.oceanbase-all-in-one/bin/env.sh 
Quick Start:           obd demo 
   
More Details:          obd -h 
=====================================================================

本地部署的安装包列表: 之后在配置文件里只需配置 obproxy-ce 和 oceanbase-ce 即可快速尝鲜。

root@ytt-pc-super:~# obd mirror list local
+----------------------------------------------------------------------------------------------------------+
|                                            local Package List                                 |
+-------------------+---------+------------------------+--------+------------------------------------------+
| name              | version | release                | arch   | md5                                   |
+-------------------+---------+------------------------+--------+------------------------------------------+
| grafana           | 7.5.17  | 1                      | x86_64 | 1bf1f338d3a3445d8599dc6902e7aeed4de4e0d6 |
| obagent           | 1.2.0   | 4.el7                  | x86_64 | 0e8f5ee68c337ea28514c9f3f820ea546227fa7e |
| obproxy-ce        | 4.0.0   | 5.el7                  | x86_64 | de53232a951184fad75b15884458d85e31d2f6c3 |
| oceanbase-ce      | 4.0.0.0 | 100000272022110114.el7 | x86_64 | 42611dc51ca9bb28f36e60e4406ceea4a74914c7 |
| oceanbase-ce-libs | 4.0.0.0 | 100000272022110114.el7 | x86_64 | 188919f8128394bf9b62e3989220ded05f1d14da |
| prometheus        | 2.37.1  | 10000102022110211.el7  | x86_64 | 58913c7606f05feb01bc1c6410346e5fc31cf263 |
+-------------------+---------+------------------------+--------+------------------------------------------+

3. 来手工编辑一个简单的 1-0-0 配置文件(可以从 OBD 安装目录下找模板来修改):为了快速部署,我们把 datafile_size 和 log_disk_size 调成固定值,并且关闭生产模式(集群名为 obytt100)!

root@ytt-pc-super:/home/ytt/config# cat obytt100.yaml 
oceanbase-ce:
servers:
- 127.0.0.1
global:
memory_limit: 9G
system_memory: 3G
datafile_size: 30G
log_disk_size: 30G
devname: lo
cpu_count: 32
production_mode: false
cluster_id: 100
cluster: obytt100
appname: obytt100
  127.0.0.1:
mysql_port: 2881
rpc_port: 2882
home_path: /home/admin/oceanbase-ce
data_dir: /data/1
redo_dir: /data/log1
zone: zone1
obproxy-ce:
 servers:
- 127.0.0.1
global:
home_path: /home/admin/obproxy-ce
skip_proxy_sys_private_check: true
enable_strict_kernel_release: false
proxy_mem_limited: 2G
prometheus_listen_port: 2884
listen_port: 2883
 127.0.0.1:
enable_cluster_checkout: false
depends:
- oceanbase-ce

4. 用 OBD 来部署1-0-0的 OceanBase :出现 obytt100 deployed 代表部署成功!

root@ytt-pc-super:/home/ytt/config# obd cluster deploy obytt100 -c obytt100.yaml 
[WARN] Use centos 7 remote mirror repository for ubuntu 22.04
[WARN] Use centos 7 remote mirror repository for ubuntu 22.04
...
obytt100 deployed

5. 启动 OceanBase 和 obproxy :出现 obytt100 running 代表启动成功。

root@ytt-pc-super:/home/ytt/config# obd cluster start obytt100
...
Start obproxy ok
obproxy program health check ok
Connect to obproxy ok
Initialize cluster ok
Wait for observer init ok
+---------------------------------------------+
|                   observer                  |
 +-----------+---------+------+-------+--------+
| ip        | version | port | zone  | status |
+-----------+---------+------+-------+--------+
| 127.0.0.1 | 4.0.0.0 | 2881 | zone1 | ACTIVE |
+-----------+---------+------+-------+--------+
obclient -h127.0.0.1 -P2881 -uroot -Doceanbase
   
+---------------------------------------------+
|                   obproxy                   |
+-----------+------+-----------------+--------+
| ip        | port | prometheus_port | status |
+-----------+------+-----------------+--------+
| 127.0.0.1 | 2883 | 2884            | active |
+-----------+------+-----------------+--------+
obclient -h127.0.0.1 -P2883 -uroot -Doceanbase
obytt100 running

6. 进入 sys 租户,执行简单的命令,测试下连接:自此部署成功。

root@ytt-pc-super:/home/ytt/config# obclient -h127.1 -P 2883 -uroot@sys#obytt100 -e "show databases"
+--------------------+
| Database           |
+--------------------+
| information_schema |
| LBACSYS            |
| mysql              |
| oceanbase          |
| ORAAUDITOR         |
| SYS                |
| test               |
+--------------------+

总结:

在非 CENTOS / REDHAT 系列 OS 部署 OceanBase 集群,需要使用 OBD(ob-deploy)工具,屏蔽远程仓库,从本地安装。


avatar
100
  Subscribe  
提醒