速来报名!AICon北京站鸿蒙专场~ 了解详情
写点什么

保姆级教程!手把手教你使用 Longhorn 管理云原生分布式 SQL 数据库!

  • 2020-05-25
  • 本文字数:4509 字

    阅读完需:约 15 分钟

保姆级教程!手把手教你使用Longhorn管理云原生分布式SQL数据库!

Longhorn 是 Kubernetes 的云原生分布式块存储,易于部署和升级,100%开源且持久,由业界采用最为广泛的 Kubernetes 管理平台创建者 Rancher Labs 推出,并于去年10月捐献给CNCF。Longhorn 的内置增量快照和备份功能可确保 volume 数据的安全,而其直观的 UI 可以方便地管理持久卷的计划备份。使用 Longhorn,你可以获得最细的管理粒度和最大的控制程度,并且可以轻松地在另一个 Kubernetes 中创建一个灾备恢复的 volume,并在发生紧急情况时进行故障转移。



云原生基础设施堆栈:计算、部署、管理、存储和数据库


YugabyteDB 是一个云原生分布式 SQL 数据库,它可以运行在 Kubernetes 环境中,所以它可以与 Longhorn 和许多其他 CNCF 项目互操作。YugabyteDB 是一个开源的高性能分布式 SQL 数据库,该数据库基于 Google Spanner 的可扩展性和容错设计而构建。Yugabyte 的 SQL API(YSQL)与 PostgreSQL 兼容。


如果你正在寻找一种方法来轻松地在 100%的云原生基础架构之上开始应用程序开发,那么这篇文章正是为你准备的。我们将一步一步告诉你如何部署一个完整的云原生基础架构堆栈,该堆栈由 Google Kubernetes Engine、Rancher 企业级 Kubernetes 管理平台、Longhorn 分布式块存储以及 YugabyteDB 分布式 SQL 数据库组成。

为什么要使用 Longhorn 和 YugabyteDB?

YugabyteDB 作为 StatefulSet 部署在 Kubernetes 上,并且需要持久存储。Longhorn 可用于备份 YugabyteDB 本地磁盘,从而允许配置大规模持久卷。将 Longhorn 和 YugabyteDB 结合使用,有以下好处:


  • 不必管理本地磁盘——它们由 Longhorn 进行管理

  • Longhorn 和 YugabyteDB 可以配置大规模的持久卷

  • Longhorn 和 YugabyteDB 都支持多云部署,可以帮助企业避免云厂商锁定


此外,Longhorn 可以在一个地理区域内进行同步复制。如果 YugabyteDB 跨区域进行部署并且其中任意一个区域中的节点发生故障,那么 YugabyteDB 只能使用来自另一区域的数据重建该节点,这会产生跨区域流量。而这会导致成本更改,并且会降低所恢复的性能。而将 Longhorn 与 YugabyteDB 结合使用,你可以无缝地重建该节点,因为 Longhorn 会在该区域内进行本地复制。这意味着 YugabyteDB 最终不必从另一个区域复制数据,进而降低了成本并提升了性能。在此部署设置中,如果整个区域发生故障,YugabyteDB 仅需执行一个跨区域节点重建。

前期准备

我们将在已经使用了 Longhorn 的 Google Kubernetes 集群上运行 YugabyteDB 集群:


在谷歌云平台上设置一个 K8S 集群和 Rancher

Rancher 是一个开源的企业级 Kubernetes 管理平台。它使得 Run Kubernetes Everywhere 更为轻松和简单,满足 IT 人员的需求并增强 DevOps 团队的能力。


Rancher 需要 64 位的 Ubuntu16.04 或 18.04 和至少 4GB 内存的 Linux 主机。在此示例中,我们将使用安装在 GCP VM 实例上的 Rancher UI 设置 Google Kubernetes Engine(GKE)集群。


使用 Rancher 在 GCP 上设置 Kubernetes 集群所需的步骤包括:


  • 在 GCP 中创建一个具有所需 IAM 角色的 Service Account

  • 创建一个运行 Ubuntu 18.04 的 VM 实例

  • 在 VM 实例上安装 Rancher

  • 生成一个 Service Account 密钥

  • 通过 Rancher UI 设置 GKE 集群

