hadoop个人理解

 

2 hadoop三种方式

Local:

需要改hadoop-site.xml—java——home

Hadoop-default是主要配置,不需要更改

命令:

hadoop/bin/hadoop demo.hadoop.HadoopGrep log文件所在目录 任意的输出目录 grep的字符串

3 重写例子

package com.hadoop.example; 

import java.io.File;
import java.util.ArrayList;
import java.util.List;

import org.apache.catalina.filters.AddDefaultCharsetFilter;

import com.sun.org.apache.bcel.internal.generic.NEW;


public class HReal {

	public static void main(String[] args) {
		
	}
	public void work(){
		JobConf conf = null;
		Mapper mapper = new Mapper();
		Reducer reducer = new Reducer();
		InputFormat inputFormat = new InputFormat();
		OutputFromat outputFromat = new OutputFromat();
		String inpathString ="";
		String outpathString="";
		
		JobTracker jobTracker = new JobTracker();
		Job job = new Job();
		jobTracker.addJob(job);
		if(job.flg=true){
			
		}
		
	}
}

class Mapper{
	private String kString;
	private String vString;
	public void deal(Class c){
		
	}
	private void deal(String s){
		
	}
	
	
	public SequenceFile deal(String kString,String vString){
		this.kString=kString;
		this.vString=vString;
		return new SequenceFile();
	}
}
class SequenceFile{
	
}
class Reducer{
	private String resultString;
	private String middleString;
	public  String  deal(){
		return resultString;
	}
}
class InputFormat{
	
	public RecordReader newReader(){
		return new RecordReader();
	}
	
	public Object format(String line){
		return line;
	}
	
	public Object  format(String line, Object type){
		if(type instanceof String){
			return line;
		}
		if(type instanceof Class){
			return line.getClass();
		}
		return line;
	}
	
	public FileSplist getSplits(String pathfile){
		File file=new File(pathfile);
		//分割文件处理
		return new FileSplist();
	}
}
class FileSplist{
	
}
class OutputFromat{
	public void write(String result){
		
	}
}
class NameNode{
	
}
class DataNode{
	
}
class Master{
	private JobTracker jobTracker;
	private NameNode nameNode;
}
class JobTracker{
	private MapReduce mapReduce;
	private InputFormat inputFormat;
	List<Job> jobs = new ArrayList<Job>();
	public void addJob(Job job){
		jobs.add(job);
	}
	public void nextJob(){
		
		jobs.get(this.getCurrentFlg());
	}
	public int getCurrentFlg(){
		return 1;
	}
	public void currState(){
		
	}
}
class MapReduce{
	
}
class JobConf{
	
}
class Job{
	static boolean flg = false;
	public void run(){
		System.out.println("deal");
		flg=true;
	}
}
class MapperTask{
	List<FileSplist> lst = new ArrayList<FileSplist>();
	InputFormat inputFormat;
	public void addTask(FileSplist fileSplist){
		lst.add(fileSplist);
	}
	
	public void read(){
//		lst.get(0)
	}
}
class Queue{
	List lst = new ArrayList();
	public void addMapperTask(MapperTask mapperTask){
		lst.add(mapperTask);
	}
}
class TaskTracker{
	int taskCount=0;
	JobTracker jobTracker;
	
	public void nextMapReduce(){
		jobTracker.nextJob();
	}
	public void deal(){
		
	}
	//定时报告任务情况
	public void schele(){
		System.out.println("当前任务完成了多少了");
		jobTracker.currState();
		if(taskCount ==3){
			nextMapReduce();
		}
		try {
			Thread.sleep(10000);
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
	}
}
class RecordReader{
	
}
class ReducerTask{
	Reducer reducer;
	OutputFromat outputFromat;
	public void sort(){
		
	}
	public void merge(){
		
	}
	public void deal(){
		sort();
		merge();
		String resultString = reducer.deal();
		outputFromat.write(resultString);
	}
}


 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

静山晚风

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值