在本地发布AWS胶水作业

问题描述

我正在尝试在本地运行胶水作业,但遇到一个问题,当我运行脚本时会引发异常:

py4j.protocol.Py4JJavaError: An error occurred while calling o47.getDynamicFrame.
: java.lang.IllegalAccessError: tried to access method org.apache.hadoop.metrics2.lib.MutableCounterLong.<init>(Lorg/apache/hadoop/metrics2/MetricsInfo;J)V from class org.apache.hadoop.fs.s3a.S3AInstrumentation

我从以下位置下载了aws-glue-libs:https://github.com/awslabs/aws-glue-libs/tree/glue-1.0/awsglue

我的代码

from pyspark.sql import SparkSession

from awsglue.context import glueContext

spark = SparkSession \
    .builder \
    .appName("glueSparkJobExample") \
    .config("spark.jars","AWSglueETLPython-1.0.0-jar-with-dependencies.jar") \
    .config("spark.local.dir","/tmp") \
    .getorCreate()

sc = spark.sparkContext
glueContext = glueContext(sc)

db = "database"
table = "table"

my_df = glueContext.create_dynamic_frame.from_catalog(
database=db,table_name=table)

如果有人可以帮助,那就太好了。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)