创建一个 Service Account 和 VM 实例

首先,我们需要创建一个附加到 GCP 项目的 Service Account。要完成此操作,访问路径是:【IAM & admin > Service accounts】



选择【Create New Service Account】,给其命名并点击【Create】。


接下来,我们需要添加所需的角色到 Service Account 以便能够使用 Rancher 设置 Kubernetes 集群。添加下面显示的角色并创建 Service Account。


角色添加完成之后,点击【Continue and Done】。


现在我们需要创建一个 Ubuntu VM 实例,它将会被托管在 GCP 上。执行路径为:【Compute Engine > VM Instances > Create New Instance】




出于本次 demo 的目的,我选择了 n1-standard-2 机器类型。选择 Ubuntu 镜像,需要点击【Boot Disk > Change】并且在操作系统的选项中选择 Ubuntu,版本选择 Ubuntu 18.04 LTS。



需要检查一下是否允许 HTTPS 流量,检查路径为【Firewall > Allow HTTPS traffic】



使用以上设置创建 VM 实例仅需几分钟。创建完成后,使用 SSH 连接到 VM。在将 terminal 连接到 VM 的情况下,下一步是通过执行以下命令来安装 Rancher:


$ sudo docker run -d --restart=unless-stopped -p 80:80 -p 443:443 rancher/rancher
复制代码


注意:如果没有找到 Docker,请按照以下说明在 Ubuntu VM 上安装它:


https://www.digitalocean.com/community/tutorials/how-to-install-and-use-docker-on-ubuntu-18-04

创建 GKE 集群

要访问 Rancher server UI 并创建登录名,请打开浏览器并转到安装它的 IP 地址。


例如:https://<external-ip>/login



注意:如果你在尝试访问 Rancher UI 时遇到任何问题,请尝试使用 Chrome Incognito 模式加载页面或禁用浏览器缓存。


按照提示创建一个新帐户。



创建帐户后,请转到 https://<external-ip>/g/clusters。然后单击【Add Cluster】以创建 GKE 集群。



选择 GKE 并给集群命名。


现在我们需要从之前创建的 GCP Service Account 中添加私钥。可以在【IAM & admin > Service Accounts > Create Key】下找到。



这将生成一个包含私钥详细信息的 JSON 文件。



复制 JSON 文件的内容到 Rancher UI 中的 Service Account 部分并单击【Next】。



考虑到本教程的目的,我选择了 n1-standard-4 机器类型,打开了【Node Pool Autoscaling】,并将最大节点数设置为 24。单击【Create】。



通过确保将集群的状态设置为 Active 来验证是否已创建集群。请耐心等待,这将需要几分钟的时间。



还可以通过转到【Kubernetes Engine>Clusters】从 GCP 项目访问该集群。


在 GKE 上安装 Longhorn

Rancher 安装完成后,我们可以使用其 UI 来在 GKE 集群上安装和设置 Longhorn。


单击该集群,在本例中为 longhorn-demo,然后选择【System】。



接下来点击【Apps>Launch】,搜索 Longhorn,并点击该卡片。



给 deployment 命名,也可以使用默认名称,然后点击【Launch】。安装完成后,你可以通过点击/index.html 链接来访问 Longhorn UI。



验证是否已安装 Longhorn,并且 GKE 群集节点是否可见。


使用 Helm 在 GKE 集群上安装 YugabyteDB

下一步是在 GKE 集群上安装 YugabyteDB。可以通过执行以下链接中的步骤来完成:


https://docs.yugabyte.com/latest/deploy/kubernetes/helm-chart/


以下将概述这些步骤:


验证并升级 Helm


首先,通过使用 Helm 版本命令来检查 Helm 是否已经安装:


$ helm version


Client: &version.Version{SemVer:"v2.14.1", GitCommit:"5270352a09c7e8b6e8c9593002a73535276507c0", GitTreeState:"clean"}
Error: could not find tiller
复制代码


如果你遇到与 Tiller 相关的问题,例如上述错误,则可以使用升级选项初始化 Helm:


