SequoiaDB 巨杉数据库Docker镜像使用教程

为方便用户快速体验,SequoiaDB 巨杉数据库提供基于 Docker 的镜像。本文介绍如何在 Docker 环境下部署 SequoiaDB 分布式集群环境。

集群规划

我们准备在五个容器中部署一个多节点高可用 SequoiaDB 集群。

主机名 IP 分区组 部署软件
Coord 协调节点 172.17.0.2:11810 SYSCoord SequoiaDB 3.2.1
Catalog编目节点 172.17.0.2:11800 SYSCatalogGroup SequoiaDB 3.2.1
Data1数据节点1 172.17.0.3:11820 group1 SequoiaDB 3.2.1
Data2数据节点2 172.17.0.4:11820 group1 SequoiaDB 3.2.1
Data3数据节点3 172.17.0.5:11820 group1 SequoiaDB 3.2.1
Data1数据节点2 172.17.0.4:11830 group2 SequoiaDB 3.2.1
Data2数据节点3 172.17.0.5:11830 group2 SequoiaDB 3.2.1
Data3数据节点1 172.17.0.3:11830 group2 SequoiaDB 3.2.1
Data1数据节点3 172.17.0.5:11840 group3 SequoiaDB 3.2.1
Data2数据节点1 172.17.0.3:11840 group3 SequoiaDB 3.2.1
Data3数据节点2 172.17.0.4:11840 group3 SequoiaDB 3.2.1
MySQL实例 172.17.0.6:3306 - SequoiaSQL-MySQL 3.2.1

集群包含一个协调节点与编目节点,三个三副本数据节点,与一个 MySQL 实例节点。

样例环境

Docker 环境 Mac Docker 2.0.0.3
容器操作系统版本 Ubuntu 18
数据库版本 SequoiaDB 3.2.1
集群部署 一个运行协调和编目节点,三个运行数据节点,一个运行 MySQL 实例

Docker 在 Linux/Windows/MacOS 平台安装方法可参考官方文档。

对于 Linux 环境可参考本样例安装 Docker 环境。

$ apt-get install -y docker.io

拉取镜像

$ docker pull sequoiadb/sequoiadb
$ docker pull sequoiadb/sequoiasql-mysql

启动四个 SequoiaDB 容器

$ docker run -it -d --name coord_catalog sequoiadb/sequoiadb:latest
$ docker run -it -d --name sdb_data1 sequoiadb/sequoiadb:latest
$ docker run -it -d --name sdb_data2 sequoiadb/sequoiadb:latest
$ docker run -it -d --name sdb_data3 sequoiadb/sequoiadb:latest

查看四个容器的容器 ID

$ docker ps -a | awk ‘{print $NF}‘;

运行结果:

NAMES
sdb_data3
sdb_data2
sdb_data1
coord_catalog

查看四个容器的容器对应的 IP 地址

$ docker inspect coord_catalog | grep IPAddress |awk ‘NR==2 {print $0}‘
$ docker inspect sdb_data1 | grep IPAddress |awk ‘NR==2 {print $0}‘
$ docker inspect sdb_data2 | grep IPAddress |awk ‘NR==2 {print $0}‘
$ docker inspect sdb_data3 | grep IPAddress |awk ‘NR==2 {print $0}‘

四条命令的输出结果分别为各个容器自身的 IP 地址:

"IPAddress": "172.17.0.2",
"IPAddress": "172.17.0.3",
"IPAddress": "172.17.0.4",
"IPAddress": "172.17.0.5",

部署 SequoiaDB 集群

根据集群规划以及各个容器的 IP 地址,在对应参数填入各自的地址与端口号。

$ docker exec coord_catalog "/init.sh" \
--coord=‘172.17.0.2:11810‘ \
--catalog=‘172.17.0.2:11800‘ \
--data=‘group1=172.17.0.3:11820,172.17.0.4:11820,172.17.0.5:11820;group2=172.17.0.4:11830,172.17.0.5:11830,172.17.0.3:11830;group3=172.17.0.5:11840,172.17.0.3:11840,172.17.0.4:11840‘

该命令输出结果为:

Begin generating SequoiaDB conf file
Finish generating SequoiaDB conf file
Restarting sdbcm process, it will take 10 seconds
Deploy...
Execute command: /opt/sequoiadb/tools/deploy/../../bin/sdb -f /opt/sequoiadb/tools/deploy/quickDeploy.js -e ‘‘

**** Deploy SequoiaDB ****
Create catalog: 172.17.0.2:11800
Create coord: 172.17.0.2:11810
Create data: 172.17.0.3:11820
Create data: 172.17.0.4:11820
Create data: 172.17.0.5:11820
Create data: 172.17.0.4:11830
Create data: 172.17.0.5:11830
Create data: 172.17.0.3:11830
Create data: 172.17.0.5:11840
Create data: 172.17.0.3:11840
Create data: 172.17.0.4:11840

