AWS Glue: 由于缺少元数据,作业运行启动失败。
创始人
2024-11-16 06:00:34
0

当AWS Glue作业启动失败并显示“由于缺少元数据,作业运行启动失败”时,这通常是由于缺少必要的元数据表或者元数据不正确引起的。以下是一些可能的解决方法和代码示例:

  1. 检查元数据表是否存在:确保您的元数据表存在于AWS Glue Data Catalog中,可以使用以下代码检查表是否存在:
import boto3

glue_client = boto3.client('glue')

response = glue_client.get_table(
    DatabaseName='your_database_name',
    Name='your_table_name'
)

print(response)

如果返回一个错误,表明表不存在,您需要创建该表。

  1. 创建元数据表:如果您确定元数据表不存在,可以使用以下代码创建表:
import boto3

glue_client = boto3.client('glue')

response = glue_client.create_table(
    DatabaseName='your_database_name',
    TableInput={
        'Name': 'your_table_name',
        'StorageDescriptor': {
            'Columns': [
                {
                    'Name': 'column1',
                    'Type': 'string'
                },
                {
                    'Name': 'column2',
                    'Type': 'int'
                },
                # Add more columns as needed
            ],
            'Location': 's3://your_bucket/your_data_folder/',
            'InputFormat': 'org.apache.hadoop.mapred.TextInputFormat',
            'OutputFormat': 'org.apache.hadoop.hive.ql.io.HiveIgnoreKeyTextOutputFormat',
            'SerdeInfo': {
                'SerializationLibrary': 'org.apache.hadoop.hive.serde2.lazy.LazySimpleSerDe',
                'Parameters': {
                    'field.delim': ','
                }
            },
        }
    }
)

print(response)

请根据您的实际情况修改上述代码中的参数。

  1. 更新元数据表:如果您确定元数据表存在但元数据不正确,可以使用以下代码更新表:
import boto3

glue_client = boto3.client('glue')

response = glue_client.update_table(
    DatabaseName='your_database_name',
    TableInput={
        'Name': 'your_table_name',
        'StorageDescriptor': {
            'Columns': [
                {
                    'Name': 'column1',
                    'Type': 'string'
                },
                {
                    'Name': 'column2',
                    'Type': 'int'
                },
                # Add more columns as needed
            ],
            'Location': 's3://your_bucket/your_data_folder/',
            'InputFormat': 'org.apache.hadoop.mapred.TextInputFormat',
            'OutputFormat': 'org.apache.hadoop.hive.ql.io.HiveIgnoreKeyTextOutputFormat',
            'SerdeInfo': {
                'SerializationLibrary': 'org.apache.hadoop.hive.serde2.lazy.LazySimpleSerDe',
                'Parameters': {
                    'field.delim': ','
                }
            },
        }
    }
)

print(response)

请根据您的实际情况修改上述代码中的参数。

通过执行上述步骤,您应该能够解决“由于缺少元数据,作业运行启动失败”错误。请确保使用正确的元数据表和正确的元数据信息。

相关内容

热门资讯

6分钟辅助!hhpoker是真... 6分钟辅助!hhpoker是真的假的,hhpoker真的有透视吗,演示教程(真是有挂)1、每一步都需...
第七分钟辅助!we poker... 第七分钟辅助!we poker插件,we poker免费辅助器,手筋教程(有挂方式)暗藏猫腻,小编详...
七分钟辅助!aa poker辅... 七分钟辅助!aa poker辅助包,pokemmo脚本辅助器下载,讲义教程(有挂秘籍)1、pokem...
第四分钟辅助!wepoker辅... 第四分钟辅助!wepoker辅助器安装包定制,aapoker透视脚本,大纲教程(有挂总结)所有人都在...
第四分钟辅助!wpk透视辅助靠... 第四分钟辅助!wpk透视辅助靠谱吗,wepoker透视苹果系统,诀窍教程(有挂猫腻);运wepoke...
七分钟辅助!aapoker透视... 七分钟辅助!aapoker透视脚本入口,wejoker开挂,学习教程(有挂教程)1、打开软件启动之后...
第四分钟辅助!淘宝买wepok... 第四分钟辅助!淘宝买wepoker透视有用吗,wpk俱乐部怎么作弊,积累教程(有挂规律)1、下载好淘...
6分钟辅助!we-poker软... 6分钟辅助!we-poker软件,购买的wpk辅助在哪里下载,积累教程(有挂技巧)购买的wpk辅助在...
第2分钟辅助!如何下载wepo... 第2分钟辅助!如何下载wepoker安装包,newpoker怎么安装脚本,教程书教程(今日头条)1、...
4分钟辅助!wepoker钻石... 4分钟辅助!wepoker钻石怎么看底牌,wepoker辅助器有哪些功能,法门教程(有挂详细)该软件...