$ helm init --upgrade --wait


$HELM_HOME has been configured at /home/jimmy/.helm.
Tiller (the Helm server-side component) has been installed into your Kubernetes Cluster.
Please note: by default, Tiller is deployed with an insecure 'allow unauthenticated users' policy.
To prevent this, run `helm init` with the --tiller-tls-verify flag.
For more information on securing your installation see: https://docs.helm.sh/using_helm/#securing-your-helm-installation
复制代码


根据以下文档,你应该能够使用 Helm chart 来安装 YugabyteDB:


https://docs.yugabyte.com/latest/deploy/kubernetes/single-zone/oss/helm-chart/

创建一个 Service account

在创建集群之前,你需要有一个 service account,它应该被授予集群管理员的角色。使用以下命令创建一个 yugabyte-helm service account,并授予 cluster-admin 的集群角色。


$ kubectl create -fhttps://raw.githubusercontent.com/yugabyte/charts/master/stable/yugabyte/yugabyte-rbac.yaml


serviceaccount/yugabyte-helm created
clusterrolebinding.rbac.authorization.k8s.io/yugabyte-helm created
复制代码

初始化 Helm

$ helm init --service-account yugabyte-helm --upgrade --wait


$HELM_HOME has been configured at /home/jimmy/.helm.


Tiller (the Helm server-side component) has been upgraded to the current version.
复制代码

创建一个命名空间

$ kubectl create namespace yb-demo


namespace/yb-demo created
复制代码

添加 chart 镜像仓库

$ helm repo add yugabytedb https://charts.yugabyte.com


"yugabytedb" has been added to your repositories
复制代码

从镜像仓库中获取更新

$ helm repo update


Hang tight while we grab the latest from your chart repositories...
...Skip local chart repository
...Successfully got an update from the "yugabytedb" chart repository
...Successfully got an update from the "stable" chart repository
Update Complete.
复制代码

安装 YugabyteDB

我们将使用 Helm chart 来安装 YugabyteDB 并且将使用 Load Balancer 公开 UI 端点和 YSQL、Yugabyte SQL API。此外,我们将在资源不足的环境中使用 Helm 资源选项,并指定 Longhorn 存储类。这将需要一段时间,需要耐心等待。你可以在文档中找到关于 Helm 的详细说明:


https://docs.yugabyte.com/latest/deploy/kubernetes/gke/helm-chart/


$ helm install yugabytedb/yugabyte --set resource.master.requests.cpu=0.1,resource.master.requests.memory=0.2Gi,resource.tserver.requests.cpu=0.1,resource.tserver.requests.memory=0.2Gi,storage.master.storageClass=longhorn,storage.tserver.storageClass=longhorn  --namespace yb-demo --name yb-demo --timeout 1200 --wait
复制代码


执行以下命令以检查 YugabyteDB 集群的状态:


$ helm status yb-demo
复制代码


你还可以通过访问 GKE 的“Services & Ingress and Workloads”页面来验证是否已安装所有组件并进行通信。


你也可以通过访问端口 7000 上 yb-master-ui 服务的端点来查看管理 UI 中的 YugabyteDB 安装。



你还可以通过执行以下命令登录到 PostgreSQL 兼容的 shell:


kubectl exec -n yb-demo -it yb-tserver-0 /home/yugabyte/bin/ysqlsh -- -h yb-tserver-0.yb-tservers.yb-demo


ysqlsh (11.2-YB-2.0.12.0-b0)
Type "help" for help.
yugabyte=#
复制代码


现在,你可以开始创建数据库对象和处理数据了。

使用 Longhorn 管理 YugabyteDB volume

接下来,重新加载 Longhorn dashboard,以验证 YugabyteDB volume 已正确设置。Volume 的数量现在应该处于可见状态:



单击【volume】以管理 volume。各个 volume 应该可见。



现在可以通过选择它们以及所需的操作来管理 volume。



就是它!现在,你已经可以在有 Longhorn 作为分布式块存储的 GKE 上运行 YugabyteDB 了!


原文链接:

https://rancher.com/blog/2020/yugabyte


作者简介


