admin

  • 标题:PolarDB大会下周三北京举行;TiDB社区活动下周六深圳举行

    重要更新

    2025 阿里云PolarDB开发者大会将于 2月26日(星期三)在北京嘉瑞文化中心举行,届时将有院士郑纬民、阿里云李飞飞、米哈游、雅迪、飞鹤等分享,感兴趣的可以现场参加。[1]

    下周六(3月1日),3.1 TiDB 社区活动深圳站举办,主题为:大规模 TiDB 国产化替代与成本优化在金融、跨境电商等行业的最新实践。感兴趣的可以现场参加。[2]

    更新详情

    腾讯云
    • 云数据库 MySQL 8.0内核版本更新20241001。[25]
    • 云数据库 PostgreSQL 支持11及以上大版本的实例开启和关闭 SSL 连接加密功能。[26]
    • 云数据库 PostgreSQL 支持在周备份计划的基础上迭代按月备份计划。[27]
    • 云数据库 PostgreSQL 支持查看所执行的任务详情,方便您了解对实例进行操作的任务进度。[28]
    火山云(字节)
    • Redis 新增支持取消事件类型为用户操作的计划内事件 [30]
    • Redis 新增支持导出分析大 Key 分析结果 [32]
    • MongoDB 新增支持对实例 Oplog 保留窗(也称 Oplog 可用时间)进行事件监控告警[37]
    • 优化了 MongoDB 账号密码校验功能,禁止使用极易被破解的弱密码[39]
    阿里云
    • RDS SQL Server 2022、2019、2016 发布新的内核小版本 [29]
    • RDS SQL Server新增存储过程sp_rds_update_db_stats,您可以更灵活高效地从采样率、并行度、超时时间及阈值百分比多维度更新数据库统计信息。[4]
    GCP(谷歌云)
    • Cloud SQL Enterprise Plus 版本的 SQL Server 实例支持完整的时间点恢复 (PITR) [8]
    • 高级查询洞察、索引顾问、主动的Query监控GA支持了 AlloyDB for PostgreSQL [9]
    • 当复制时间落后于预定义的时间长度时,Cloud SQL for MySQL 支持重建副本。[12]
    AWS(亚马逊云)
    • Aurora PostgreSQL 零 ETL 集成支持更多区域 [13]
    • Amazon RDS 支持 MySQL 8.4.4 和 MySQL 8.0.41[14]
    • Timestream for InfluxDB 增加了读取副本支持 [19]
    • RDS for PostgreSQL 支持次要版本 17.3、16.7、15.11、14.16、13.19 [23]
    • Amazon Q 生成 SQL 现已在更多区域推出[24]

    参考链接

  • 在不同的云厂商,购买相同规格的MySQL实例(如4vCPU-16GB),获得的性能相同吗?

    本次测试中,极限性能(512并发下的QPS)表现如上图:腾讯云性能最好,达3.6万;其次是阿里云2.7万,相比于上一次测试的4.0万性能下降比较明显;其次是华为、AWS、百度,再次是Azure、Google云和Oracle云。更多详细数据参考如下。

    Sysbench QPS 详细数据

    dataaliyunawsazurebaidugooglehuaweioracletencent
    457892183151720171915247630325868
    8871643352964382234154546504610518
    161437382725489697560718472783916903
    322013215377911111910858214384771723484
    4823026178621143915330964118667774726802
    6424990199471262318316987721269788930054
    96269542246113578205351042322137852935131
    128269242320014057214811068221394823036199
    192265862330914484214271120322040795836259
    256259332339614640218271141322847743835743
    384272092292414638214521155224148769035747
    512276622277814674214051135024079719636052

    Latency (Event) 详细数据

    如下表格分别为:平均延迟 和 95%延迟数据。单位为:毫秒/ms。

    dataaliyunawsazurebaidugooglehuaweioracletencent
    412.4432.9847.4535.7037.6029.0823.7412.27
    816.5233.2248.5837.6842.1631.6728.5413.69
    1620.0434.8152.4641.2947.4333.9936.7417.04
    3228.6137.4563.2148.3667.1140.0474.6324.53
    4837.5248.3775.5256.3589.6146.28111.5232.23
    6446.1057.7591.2562.89116.6154.16146.0038.33
    9664.1176.92127.2584.14165.7678.04202.5649.18
    12885.5799.30163.88107.25215.61107.68279.9063.64
    192129.99148.24238.56161.27308.43156.77434.1295.30
    256177.67196.91314.68211.08403.63201.61619.30128.89
    384254.00301.39472.05322.16598.09286.09898.19193.28
    512333.11404.42627.82430.45811.55382.501279.61255.51
    dataaliyunawsazurebaidugooglehuaweioracletencent
    418.9536.2455.8241.1047.4737.5636.8914.73
    825.7436.2457.8744.9861.0839.6546.6317.01
    1629.1941.1062.1950.1187.5641.8566.8421.89
    3244.1745.7978.6062.19147.6149.21121.0831.94
    4866.8459.9995.8177.19204.1156.84200.4741.85
    6486.0071.83121.0890.78219.3668.05267.4149.21
    96116.80101.13183.21125.52272.27123.28325.9862.19
    128147.61142.39248.83164.45331.91150.29442.7377.19
    192219.36211.60376.49227.40450.77231.53634.66116.80
    256282.25272.27511.33292.60569.67320.171376.60158.63
    384376.49411.96802.05427.07831.46539.712449.36253.35
    512484.44549.521109.09559.501129.24549.523982.86369.77

    MySQL 参数对比表格

    dataaliyunawsazurebaidugooglehuaweioracletencent
    have_sslDISABLEDYESYESDISABLEDYESDISABLEDYESDISABLED
    innodb_buffer_pool_size9.75GB11GB12GB12GB11GB9GB17GB12GB
    innodb_doublewriteONOFFOFFONONONONON
    innodb_flush_log_at_trx_commit11111111
    innodb_flush_methodO_DIRECTO_DIRECTfsyncfsyncO_DIRECTO_DIRECTO_DIRECTO_DIRECT
    innodb_io_capacity200002002002000500012000125020000
    innodb_read_io_threads44NA84424
    innodb_write_io_threads44NA84444
    log_binONOFFONONONONONON
    performance_schemaOFFOFFONOFFONOFFONOFF
    rpl_semi_sync_master_enabledONNANAONNAONNAON
    rpl_semi_sync_master_timeout1000NANA10000NA10000NA10000
    sync_binlog11110001111
    thread_pool_size8NA4NANANA164
    version8.0.368.0.398.0.39-azure8.0.32-2.0.0.28.0.31-google8.0.28-2310038.0.40-u3-cloud8.0.30-txsql
    instance_typedb.m6i.xlargeGP_Standard_D4ads_v5db-custom-4-16384m
    storage_typecloud_essdio1NANAm
    storage_size100100100m100
    storage_iops30003000NAm
    cpu_capacity100.9106.972.773.449.4163.1101.1118.4

    云数据库的 MySQL 8.4 版本

    目前,主流版本依旧还是8.0。在2024年04月,最新发布了 8.4 版本,该版本将是下一个稳定版(LTS版),所以也有部分云厂商开始这次该版本。目前,发布了 MySQL 8.4的云厂商有Amazon、Google云和Oracle云。这里也对8.4版本的性能做了测试,并对比如下:

    各云厂商详细测试数据

    关于各个云厂商更多的详细测试数据可以参考如下专题页面:

    更多参考

  • 标题:PolarDB for AI 内置支持多种机器学习算法模型、NL2SQL等能力; 华为云新增Redis 7.0支持

    重要更新

    2025 阿里云PolarDB开发者大会将于 2月26日(星期三)在北京举行,感兴趣的可以现场参加[1]

    更新详情

    阿里云

    • PolarDB for AI 发布,内置支持多种机器学习算法模型、NL2SQL等能力 [3][4]
    GCP(谷歌云)
    • Spanner 自定义组织策略(Custom organization policies)正式发布[8]
    火山云(字节)
    • veDB MySQL 新增规格 2 核 8GiB、支持为账号和数据库设置描述信息等更新 [13][15]
    • veDB MySQL 优化了对使用 Hint 语法指定的节点不存在或发生故障时的报错信息 [19]
    AWS(亚马逊云)
    • Amazon RDS for SQL Server 支持新的小版本[21]
    • Aurora PostgreSQL 支持在 Amazon CloudWatch 查看锁争用诊断 [23]
    • Amazon DocumentDB(兼容 MongoDB)支持在 AWS Toolkit for Visual Studio Code 中操作[28]
    腾讯云
    • 云数据库 MySQL、TDSQL-C MySQL 只读分析引擎发布了新的版本 1.2404.21.0。[29][30]

    华为云

    • DCS for Redis 新增支持 Redis 7.0实例[2]

    参考链接

  • 在2015年,由 OpenAI 的 DP Kingma 等发布了 《ADAM: A METHOD FOR STOCHASTIC OPTIMIZATION》算法后,由于其迭代效率提升非常明显,所以 ADAM(或其变种)就被广泛的采用。本文将继续对上一篇介绍的梯度下降算法进行优化,并介绍 ADAM 算法(一种对随机梯度下降算法的优化算法)的实现以及效果。

    Stochastic Gradient Descent 或者说 mini-batch解决了样本量巨大时,梯度下降迭代的问题。但是,也带了一些新的问题。最为主要的是,因为样本数据的波动,而导致每次梯度下降计算时,梯度方向的波动,从而降低了梯度下降迭代的效率。

    在前面的《Mini-batch Gradient Descent和随机梯度下降(SGD)》文章中,我们对比了 mini-batch 和 batch gradient descent 的在迭代时,目标函数下降的速度。

    可以看到,batch gradient descent 的目标函数下降非常稳定,而 Mini-batch 的实现则会有明显的波动。为了尝试修正这个问题,从而提高迭代效率,在神经网络算法上,逐渐探索出了一些较为高效的优化算法:Adam SGD。该算法将 RMSprop 和 “Exponential smoothing”的想法结合在一起,形成了一个较为高效的算法,在实践中被广为使用。


    Stochastic Gradient Descent 与 Momentum

    SGD 会在每次迭代时根据样本的偏差,展现出不同的偏差,所以,在使用SGD进行迭代时,观察其 cost函数下降,应该会有更加明显的波动(后续吧自己实现的程序改造后,尝试观察一下)。

    为了加快迭代的速度,一个折中的思路是,引入一个均值替换当前的梯度方向。该如何引入这个均值呢?梯度是一个随时计算推进,不断推进的变量,常用的均值计算可以参考:Moving average。最为常见的实现是使用“Exponential moving average”,这种平均值的计算,在迭代计算时实现非常简单。

    Momentum 就是 “Exponential moving average”实现时的参数“smoothing factor”,在神经网络中,经常使用 \( \beta \)表示(原因是 \( \alpha \) 已经表示学习率了 )。

    而这里的 Momentum ,也是 TensorFlow 在构造 SGD 算法时需要的另一个参数。

    关于Exponential moving average

    或者叫“Exponential smoothing”。我们看看这个算法的具体实现是怎样的?

    原始的迭代:\( w = w – \alpha \frac{\partial J}{\partial w} \)

    使用 “Exponential smoothing” 后的迭代:

    $$
    \begin{align}
    v_0 & = 0 \quad \partial{w}_t = \frac{\partial J}{\partial w}|_{(for \, sample \, t)} \\
    v_{t} & = \beta*v_{t-1} + (1-\beta)\partial{w}_{t} \\
    w & := w – \alpha v_t
    \end{align}
    $$

    考虑 \( \beta = 0.9 \),如果数学直觉比较好的话,可以看出,原本使用梯度\( \partial{w} \)进行迭代的,这里使用了一个梯度的“Exponential smoothing” \( v_t \)去替代。上面的式子中,\( v_t \) 如果展开有如下表达式:

    $$
    \begin{align}
    v_t & = (1-\beta)\partial{w}_{t} + \beta(1-\beta)\partial{w}_{t-1} + \beta^2(1-\beta)\partial{w}_{t-2} … \\
    & = \sum\limits_{i=0}^{t} \beta^{i}(1-\beta)\partial{w}_{i}
    \end{align}
    $$

    使用“Exponential smoothing” 之后,新的迭代方向 \( v_t \),可以理解为一个前面所有梯度方向的加权平均。离得越近的梯度,权重越高,例如,\( \partial{w}_{t} \)的权重是\( (1-\beta) \);而之前的梯度,则每次乘以一个 \( \beta \)衰减。

    Exponential moving average的“冷启动问题”与修正

    仔细观测上诉的 “Exponential moving average” 公式,可以注意到一个问题,就是其最初的几个点总是会偏小。其原因是,当前值的权重总是为 \( 1- \beta \),而因为是初始的几个值,并没有更前面的数据去“平均”当前值,也就会出现,初始值总是会偏小的问题。

    通常,如果样本量很大的事时候,则可以忽略这个问题,因为初始值偏小的点占比会非常少,可以忽略。如果要一定程度上解决这个问题,也有继续对上述的 “Exponential moving average”做了一些修正,可以考虑对 \( v_t \)的结果值做一个修正:\( v_t := \frac{vt}{1-\beta^t} \)。

    一般的,因为样本的数量总是比较大的,所以我们可以忽略这个问题,而无需做任何修正。

    RMSprop

    在前面的“Gradient Descent with Momentum”中,我们看到为了解决梯度波动较大的问题,使用了 “Exponential moving average” 去尝试将一些比较偏的梯度,拉倒一个较为平均的方向上来。RMSprop的想法也是类似的,这里通过了root mean square的想法进行平均值的计算。具体的,在进行 SGD 时,每次更新梯度,按照如下的方法进行更新:

    $$
    \begin{align}
    s_0 & = 0 \quad \partial{w}_t = \frac{\partial J}{\partial w}|_{(for \, sample \, t)} \\
    s_{t} & = \beta*s_{t-1} + (1-\beta)(\partial{w}_{t})^2 \\
    w & := w – \alpha \frac{\partial w}{\sqrt{s_{t}}}
    \end{align}
    $$

    说明:这里对梯度进行平方时,如果在程序中是一个梯度向量,那么这里“平方”也就是对梯度的每一个分量进行一次平方。

    在“Exponential smoothing”的实现中,是将当前值,使用一个加权平均替代。与“Exponential smoothing”类似的,原本的梯度方向,现在使用如下的方向去替代了:

    $$
    \begin{align}
    s_t & = \frac{\partial{w}_{t}}{\sqrt{(1-\beta)(\partial{w}_{t})^2 + \beta(1-\beta)(\partial{w}_{t-1})^2 + \beta^2(1-\beta)(\partial{w}_{t-2})^2 + \cdots }} \\
    & = \frac{\partial{w}_{t}}{\sqrt{\sum\limits_{i=1}^{t}\beta^i(1-\beta)(\partial{w}_{i})^2}} \\
    \end{align}
    $$

    Adam Gradient Descent

    这可能是实际使用最多的算法,全称是 Adaptive Moment Estimation 。该实现,将 “Momentum” 和 “RMSprop” 做了一定的融合,形成了新的“最佳实践” Adam。在融合上,具体的实现与两个细节点:

    (1) 在 Adam 中均使用了“修正”计算,即 \( \hat{v_t} = \frac{v_t}{1-(\beta_1)^t} \quad \hat{s_t} = \frac{s_t}{1-(\beta_1)^t} \)

    (2) 参数更新公式,使用了两个算法的融合: \( w := w – \alpha \frac{\hat{v_t}}{\sqrt{\hat{s_t}}} \)

    Adam optimization的效果对比

    在 Adam 的论文中对于效果做了非常多的评估,感兴趣的可以参考相关论文。

    这里根据之前完成的训练程序,也进行了优化,实现了Adam算法。在 MNIST 数据集的训练上,我们来看看 Adam 的效果:

    从右图可以看到,Adam(蓝色)明显的提升了迭代效率。依旧一定程度存在 mini-batch(绿色) 的梯度波动的问题。相比于,batch gradient descent (红色)算法,迭代效率大大增加,约在第10次迭代,即在第一个epoch 的第十批样本进行训练时,cost 就下降到了比较低的程度。

    关于 root mean square

    root mean square也叫二次平均值,考虑一组数据:\( {x_1,x_2, \cdots , x_n } \),其RMS则为:

    $$ x_{rms} = \sqrt{\frac{1}{n} \sum_{i=1}^n x_i^2} = \sqrt{\frac{1}{n} (x_1^2 + x_2^2 + \cdots + x_n^2)} $$

    补充说明

    可以看到,所有的这些优化都是面向“最优化”问题的。梯度下降是一个一阶优化(First-order Optimization)的方法,其核心就在与每次迭代时,应该如何去更新响应的参数值,在梯度下降中也就是如何去选择合适的学习率。

    牛顿法是典型的二阶优化(Second-order Optimization),在迭代时使用了二阶导数,所以,通常可以获得更好的迭代效率。但是因为二阶导数的计算复杂度会上升非常多(对应的矩阵可能是所有参数的平方,应该也有人尝试去算过了…)。这也是为什么在这个场景下,依旧是使用一阶优化方法的原因。

    如果想比较好的理解学习率、Momentum、RMSprop、Adam等内容,建议先了解梯度、数值方法、最优化问题等数学方法。

    到这里这个系列算是一个小阶段了,这是一个个人学习的笔记,从数学的梯度概念开始,逐步到神经网络训练的Adam优化算法,也包含部分动手实践的神经网络算法实现。完成的系列包括了:

  • Terraform 可以自动化的创建云端的资源,但是要想实现更高的灵活度,则需要更为灵活的使用Terraform的“Data Sources”能力。例如,在自动化的创建数据库时,云厂商允许创建的版本号是在动态变化的,例如,当前最新的允许的创建的MySQL版本通常是 8.0.40,但通常过了一个季度之后,就变成了 8.0.41。这时,对应的 Terraform 的脚本就需要调整或者传递参数就需要发生变化。而 Terraform 提供的 “Data Sources” 能力则可以很好的解决这个问题。

    在 Oracle 的 Terraform 中可以使用 “Data Source: oci_mysql_mysql_versions” 实现该能力。

    示例

    首先使用 data 命令定义该对象:

    data "oci_mysql_mysql_versions" "gmv" {
        compartment_id = oci_identity_compartment.oic.id
    }

    这里会获取该租户环境下支持的所有MySQL版本。

    然后,再使用 output 命令就可以获取并输出这些版本信息。详细的output命令如下:

    output "mysql_version" {
      value       = data.oci_mysql_mysql_versions.gmv.versions
    }

    详细的输出示例如下:

    mysql_version = tolist([
      {
        "version_family" = "8.0"
        "versions" = tolist([
          {
            "description" = "8.0.36"
            "version" = "8.0.36"
          },
          {
            "description" = "8.0.37"
            "version" = "8.0.37"
          },
          {
            "description" = "8.0.38"
            "version" = "8.0.38"
          },
          {
            "description" = "8.0.39"
            "version" = "8.0.39"
          },
          {
            "description" = "8.0.40"
            "version" = "8.0.40"
          },
          {
            "description" = "8.0.41"
            "version" = "8.0.41"
          },
        ])
      },
      {
        "version_family" = "8.4 - LTS"
        "versions" = tolist([
          {
            "description" = "8.4.0"
            "version" = "8.4.0"
          },
          {
            "description" = "8.4.1"
            "version" = "8.4.1"
          },
          {
            "description" = "8.4.2"
            "version" = "8.4.2"
          },
          {
            "description" = "8.4.3"
            "version" = "8.4.3"
          },
          {
            "description" = "8.4.4"
            "version" = "8.4.4"
          },
        ])
      },
      {
        "version_family" = "9 - Innovation"
        "versions" = tolist([
          {
            "description" = "9.1.0"
            "version" = "9.1.0"
          },
          {
            "description" = "9.1.1"
            "version" = "9.1.1"
          },
          {
            "description" = "9.1.2"
            "version" = "9.1.2"
          },
          {
            "description" = "9.2.0"
            "version" = "9.2.0"
          },
        ])
      },
    ])

    获取特定大版本的各小版本

    可以通过 data资源中新增filter模块以过滤出需要的对象。

    在 Terraform 中,关于 data 资源是否可以使用 filter,以及filter支持的完整度视乎并没有明确的说明。这需要更具不同的供应商的实现。常见的,在data resourcefilter可以支持“列表匹配”、“通配符匹配”或者“正则匹配”。具体的匹配方式,则需要通过文档、或者测试区验证。

    添加带正则匹配的 filter
    data "oci_mysql_mysql_versions" "gmv" {
        #Required
        compartment_id = oci_identity_compartment.oic.id
        filter {
            name = "version_family"
            values = ["8.0.*"]
            regex  = true
        }
    }

    通过 HCL 语言获取最新的版本
    output "latest_versions" {
      value = {
        for db_version in data.oci_mysql_mysql_versions.gmv.versions : db_version.version_family => sort([
          for v in db_version.versions : v.version
        ])[length(db_version.versions) - 1] // 取排序后的最后一个版本
      }
    }

    最后的输出如下:

    latest_versions = {
      "8.0" = "8.0.41"
      "8.4 - LTS" = "8.4.4"
      "9 - Innovation" = "9.2.0"
    }

    参考链接

  • 蛇年大吉!

    标题:清华大学数据库教授李国良入选 ACM Fellow; 阿里云 PolarDB 打破TPC-C记录

    重要更新

    清华大学李国良入选ACM Fellow,以表彰其在人机协同(human-in-the-loop)数据集成与基于学习的数据库系统领域做出的重要贡献。此外,李国良还是 openGauss 社区技术委员会主席。[6]

    阿里云 PolarDB 打破TPC-C记录[1][2],以更高的性能、更好的性价比超越之前OceanBase、TDSQL创下的记录。PolarDB本次使用的使用的版本为多主集群(Limitless),总计使用2340个数据节点,56,160个cores,1170个处理器[3]

    更新详情

    Azure(微软云)
    • Azure SQL Database 正式提供免费试用,该试用提供10个数据库、每个32GB的 serverless 实例,每月最多使用资源为100,000 vCore*秒 [5]
    GCP(谷歌云)
    • Cloud SQL for MySQL 5.6 和 5.7 ,PostgreSQL 9.6、10、11 和 12因为社区生命周期终止 (EOL) ,当前已加入 Cloud SQL 扩展支持阶段 [14][15]
    • Spanner 索引顾问在 GoogleSQL 和 PostgreSQL 方言数据库中均已普遍可用。索引顾问会分析您的查询,推荐新索引或对现有索引进行更改,以提高查询的性能[18]
    • Spanner 支持新的 SERIALAUTO_INCREMENT DDL 语法 [19]
    • BigQuery ML 支持多项生成式 AI 功能 [27]
    • Spanner 支持 GoogleSQL 和 PostgreSQL 方言数据库中的 `SELECT…FOR UPDATE` 查询语法[34]
    Oracle云
    • HeatWave 支持更改管理员密码 [40]
    • HeatWave 支持版本 9.2.0、8.4.4 和 8.0.41 [41]
    • OCI 上的 PostgreSQL 数据库增加了对 pg_cron 和 pgaudit 扩展的支持[42]
    火山云(字节)
    • DBW 提供用户组管理功能,通过将火山引擎子用户分配到用户组 [45]
    • DBW 支持批量开启、关闭和修改实例的安全管控 [46]
    AWS(亚马逊云)
    • DocumentDB 现在提供与 CloudShell 的一键连接 [51]
    • RDS Custom for SQL Server 使用 io2 Block Express 卷支持高达 64TiB 和 256,000 IOPS [57]
    • Timestream for InfluxDb 现已支持存储扩展 [60]
    • Aurora PostgreSQL Limitless Database 现在支持 PostgreSQL 16.6 [66]
    • ElastiCache 现在支持一键设置 EC2 和缓存之间的连接[68]

    参考链接