启动一个 MySQL 实例容器

$ docker run -it -d -p 3306:3306 --name mysql sequoiadb/sequoiasql-mysql:latest

查看启动容器的 ID

$ docker ps -a | awk ‘{print $NF}‘;

输出结果为包括 MySQL 实例在内的所有容器名:

NAMES
mysql
sdb_data3
sdb_data2
sdb_data1
coord_catalog

查看容器 IP 地址

$ docker inspect mysql | grep IPAddress | awk ‘NR==2 {print $0}‘

输出结果为 MySQL 实例的 IP 地址:

"IPAddress": "172.17.0.6",

将 MySQL 实例注册入协调节点

$ docker exec mysql "/init.sh" --port=3306 --coord=‘172.17.0.2:11810‘

输出结果为:

Creating SequoiaSQL instance: MySQLInstance
Modify configuration file and restart the instance: MySQLInstance
Restarting instance: MySQLInstance
Opening remote access to user root
Restarting instance: MySQLInstance
Instance MySQLInstance is created on port 3306, default user is root

本地登陆 MySQL 测试

$ mysql -h 127.0.0.1 -P 3306 -u root

可以得到 MySQL 连接成功的输出:

Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.7.25 Source distribution

Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type ‘help;‘ or ‘\h‘ for help. Type ‘\c‘ to clear the current input statement.

用户可以使用 MySQL 命令创建数据库与表:

mysql> create database sample;
Query OK, 1 row affected (0.00 sec)

mysql> use sample;
Database changed
mysql> create table t1 (c1 int);
Query OK, 0 rows affected (0.59 sec)

mysql> show table status;
+------+-----------+---------+------------+------+----------------+-------------+-----------------+--------------+-----------+----------------+-------------+-------------+------------+-------------+----------+----------------+---------+
| Name | Engine | Version | Row_format | Rows | Avg_row_length | Data_length | Max_data_length | Index_length | Data_free | Auto_increment | Create_time | Update_time | Check_time | Collation | Checksum | Create_options | Comment |
+------+-----------+---------+------------+------+----------------+-------------+-----------------+--------------+-----------+----------------+-------------+-------------+------------+-------------+----------+----------------+---------+
| t1 | SequoiaDB | 10 | Fixed | 0 | 0 | 0 | 8796093022208 | 131072 | 0 | NULL | NULL | NULL | NULL | utf8mb4_bin | NULL | | |
+------+-----------+---------+------------+------+----------------+-------------+-----------------+--------------+-----------+----------------+-------------+-------------+------------+-------------+----------+----------------+---------+
1 row in set (0.16 sec)

重置镜像

为方便用户重置已经创建了数据库节点的容器,用户可以使用 cleanup.sh 脚本进行本地容器的重置。

$ docker exec mysql /cleanup.sh
$ docker exec coord_catalog /cleanup.sh
$ docker exec sdb_data1 /cleanup.sh
$ docker exec sdb_data2 /cleanup.sh
$ docker exec sdb_data3 /cleanup.sh

结论

为方便用户快速试用 SequoiaDB 分布式数据库,用户可直接拉取 SequoiaDB 的 Docker 镜像创建一个分布式集群。

该集群仅为测试使用,不可直接应用于生产环境。

原文地址:https://blog.51cto.com/13722387/2421956

时间: 2024-08-02 03:13:06

SequoiaDB 巨杉数据库Docker镜像使用教程的相关文章

巨杉Tech|SequoiaDB 巨杉数据库高可用容灾测试

数据库的高可用是指最大程度地为用户提供服务,避免服务器宕机等故障带来的服务中断.数据库的高可用性不仅仅体现在数据库能否持续提供服务,而且也体现在能否保证数据的一致性. SequoiaDB 巨杉数据库作为一款100%兼容 MySQL 的国产开源分布式数据库,它在高可用方面的表现如何?它的高可用性是如何实现的?本文将详细描述SequoiaDB巨杉数据库的高可用性原理,并进行测试验证. 01 巨杉分布式集群架构 SequoiaDB 巨杉数据库采用计算与存储分离架构,SequoiaSQL-MySQL 是

SequoiaDB巨杉数据库携手民生银行分布式数据管理平台

日前,SequoiaDB巨杉数据库成功中选民生银行新一期"年度生产运营商业软件许可和服务采购"项目,再次携手推进分布式数据库管理平台建设.自从2014年正式和民生银行建立合作,巨杉数据库至今已经管理超过2PB的数据,节点数超过130台物理服务器,并已经在数据中台.分布式影像管理等多个核心业务系统.平台规模使用. 民生银行简介:民生银行是中国第一家主要由民营企业发起设立的全国性股份制商业银行,截至2017年末,中国民生银行已经成为资产总额59,020.86亿元,一级资本净额超过3800亿

新手福音:巨杉数据库教程专区上线啦!

