ETL的开发过程

在生产环境中, 使用shell脚本完成一次etl操作

1.定义一个etl函数, 里面传入json行数据, 用json.loads加载行数据,并对行数据进行判断,如果没有行数据,或data字段没有在行数据里, 就直接返回空的结果, 否则就继续往下执行

2.接着获取行里的数据, 用for循环判断, 如果包含某个值, 我就将变量赋值取出, 装在集合容器里

3.设置sparksession会话, 并enableHiveSupport, 我用的是hiveonspark模式,

4.初始化rdd, 从大数据emr集群中(也可能是从实时系统kafka读取数据)加载数据到rdd , 然后用自己自定义的etl解析过滤

5.将rdd转为df, createDateFream()要传两个参数,一个是rdd,一个是schema信息

6.将df创建临时表 createOrReplaceTemView()

7.将临时表表的数据加载到hive表中, 完成整个ETL操作

ETL常用场景:

1.清洗nginx日志信息, 预处理日志文件(每小时将上报的日志拉取到本机,hdfs命令上传集群),并清洗存入hive

2.每小时清洗用户表信息,

3.后处理清洗商户信息,

4.清洗并合并设备状态信息,

5.每小时清洗每日设备分成, 清洗并合并积分流水表信息, 每小时清洗支付宝订单表信息等,

def etl(row_str):
	result = []
	try:
		row = json.loads(row_str)
		if(not row) or ('data' not in row):
		return result
		
		获取行
		base = {}
		for r_k in row:
			r_v = row[r_k]
			if r_k != 'data':
				r_k=r_k.lower()
				base[r_k]=r_k
				print(base)
		获取data
		for data in row['data']:
			base_data = base.copy()
			if data:
				for d_k in data:
					d_v = data[d_k]
					if d_k != 'list':
						d_k = d_k.lower()
						base_data[d_k] = d_v
						print(base_data)
		获取list
		 for list_ in data['list']:
                    if list_:
                        # print(list_)
                        list_data = base_data.copy()
                        # list_data.update(list_)
                        for l_k in list_:
                            l_v = list_[l_k]
                            l_k = l_k.lower()
                            list_data[l_k] = l_v
                        # print(list_data)
                        result += [list_data]
                        # print(result)
      except Exception as e:
      	print(e)
      	pass
      retuen result
      
  设置会话
  spark = SparkSession.builder.appName("程序名" % statdate分区日期)
  .enableHiveSupport()
  .getOrCreate()
  
  初始化rdd
  rawLogRDD = spark.sparkContext.textfile("hdfs://emr-cluster/ld_log")
  
  etl解析
  etllogRDD = rawLogRDD.flatMap(etl)
  可以进行测试打印
  for record in etlLogRDD.collect():
  	print(record)
  	
  	将rdd 转为df
  	sampleDF = spark.sql("select * from dept limit 1")
  	etlLogSchema = sampleDF.schema
  	etlLogSchema.__dict__['fields'] = etlLogSchema.__dict__['fields'][:-1]
