云上数据库:从零到壹的实践经验分享
零:前言 云原生时代已经到来,虚竹哥今天分享一下,不同的数据库上云的实战经验。 一、背景 随着各行各业业务数据量的不断增加和数据类型的复杂化,需要使用多种数据库来存储数据。然而,这些行业也面临着无法弹性扩缩容和高昂的运维成本等问题。 客户的数据库主要采用以下三种部署方式: • 本地数据库:使用传统的本地数据库部署方式,在IDC机房中部署数据库,而不是使用公有云服务; • 云ECS部署数据库:为了降低成本并优化架构设计,选择将数据库部署在云厂商的服务器上,而不是使用云数据库服务。 • 云数据库服务:为了提高数据的可靠性和安全性,可扩展性和灵活性,向云厂商直接购买云数据库服务。 1.1、痛点 • 业务上线速度慢:无论是本地数据库还是ECS自建数据库,都需要用户自己安装软件,自行解决补丁升级、高可用等问题,非常耗时; • 无法弹性扩缩容:无法根据业务需求进行快速变更,比如在流量增长后,自建数据库无法做到快速升级配置,可能流失潜在客户,流量高峰回落后,又无法做到快速降配,造成资源浪费; • 运维人力成本高:自建数据库需要用户自行解决所有数据库日常运维问题,实例数量达到一定程度后,管理非常困难,DBA人力成本高昂; • 安全防护问题多:自建数据库需要自行下载安装包,可能会被植入木马病毒,对数据库造成威胁;无灾备机制,需自行解决安全防护问题;缺少专业团队为数据库提供安全保障。 1.2、解决方案 数据库上云! 数据库上云! 数据库上云! 核心优点 弹性伸缩,部署灵活 弹性伸缩:云数据库即开即用,可弹性伸缩,规格可升可降,让企业灵活掌握资源投入; 按需付费:资源按需付费,随业务需求快速扩容,灵活部署,帮助客户从容应对业务量增长带来的资源紧张、响应速度慢等问题。 智能运维,降本增效 智能运维:相对客户原有自建数据库,云数据库在备份、添加只读、监控告警等更加方便; 降低运维成本:让DBA有时间专注应用优化等更有价值业务,降低DBA运维成本。同时,华为云具备专业的数据中心运维团队,让企业专注发展业务; 减轻企业负担:企业无需耗费长时间搭建IDC,无需高昂的一次性投入,无需担心设备折旧问题。 灾备完善,安全可靠 完善的灾备机制华为云数据库具备主备、两地三中心灾备、回收站、安全组等机制设计,大大提高数据库的安全性与可靠性; 严守数据中立:华为云不用技术手段非法获取客户数据,不对客户数据进行商业变现; 专注基础设施:华为云专注打造云基础设施服务,助力企业数据库上云,自主掌握核心数据; 数据中心稳定:T4级别机房,最高支持3AZ高可靠,满足客户高安全需求,所有数据3副本存储,跨机房跨区域保存; 安全防护丰富:提供WAF/DDoS等10+安全服务,保障业务安全。 更高可用,更强性能 云数据库性能更强:与自建单机数据库相比,主备、分布式架构的云数据库性能更加强大,满足大数据量需求。 下面以华为云的几款不同的数据库产品为例,分享下从零到壹数据库上云。 二、MySQL上云 云数据库RDS for MySQL是一种关系型数据库管理系统,RDS for MySQL性能卓越,搭配LAMP,成为WEB开发的高效解决方案。 2.1、优点 超高性能,极致体验 优质硬件:华为经过多年的研究、创新和开发的服务器硬件,稳定、高性能。 SQL优化:提供慢SQL检测,并给出对应的优化建议。 高速访问:搭配同一地域的弹性云服务器,通过内网通信,缩短应用响应时间,并节省公网流量费用。 更低成本,更多服务 使用华为云数据库RDS for MySQL,只需支付RDS for MySQL实例费用,无需购买和安装任何软硬件,简化运维操作。与之相比,使用自建数据库则需要付出服务器、系统、数据库等软硬件费用+机房托管费用+运维操作成本。 全系列高安全认证,数据库安全无忧 访问控制:入站、出站规则进行限制,控制可以连接数据库的网络范围。 安全防护:处于多层防火墙的保护之下,可以有力地抗击各种恶意攻击,保证数据安全。 数据加密:通过TLS加密、SSL加密实现传输加密。通过静态加密、表空间加密对数据进行加密。 操作审计:云审计服务,记录与云数据库RDS实例相关的操作事件。 多种部署及容灾方案,满足多种可用性需求 双机热备:云数据库RDS服务采用热备架构,故障秒级自动切换。 异地容灾:可以在异地区域使用备份文件在异地恢复到新的RDS实例,用来恢复业务。 同城容灾:支持多可用区部署,可用区之间内网互通,不同可用区之间电力、网络物理隔离。 强大扩展能力,满足不同阶段业务需求 丰富的产品规格:提供单机、主备、只读实例,一键单机转主备。 弹性扩容:支持增删只读实例,及时应对业务暴涨/回落情况。 多种配置:通用型(通过资源复用换取CPU使用率最大化,性价比较高)、独享型(完全独享CPU和内存,性能长期稳定)。 丰富的运维工具,助力聚焦核心业务 备份恢复:支持按备份集和指定时间点的恢复,732天自动备份恢复,数据不丢失。 智能运维:全方位对数据库进行智能监控与诊断优化。 监控报警:自定义监控目标与通知策略,及时了解云数据库RDS for MySQL服务运行状况。 差异化优势 性价比:优异产品性能,确保领先或持平业界,且价格上更具竞争力; 可为单机实例添加只读实例,可以满足非核心业务的多读需求; 支持秒级监控,包括1秒监控和5秒监控,用于提高监控指标的瞬时精确值; 支持查看参数模板所应用到实例的记录。 2.2、适用场景 针对电商客户 云数据库RDS for MySQL为电商和移动商务应用提供可靠、经济、高效的数据存储,使应用在网络上快速安全运行; 服务价值 RDS for MySQL可帮助客户有效管理用户、充值支付、账单等关键数据,快速进行规格变更应对流量洪峰; 针对游戏客户 云数据库RDS for MySQL凭借其高可靠、高性能等特性,能帮助客户轻松部署移动在线游戏服务; 服务价值 RDS for MySQL可帮助客户有效管理用户、充值、支付、账单、购物车等数据; 针对物联网IoT客户 规模和可靠性至关重要,需要云数据库提供快速的响应时间来支持大量的连接; 服务价值 云数据库RDS for MySQL提供了高吞吐量和高并发性,可以通过快速的响应来支持大量的连接; 针对电子政务客户 电子政务面临服务数十亿人次的潜在规模的挑战,需要高性能,高吞吐量和高可用的云服务。 服务价值 高性能、高吞吐量、高可用的云数据库RDS for MySQL可帮助客户轻松应对潜在用户规模的挑战。 2.3、购买体验
先注册登录华为云帐号。 登录管理控制台并单击“购买数据库实例”。
按需购买哈 本次虚竹哥为了学习,买了单机版,4核8g,建议连接数是2500的。
注:企业的生产数据库,要用 主备 的实例类型(一主一备的经典高可用架构)。 设置网络:
设置root账号的密码
最后一步,买买买。 2.4、连接体验 绑定弹性公网IP 选择买的实例,单击实例名称,进入实例的“基本信息”页面。
选择弹性公网IP,单击“是”,提交绑定任务。
这样就绑定成功了。 设置安全组规则 选择买的实例,单击实例名称,进入实例的“基本信息”页面。
左侧导航栏,单击“连接管理”,在“安全组规则”模块“当前安全组”处,单击安全组名称,进入安全组页面。
可添加入方向规则和出方向规则。
通过公网连接RDS for MySQL实例 使用客户端navicat
密码是购买时,设置的密码。 测试连接。
接下来连接上的操作与本地操作一样。 三、Redis上云 云数据库GaussDB(for Redis)作为华为云旗下企业级Redis,致力于为企业客户提供稳定可靠、超高并发,且能够极速弹性扩容的核心数据存储服务。GaussDB(for Redis)采用云原生分布式架构,完全兼容Redis协议,支持丰富的数据类型,提供数据实时持久化、多副本强一致保障,以及实时监控、弹性伸缩、自动备份等一站式服务。 3.1、优点 高可用 某个节点发生故障,可以在秒级内完成接管,即使N-1节点同时发生故障,只要还有1个实例可用,业务依然可以正常运行,最大程度减少对业务的影响; 高吞吐 多节点可以同时写入,且采用多线程架构,吞吐轻松翻倍,QPS可水平扩展,有效扛住流量高峰; 强一致 通过GaussDB基础组件服务实现数据三副本冗余,确保0丢失,同时满足多点访问强一致性要求,业务设计更轻松; 大容量 采用计算、存储分离架构,全面支持大数据量场景,产品定位突破“缓存”局限,能帮业务长期承载更多重要数据; 秒扩容 以1GB粒度随时按需调整,秒级生效。GaussDB基础组件服务实现了存储平滑伸缩,业务0感知; 降成本 相比纯内存架构,硬件成本降低75%~90%,容量几乎全部可用,并且可按1GB细粒度购买,不会买多浪费。 差异化优势 • 高可靠——数据0丢失,强一致,性能稳定 • 低成本——价格节省75%,容量更大 • 弹性伸缩——平滑扩容,秒级体验 • 安全运维——专业云服务,一站式运维 • 单节点支持最大1TB,可对数据做持久化存储,保证数据强一致存储 • 通过安全组限制源端IP对实例的访问权限,可以细化到端口 • 可通过控制台对访问账号的权限进行设置和管理 • 客户可以在控制台自定义设置备份文件留存时间,最长保留周期为35天,满足金融客户监管需求 • 客户可以在控制台实现实例重启,修改某些运行参数 3.2、适用场景 针对电商客户 在大促活动期间会出现大量并发访问,而商品搜索又存在热门商品和冷门商品并存的状况,同时对数据一致性有较高要求; 服务价值 使用GaussDB(for Redis)作为前端缓存(需要配置大内存),可缓解后端数据库压力,平稳渡过业务高峰;同时,将热门商品信息作为热数据驻留在内存中,冷门商品信息置换到共享存储池中,可进一步降低数据库压力;此外,强一致counter让秒杀活动不再“雪崩”,库存扣减不再担心“超卖”,还可以用sorted set帮助构建spam机制,用geo实现物流跟踪; 针对游戏客户 存在一些对时延非常敏感的场景,如跨服对战,同时需要打造敏捷迭代、功能完备的游戏系统; 服务价值 GaussDB(for Redis)提供丰富的数据类型,帮助客户构建自己的游戏系统。如用sorted set搭建实时排行榜、用pub/sub实现即时聊天室;部署动态服用于更新玩家发布的“朋友圈”,部署账号服用于保存基本用户信息,部署好友服用于持久化存储海量、复杂的玩家关系网。此外,使用GaussDB(for Redis)作为前端缓存(需要配置大内存),可加快应用访问速度,帮助降低时延; 针对物联网IoT客户 需要高可靠、高可用、高性能的数据库,保障业务稳定发展,防止出现阻塞问题。 服务价值 例如多城市车辆充电平台,往往需要管理分布在极大范围的端点设备,为了让更多终端轻松互联、安全管理,可以借助GaussDB(for Redis)构建高并发的任务调度系统、端设备监控以及更多边缘计算能力。 3.3、购买体验
先注册登录华为云帐号。 登录管理控制台并选择云数据库GaussDB(for Redis)。
按需购买哈,这里虚竹哥选购的是2核24GB的
选择网络:
设置密码:
最后一步,买买买。 3.4、连接体验 获取Redis客户端:
解压客户端工具包:
连接实例:
出现如下信息,说明连接成功:
四、InfluxDB上云 GaussDB(for Influx) 是一款采用计算存储分离架构,兼容InfluxDB生态的云原生时序数据库。提供高性能读写、高压缩率、冷热分层存储以及弹性扩容、监控告警等服务能力。适用于运维、物联网、工业生产等监控应用场景。 4.1、优点 极致性能 亿级时间线数据管理,轻松支撑每天万亿记录写入,聚合查询性能卓越。 海量数据分析 支持多维条件组合查询,更有聚合分析、时序洞察特性,提供全场景支持。 低成本存储 列式存储,自适应压缩算法,自动冷热分级存储,存储成本低。 极致弹性 计算和存储可以独立按需扩容,无需迁移数据,急速完成数据库集群扩缩容。 4.2、适用场景 针对物联网IoT客户 IoT传感器时序数据分析,助力万物互联。 服务价值 • 超强写入:小批量写入场景性能为开源版本InfluxDB的4.5倍,大批量写入场景性能为开源版本InfluxDB的3.3倍 • 多维度分析:支持多维条件组合查询,对海量数据分析得心应手 • 弹性扩展:基于计算存储分离的分布式架构,分钟级计算节点扩容,应对业务高峰期 针对应用运维监控 统一应用运维实时监控,全局把控系统运行状态。 服务价值 • 海量数据支持:支持每天万亿条监控指标写入,写入性能线性扩展 • 异常检测:支持多种时序异常类型的检测告警,异常可视化直观展示,方便运维人员识别异常,告警策略设置简单,无需机器学习知识背景 • 智能预测:采用多维时序预测算法,利用多指标间关联关系提高预测准确度,相比传统预测算法准确度更高 4.3、购买体验
先注册登录华为云帐号。 登录管理控制台并选择GaussDB(for Influx)。
按需购买哈,虚竹哥选购的是4核16的。
网络设置和密码设置:
最后一步,买买买。 4.4、连接体验 通过Java语言连接实例: pom.xml依赖添加:
使用SSL方式连接实例的Java代码示例:
使用非SSL方式连接实例的Java代码示例:
使用连接池方式连接实例的Java代码示例:
#FormatImgID_35# 五、文档数据库上云 华为云文档数据库服务(document Database Service,简称DDS)完全兼容MongoDB协议,提供安全、高可用、高可靠、弹性伸缩和易用的数据库服务,支持分片集群(Sharding)、副本集(ReplicaSet)和单节点三种部署架构,同时提供一键部署、弹性扩容、容灾、备份、恢复、监控和告警等功能。 5.1、优点 实例类型灵活多样 文档数据库服务DDS支持集群实例、副本集实例、单节点实例等多种实例类型,能够满足不同业务场景需求; 弹性伸缩灵活配置 文档数据库服务DDS提供了变更实例存储空间、节点数量、CPU和内存规格的功能,客户可以根据业务需要灵活配置所需资源; 灵活管理可视可控 管理控制台提供全面的监控信息,简单易用,灵活管理,可视可控; 多层数据安全保障 通过虚拟私有云、子网、安全组、存储加密、DDoS防护以及SSL安全访问等多层安全防护体系,有力抗击各种恶意攻击,保障数据安全;提供审计日志功能,记录客户对数据库或集合执行的操作,帮助客户对数据库进行安全审计、故障根因分析等操作;支持细粒度权限,实现精细的权限管理; 丰富工具简化运维 在备份和恢复方面,支持全量备份、增量备份,副本集支持任意时间点备份恢复,备份数据最多可保存732天;在监控报警方面,可实时监控实例运行的指标,用户可自定义监控目标与通知策略,及时了解数据库服务的运行情况。 差异化优势 1、支持单节点部署,解决无高可用需求的测试场景,节省资源成本; 2、支持用户设置跨区域备份策略,包含开启/关闭,备份区域,以及备份保留时长; 3、实例支持可用区迁移:解决用户AZ级别的容灾问题; 4、提供错误日志展示和下载功能; 5、支持租户使用自己在KMS服务上上传的密钥对DDS数据进行静态加密,提高数据安全性,部分金融、外企有加密需求,并且是上云必备门槛; 6、只读复制延迟:客户可以在控制台设置只读节点的复制延迟时间,在紧急情况下(误删数据)通过延迟的只读节点快速找回数据。 5.2、适用场景 针对大型企业和互联网客户 往往需要应对TB级数据,有较强的数据存储需求。且大数据场景下,还需要满足业务在线数据实时写入数据库、大数据计算分析、分析结果反馈等实时查询、动态分析的需求。 服务价值 DDS的副本集模式采用三节点Replica Set的高可用架构,三个数据节点组成一个反亲和组,部署在不同的物理服务器上,自动同步数据。Primary节点和Secondary节点提供服务,两个节点分别拥有独立内网地址,配合Driver实现读取压力分配。不仅可以满足大型企业和互联网行业客户对海量数据存储的需求,还能解决数据分析场景需求。 针对游戏客户 在游戏应用中,游戏玩家活跃高峰期,对并发能力要求较高,同时随着业务发展,在游戏玩法变化时可能还需要变更表结构,运维难度和工作量较大; 服务价值 可以将一些用户信息,如用户装备、用户积分等存储在DDS数据库中,使用DDS的集群类型,应对高并发场景;DDS副本集和集群架构的高可用特性,能够满足游戏在高并发场景下持续稳定运行的需求;另外,DDS兼容MongoDB,具有No-Schema的方式,能免去客户在游戏玩法变化中需要变更表结构的痛苦,非常适用于灵活多变的游戏业务需求;客户可以将模式固定的结构化数据存储在云数据库RDS中,模式灵活的业务存储在DDS中,高热数据存储在GaussDB(for Redis)里,实现对业务数据高效存取,降低存储数据的投入成本; 针对物联网IoT客户 IoT智能终端往往需要进行多样化的数据采集,且需要存储设备日志信息,并对这些信息进行多维度分析。同时,IoT业务增长快、数据量大、访问量增长迅速,数据存储需要具备水平扩展能力; 服务价值 DDS兼容MongoDB,具有高性能和异步数据写入功能,特定场景下可达到内存数据库的处理能力。同时,DDS中的集群实例,可动态扩容和增加mongos和shard组件的性能规格和个数,性能及存储空间可实现快速扩展,非常适合IoT的高并发写入的场景; 5.3、购买体验
先注册登录华为云帐号。 登录管理控制台并选择DDS。
按需购买哈,虚竹哥选购的是,副本集,4核8G的。
网络设置:
最后一步,买买买。 5.4、连接体验
Java示例(无证书连接): 通过Java连接集群实例时,代码中的Java链接格式如下:
参数说明:
总结 本文分享的内容比较多,从游戏、电商、社交等泛互联网行业的现状和痛点进行分析,主要涉及的问题是:业务上线速度慢、无法弹性扩缩容、运维人力成本高和安全防护问题多。虚竹哥建议解决方案是:数据库上云! 数据库上云的核心优点主要有4个方面: • 弹性伸缩,部署灵活 • 智能运维,降本增效 • 灾备完善,安全可靠 • 更高可用,更强性能 通过本文的学习,可以对数据库上云有一定的了解和实操经验。 除了理论方面的分享,文中还介绍了多个不同数据库类型的上云实践分享。主要数据库有:云数据库RDS for MySQL,云数据库GaussDB(for Redis),GaussDB(for Influx) 和华为云文档数据库服务(document Database Service,简称DDS)。从优点到适用场景,到购买体验和连接体验详细介绍一番。 通过本文的学习,可以对数据库上云有一定的了解和实操经验。目前正值华为云618营销季,云数据库新用户首单0.8折起,RDS for MySQL单机版 4核8G3个月仅需96元、GaussDB(for Redis)114.8元/年、GaussDB(for Influx) 265.28元/年,更有新用户文档数据库服务DDS首月免费用等超值福利,让数据库轻松上云!有需要的朋友尽快去华为云官网看看吧。
(华为云618营销季,让数据库轻松上云) 哈哈,我是虚竹哥,我们下文见~【作者:小虚竹】 |