作为一个程序员 在经历了种种"入门"之后- 你是不是曾经感到绝望? 没关系! 这次SequoiaDB"老司机" 真正带您"从入门到精通"! SequoiaDB巨杉数据库已经进入2.x时代,同时已经发布了2.6社区版.自此SequoiaDB巨杉数据库以优异的性能体验.前沿的发展趋势.本土的学习资源,成为最具学习价值的新一代分布式数据库.?巨杉斩获"中国十大开源软件",商业软件开源化得到企业级市场认可 在大量用户的使用过程中,我们

巨杉Tech | 使用 SequoiaDB 分布式数据库搭建JIRA流程管理系统

介绍 JIRA是Atlassian公司出品的项目与事务跟踪工具,被广泛应用于缺陷跟踪.客户服务.需求收集.流程审批.任务跟踪.项目跟踪和敏捷管理等工作领域.很多企业与互联网公司都在使用Jira作为内部流程管理系统,进行团队协作与问题单管理. JIRA的后台数据库可以选择使用嵌入式数据库或MySQL/PGSQL等专业数据库.一般来说,大部分企业选择MySQL作为底层的数据存储.但是,随着问题工单的不断积累,对于较大型企业来说MySQL所支撑的数据量可能很快达到瓶颈.用户可以选择使用SequoiaD

【巨杉数据库SequoiaDB】点燃深秋,巨杉数据库亮相DTC数据技术嘉年华大会

2019年11月15日,第九届数据技术嘉年华大会在北京隆重召开,本次大会以 "开源 ? 智能 ? 云数据 - 自主驱动发展 创新引领未来" 为主题,探索数据价值,共论智能未来.SequoiaDB 巨杉数据库作为领先的金融级分布式关系型数据库,为大家带来新一代分布式数据库的发展趋势和特性,也通过分享巨杉的丰富金融级实践经验,帮助大家充分了解分布式数据库当前的应用场景. ****分布式数据库发展趋势 在上午主会场的分享中,巨杉数据库联合创始人王涛,为大家带来了题为"新一代分布式数

【巨杉数据库SequoiaDB】巨杉Tech | 四步走,快速诊断数据库集群状态

1.背景 SequoiaDB 巨杉数据库是一款金融级分布式数据库,包括了分布式 NewSQL.分布式文件系统与对象存储.与高性能 NoSQL 三种存储模式,分别对应分布式在线交易.非结构化数据和内容管理.以及海量数据管理和高性能访问场景. 集群一般会使用三副本方式以确保数据安全.假若集群发生因硬件故障等原因导致的节点故障或集群异常,数据库管理员应进行系统的分析和诊断,以确保集群正常工作,不会影响用户的正常使用.本文将与大家分享一下基本的 SequoiaDB 数据库诊断方法. 数据库集群诊断 1)

【巨杉数据库SequoiaDB】企业级和开源领域“两开花”,巨杉引领国产数据库创新

2019年12月15日,OSC 源创会·年终盛典在深圳圆满举行.巨杉数据库作为业界领先的金融级分布式数据库厂商, 获得 "2019年开源数据库先锋企业" 及 "2019 GVP-Gitee最有价值开源项目" 两项殊荣. ? SequoiaDB 巨杉数据库始终坚持自研路线,并于2014年正式开源,是国内最早的开源数据库之一.经过8年的自主研发和技术发展,迭代发展出了技术领先.产品安全稳定.通用性强的金融级产品.今年 SequoiaDB 发布两个主要的版本,近期发布的3

巨杉数据库入选Gartner数据库推荐2017报告

SequoiaDB巨杉数据库入选Gartner数据库报告,成为国内首批入选Gartner报告的数据库厂商. "巨杉数据库SequoiaDB, 总部位于中国广州,是一款分布式.多模型(Multimodel).高可用的SQL数据库.巨杉数据库具有跨地域分布式部署和灵活扩展的能力,同时还支持针对内容和文件的块存储引擎.此外,SequoiaDB还支持基于Mpp分布式架构的数据分析操作.在我们的调研中,巨杉数据库"永远在线"的稳定性令人印象深刻,同时在企业级支持服务.开发应用友好度.性

巨杉数据库完成C轮数千万美元融资

业界领先的金融级分布式数据库公司,巨杉数据库近日宣布完成由嘉实投资领投的C轮融资.本轮的领投方为嘉实投资,启明创投与DCM作为早期投资方跟投.SequoiaDB巨杉数据库成立6年来一直坚持技术驱动产品,专注打造金融级分布式数据库,成为中国首次入选Gartner数据库报告的数据库厂商.目前,巨杉数据库付费企业级客户与社区用户总数超过1000家,并已在超过50家500强级别的银行.保险.证券等大型金融机构核心生产业务上线. 本轮投资方,嘉实投资管理公司CEO 仇小川表示:"巨杉数据库与阿里云成为首次