etlLogSchema.__dict__['names'] = etlLogSchema.__dict__['names'][:-1]
etlLogDF = spark.createDataFrame(etlLogRDD,etlLogSchema)
测试:etlLogDF.printSchema()
etlLogDF.show()
exit()
创建临时表
etl.LogDF.createOrReplaceTmpView("etl_log")
写入分区表
spark.sql("alter table dept drop if exist partition(statdate='%s')" ) % statdate)
spark.sql("insert overwrite table dept partition(statdate='%s') select * from etl_log " % statdate)
		
  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 开源大数据ETL(Extract-Transform-Load)开发流程是将各种源数据从不同的数据源(如数据库、文件等)中提取出来,经过转换和加工后加载到目标数据仓库或数据湖中的过程。以下是开源大数据ETL开发流程的简要介绍: 1. 数据需求分析:根据业务需求,确定需要提取、转换和加载的数据,分析其结构和特征。 2. 数据源准备:选择适当的数据源,并进行连接、授权等相关设置,以保证能够提取所需的数据。 3. 数据提取:使用相应的开源大数据ETL工具(如Apache Nifi、Talend等),从数据源中提取所需数据,并将其暂存到缓冲区中。 4. 数据清洗和转换:对提取的数据进行清洗和转换,包括数据格式转换、去除重复记录、填充缺失值、数据标准化等。 5. 数据加载:将清洗和转换后的数据加载到目标数据仓库或数据湖中,保证数据的完整性和一致性。 6. 错误处理和监控:在数据处理过程中,监控和处理可能出现的错误,如数据源连接失败、错误数据处理等,保证数据流的稳定和正确。 7. 数据验证和测试:对加载到目标数据仓库或数据湖中的数据进行验证和测试,确保数据的准确性和完整性。 8. 调度和自动化:设置自动化调度,定期执行ETL流程,确保数据的及时更新和同步。 9. 日志记录和性能优化:记录ETL流程的日志,并进行性能优化,如调整数据提取的并发数、增加缓存大小等,以提高ETL过程的效率和稳定性。 综上所述,开源大数据ETL开发流程包括数据需求分析、数据源准备、数据提取、数据清洗和转换、数据加载、错误处理和监控、数据验证和测试、调度和自动化、日志记录和性能优化等步骤,通过这些步骤,我们可以实现对各种数据进行ETL处理,以满足业务需求。 ### 回答2: 开源大数据ETL(Extract-Transform-Load)开发流程是指在使用开源技术和工具进行大数据处理的过程中,从数据抽取到转换再到加载的一系列操作流程。具体包括以下几个阶段: 1. 数据抽取(Extract):从源系统中获取数据,可以通过不同的方式进行数据抽取,包括批量导入、实时抓取、API接口等。在这个阶段,需要考虑数据的来源、数据格式、数据量和抽取策略等。 2. 数据转换(Transform):将抽取的数据进行清洗、整理、加工和转换操作,以适应目标系统的需求。数据转换可以包括数据过滤、字段映射、数据合并等操作,可以使用开源的大数据处理框架(如Apache Spark、Apache Flink)进行数据转换。 3. 数据加载(Load):将转换后的数据加载到目标系统中,目标系统可以是数据仓库、数据湖或者其他数据存储设施。数据加载可以使用开源的分布式存储系统(如Apache Hadoop、Apache HBase)进行存储和管理。 在开源大数据ETL开发流程中,还需要考虑以下几个方面: 1. 算法和模型选择:根据实际需求选择合适的算法和模型,以实现数据的清洗、转换和加载。 2. 数据质量控制:确保抽取的数据质量,进行数据质量检测和修复,以保证后续数据处理的准确性。 3. 任务调度和监控:建立定时调度机制,监控整个ETL流程的运行情况,及时发现和解决问题。 4. 数据安全和权限管理:对ETL过程中涉及的数据进行权限控制,保障数据的安全性。 总结起来,开源大数据ETL开发流程主要包括数据抽取、数据转换和数据加载三个阶段,同时需要考虑算法和模型选择、数据质量控制、任务调度和监控、数据安全和权限管理等方面。通过合理设计和实施ETL流程,可以从海量的原始数据中提取出有用的信息,为业务决策和数据分析提供支持。 ### 回答3: 开源大数据ETL(Extract-Transform-Load)开发流程是指使用开源工具和技术进行大数据ETL任务的开发过程。下面是一个典型的开源大数据ETL开发流程: 1. 分析需求:首先,需要明确ETL任务的需求和目标。确定要处理的数据类型、数据源和目标数据仓库等信息。 2. 数据抽取:使用开源工具(例如Apache Nifi、Apache Flume)从源系统中提取数据,并将数据存储到临时位置或数据湖中。 3. 数据清洗和转换:对抽取得到的数据进行清洗和转换,以适合目标系统或数据需求。可以使用开源工具(例如Apache Spark、Apache Pig)进行数据清洗、过滤、去重、格式转换等操作。 4. 数据加载:将清洗和转换后的数据加载到目标系统或数据仓库中。可以使用开源工具(例如Apache Hive、Apache HBase)进行数据加载操作。 5. 数据质量和验证:对加载到目标系统的数据进行质量检查和验证,确保数据的准确性和完整性。可以使用开源工具(例如Apache Kylin、Apache Atlas)进行数据质量检查和元数据管理。 6. 调度和监控:设置ETL任务的调度计划,确保任务的自动执行。可以使用开源工具(例如Apache Oozie、Apache Airflow)进行任务调度和监控,同时可以使用开源工具(例如Apache Zeppelin、Grafana)对任务执行情况进行活动监控和可视化展示。 7. 故障处理和优化:在ETL任务运行过程中,可能会出现故障或性能问题。需要对任务进行故障处理和优化。可以使用开源工具(例如Apache Kafka、Apache ZooKeeper)进行故障处理和性能优化。 8. 文档和分享:最后,需要编写ETL任务的文档,包括任务架构、代码、配置等信息,并与团队成员分享经验和经验教训。 以上是开源大数据ETL开发流程的基本步骤。根据具体的需求和技术栈,可能会有所不同。开源工具的选择和配置也会因具体情况而有所差异。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值