sqoop 抽取源码流程分析( 三 ) 代码生成工具分析

来源:互联网 发布:80端口被进程4占用 编辑:程序博客网 时间:2024/05/16 23:35

1. 工具的作用

根据数据库 Schema 信息生成一个java文件,并编译打包。

2. 继承关系

public class CodeGenTool extends com.cloudera.sqoop.tool.BaseSqoopTool {

可以看出,基本上所有的工具类都从BaseSqoopTool 继承3而来,具体的关系,已经在ImportTool 工具的代码分析中讲过。

3. 工具类的run 方法

  @Override  /** {@inheritDoc} */  public int run(SqoopOptions options) {......   generateORM(options, options.getTableName());.....

3.1 generateORM 的具体实现

 public String generateORM(SqoopOptions options, String tableName)      throws IOException {......    CompilationManager compileMgr = new CompilationManager(options);    ClassWriter classWriter = new ClassWriter(options, manager, tableName, compileMgr);    classWriter.generate();    compileMgr.compile();    compileMgr.jar();......

3.2 代码生成 ClassWriter

这个部分主要是根据数据库的元数据信息进行

3.3 代码编译 CompilationManager

这个部分主要是对刚刚生成的代码进行编译的,具体细节请去看源码,这里暂时忽略

0 0
原创粉丝点击