当前位置: 首页 > article >正文

数据库真的是能够决定架构的

在今天什么都是架构

从招聘网站中还能看到Java架构师、PHP架构师.NET架构师等等。我不否认每个都有自己的架构,但是我觉得这些都应该是应用架构。

我接触到不少架构师是Java出身,然后也懂操作系统,也知道一点数据库,也懂中间件。只是喜欢简单问题复杂化,动不动就是Redis、Mongodb、Kafka、RabbitMQ、NGINX等等。再就是DataX的数据同步。确实全面覆盖了。

但是没有从数据库–数据架构的角度去考虑

举一个例子,我和开发说你这个报表写的不太好,要么你到从库执行? 这时候开发说,我这个查出来以后要做数据的更新,也就是说要有写的动作。这个怎么解决?在开发思维中从库是不可以写的。

从库是不是不可以写?未必。

举例来书Oracle的ADG从库是不可以写入的。但是严谨一点的话,在19C的版本中DML重定向以后是可以写入的。而且可以保证数据一致性。当我说到这里,开发不明白,问到你能识别哪个是select那个是update吗?

我回答没必要知道,你所有请求都到从库上,数据库给你解决。

开发依然不明白,那么架构呢?我说数据库都给你做了。

开发依然不明白,不是读写分离是架构的事情吗?我说数据架构也是架构。

其实不仅仅是Oracle。那么MySQL的Innodb CLuster 就是Router+MGR这样,也没有需要应用架构师做什么工作。数据库自己的组件全解决了。这里更加不要说RAC这种对应用全透明的架构。

也许有些人不喜欢这样的,因为数据库全做了,他就没什么可做的。无法凸显。但是我觉得好的数据库就是提供了友好的功能让大家架构简单。

其他的数据库也是有类似的,我就不一一点名其他的数据库了。

数据库趋势之一-HTAP

天下苦Hadoop久已,凡是运维过Hadoop的都有自己的苦楚。至少我没听到过说运维Hadoop一个字:爽。没有,从来没有。
但是我听过运维ExaData的人说,爽。

OLTP到OLAP就一个实时性和准确性就能要了运维的半条命。而如果几乎头部的数据库公司都有自己的HTAP解决方案。

这是什么?这就是架构,再也不用Kafka、DataX、CDC、以及哪怕宣称最稳定的OGG了。

Hadoop全家桶也是架构,但是不友好。

就像前面开发人员说的,你能分得清select那个是update吗?那么我们在业务系统中能要求,这里只能点查,那里不能聚合吗?不方便的。

如果从数据库角度出发,整个架构就会很清楚

试想当你系统的数据库缩减到几套的时候,架构就会很简单。用数学的思维看,当只有一套时候。那就没什么架构了。大道至简!


http://www.kler.cn/a/373247.html

相关文章:

  • flutter在使用gradle时的加速
  • 【机器学习】制造业转型:机器学习如何推动工业 4.0 的深度发展
  • DAMA CDGA 备考笔记(二)
  • AWS云计算概览(自用留存)
  • 在AI智能中有几种重要的神经网络类型?6种重要的神经网络类型分享!
  • RabbitMQ(四)
  • 论文提交步骤 | 2024年第五届MathorCup大数据竞赛
  • 阿里云物联网的通信方式
  • C++第九讲:模板进阶
  • 第三方软件检测公司分享:软件性能测试有哪些好用的测试工具?
  • 机器人技术基础(4章逆运动解算和雅克比矩阵)
  • wsl 使用docker 部署oracle11g数据库
  • IDEA集成JProfiler
  • 【已解决,含泪总结】非root权限在服务器Ubuntu18.04上配置python和torch环境,代码最终成功训练(二)
  • SpringBoot利用InitializingBean实现策略模式
  • 一:Linux学习笔记(第一阶段)-- 安装软件 vmware workstation 虚拟机软件 centos系统
  • XQT_UI 组件|01|颜色
  • Vue.js 构建可复用的组件
  • 小型语言模型(LLM)综述!
  • TVB被嘲讽工资低,张兆辉得体且高情商的回应,赢得网友赞赏
  • 【JIT/极态云】技术文档--发起申请
  • Chrome DevTools:Console Performance 汇总篇
  • LabVIEW涡扇发动机加力泵测试
  • 知难而进:什么是Web开发——关于软件开发你需要知道些什么
  • AIGC时代的数据盛宴:R语言引领数据分析新风尚
  • C++算法第五天