作者:杨涛涛
资深数据库专家,专研 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)工具,屏蔽远程仓库,从本地安装。