Jimmy Guerrero,在开发者关系团队和开源社区拥有 20 多年的经验。他目前领导 YugabyteDB 的社区和市场团队。


2020-05-25 16:412001

评论

发布
暂无评论
发现更多内容

用好这28个工具,开发效率爆涨|云效工程师指北

阿里云云效

云计算 阿里云 云原生 研发工具 研发

布局说明 - 大屏云极简使用手册

shulinwu

可视化 数据可视化 大屏可视化 智慧大屏可视化 大屏

实践GoF的23种设计模式:SOLID原则(上)

华为云开发者联盟

设计模式 GoF SOLID SOLID原则 分布式应用系统

ironSource 新功能发布,开发者可在同一会话中实时调整广告策略

Geek_2d6073

Python 中 base64 编码与解码

AlwaysBeta

Python 程序员 编程语言 base64

C++学习网站

C语言与CPP编程

c++

应用数仓ODBC前,这些问题你需要先了解一下

华为云开发者联盟

数据库 GaussDB(DWS) 驱动 ODBC 驱动管理器

BFS/DFS/DP 算法案例 LeetCode题目:传递信息

OpenHacker

LeetCode 动态规划 深度优先搜索 算法解析 广度优先搜素

星环科技ArgoDB 3.2正式发布,全面升级易用性、性能和安全

星环科技

数据库

HertzBeat赫兹跳动v1.0.beta.4 发布, 易用友好的高性能监控告警系统

TanCloud探云

开源 APM 监控 监控系统 监控告警

Android包体积优化上篇- 资源混淆优化

百度Geek说

百度 前端 后端 优化 包体积

用 python selenium 爬简书,Python自动化领域之 Selenium WebDriver 学习第2篇

梦想橡皮擦

Python 3月月更

赋能金融领域,国密改造让安全合规更加牢固

电子信息发烧客

安全

虎符研究院关于 Manta Network平行链解决方案的分享

区块链前沿News

虎符交易所 币圈后浪

【案例】基于星环科技数据云平台TDC为富国基金建设万能的数据湖

星环科技

数据库

Web 键盘输入法应用开发指南 (2) —— 键盘事件

天择

JavaScript 键盘 输入法 3月月更

融云 IM 在 Electron 平台上的设计实践

融云 RongCloud

数据系统提供商极道科技加入龙蜥社区

OpenAnolis小助手

Linux 开源 数据系统

易观分析对《关于银行业保险业数字化转型的指导意见》的解读

易观分析

银行 数字化

新思科技最新报告显示97%的应用存在漏洞

InfoQ_434670063458

新思科技 应用安全

教你如何使用flask实现ajax数据入库

华为云开发者联盟

Python 数据库 flask 文件上传 ajax数据

跨团队协作:提高团队生产力的 7 种策略

小炮

团队管理 知识管理 团队协作 办公效率

一文带你看懂HarmonyOS应用上架

HarmonyOS开发者

HarmonyOS 应用开发

“碳中和”背后的创新科技!

青云技术社区

云计算 碳中和

组件简介 - 大屏云极简使用手册

shulinwu

数据可视化 大屏可视化 智慧大屏可视化 大屏

阿里云智能编码插件,更Cosy的开发体验

阿里云云效

Java 阿里云 程序员 开发 研发

低代码平台设计探索,如何更好赋能开发者

雯雯写代码

低代码 开发平台 开发者,

Nebula Graph 的 KV 存储分离原理和性能测评

NebulaGraph

图数据库 分布式图数据库

墨天轮国产数据库沙龙 | 许力:阿里云原生Lindorm TSDB数据库,驱动工业IT&OT超融合数字化系统升级

墨天轮

数据库 阿里云 tsdb

数据可视化大屏 - 大屏云极简使用手册

shulinwu

可视化 数据可视化 大屏可视化 智慧大屏可视化 大屏

活动预告 | DataOps + MLOps Meetup

第四范式开发者社区

人工智能 机器学习 开源 DevOps MLOps

保姆级教程!手把手教你使用Longhorn管理云原生分布式SQL数据库!_文化 & 方法_Rancher_InfoQ精选文章