AWS中国云中的ETL之从aurora搬数据到s3(Glue版——修复版)

问题

AWS中国云中的ETL之从aurora搬数据到s3(Glue版)

之前这个方式,在数据比较大的情况下,会出现对mysql全表扫描问题。

解决思路

使用JDBC下推方式,避免对mysql取数的全表扫描。

解决

将可视化ETL改成脚本方式:具体代码如下:

python 复制代码
import sys
from awsglue.transforms import *
from awsglue.utils import getResolvedOptions
from pyspark.context import SparkContext
from awsglue.context import GlueContext
from awsglue.job import Job
from awsgluedq.transforms import EvaluateDataQuality
from awsglue import DynamicFrame

def sparkSqlQuery(glueContext, query, mapping, transformation_ctx) -> DynamicFrame:
    for alias, frame in mapping.items():
        frame.toDF().createOrReplaceTempView(alias)
    result = spark.sql(query)
    return DynamicFrame.fromDF(result, glueContext, transformation_ctx)
args = getResolvedOptions(sys.argv, ['JOB_NAME'])
sc = SparkContext()
glueContext = GlueContext(sc)
spark = glueContext.spark_session
job = Job(glueContext)
job.init(args['JOB_NAME'], args)

# Default ruleset used by all target nodes with data quality enabled
DEFAULT_DATA_QUALITY_RULESET = """
    Rules = [
        ColumnCount > 0
    ]
"""

sampleQuery = '''
select track_id,
    distinct_id,
    lib,
    event,
    type,
    all_json,
    host,
    user_agent,
    ua_platform,
    ua_browser,
    ua_version,
    ua_language,
    connection,
    pragma,
    cache_control,
    accept,
    accept_encoding,
    accept_language,
    ip,
    ip_city,
    ip_asn,
    url,
    referrer,
    remark,
    created_at,
    date,
    hour
from xxxx
where date = CURDATE() and
'''.rstrip('\n')

# Script generated for node prod-mysql
prodmysql_node202512354346 = glueContext.create_dynamic_frame.from_options(
    connection_type = "mysql",
    connection_options = {
        "useConnectionProperties": "true",
        "dbtable": "xxxx",
        "connectionName": "prod Aurora connection",
        "sampleQuery": sampleQuery,
        # 启用JDBC下推
        "enablePartitioningForSampleQuery": True,
        # 按小时字段分区
        "hashfield": "hour",
        "hashpartitions": "24"
    },
    transformation_ctx = "prodmysql_node202512354346"
)

# Script generated for node SQL Query xxxx
SqlQuery68 = '''
select track_id,
    distinct_id,
    lib,
    event,
    type,
    all_json,
    host,
    user_agent,
    ua_platform,
    ua_browser,
    ua_version,
    ua_language,
    connection,
    pragma,
    cache_control,
    accept,
    accept_encoding,
    accept_language,
    ip,
    ip_city,
    ip_asn,
    url,
    referrer,
    remark,
    created_at,
    date,
    hour,
    YEAR(date) AS year,
    MONTH(date) AS month,
    DAY(date) AS day 
from xxxx 
where date = CURDATE();
'''
SQLQueryxxxx_node20251236978987 = sparkSqlQuery(glueContext, query = SqlQuery68, mapping = {"xxxx":prodmysql_node202512354346}, transformation_ctx = "SQLQueryxxxx_node20251236978987")

# Script generated for node Amazon S3 xxxx
EvaluateDataQuality().process_rows(frame=SQLQueryxxxx_node20251236978987, ruleset=DEFAULT_DATA_QUALITY_RULESET, publishing_options={"dataQualityEvaluationContext": "EvaluateDataQuality_node1758699684078", "enableDataQualityResultsPublishing": True}, additional_options={"dataQualityResultsPublishing.strategy": "BEST_EFFORT", "observations.scope": "ALL"})
# AmazonS3xxxx_node1758699703229 = glueContext.write_dynamic_frame.from_options(frame=SQLQueryxxxx_node20251236978987, connection_type="s3", format="glueparquet", connection_options={"path": "s3://aws-glue-prod-xxxx", "partitionKeys": ["year", "month", "day"]}, format_options={"compression": "snappy"}, transformation_ctx="AmazonS3xxxx_node1758699703229")

additionalOptions = {
    "enableUpdateCatalog": True
}
# 自动添加给表分区,记得给表添加属性useGlueParquetWriter为true
additionalOptions["partitionKeys"] = ["year", "month", "day"]

write_sink = glueContext.write_dynamic_frame_from_catalog(
    frame=SQLQueryxxxx_node20251236978987, 
    database="prod", 
    table_name="aws_glue_prod_xxxx", 
    transformation_ctx="write_sink",
    additional_options=additionalOptions
)

job.commit()

注意在运行之前,记得给表添加属性useGlueParquetWriter为true。

参考

相关推荐
瞎某某Blinder4 小时前
DFT学习记录[6]基于 HES06的能带计算+有效质量计算
python·学习·程序人生·数据挖掘·云计算·学习方法
byoass9 小时前
智巢AI知识库深度解析:企业文档管理从大海捞针到精准狙击的进化之路
开发语言·网络·人工智能·安全·c#·云计算
byoass14 小时前
企业云盘权限管理深度对比:巴别鸟、联想Filez、腾讯企微云盘
网络·安全·云计算·企业微信
翼龙云_cloud15 小时前
阿里云代理商:阿里云部署的Hermes Agent 钉钉接入指南
人工智能·阿里云·云计算·钉钉·ai 智能体·hermes agent
byoass16 小时前
企业云盘API集成指南:如何与CI/CD流水线打通
网络·安全·ci/cd·云计算
easy_coder17 小时前
超越提示词:Context Engineering 在AI智能诊断中的应用
人工智能·云计算
easy_coder17 小时前
ReAct Agent 陷入死循环?私有云部署诊断中的陷阱与破局之道
人工智能·云计算
手揽回忆怎么睡17 小时前
本地服务镜像推送到阿里云ACR
阿里云·云计算
byoass18 小时前
企业云盘全文检索实战:Elasticsearch集成与分布式搜索
网络·分布式·安全·elasticsearch·云计算·全文检索
翼龙云_cloud18 小时前
云代理商:云端部署的Hermes Agent 如何接入钉钉?
人工智能·云计算·ai 智能体·hermes agent·hermes