除了使用Hive,Pig来执行一个MapReduce任务,不需要专门的把项目打成jar包,提交执行,或者定时执行,因为Hive,Pig这些开源框架已经,帮我们自动打包上传了。

而有些时候,我们自己手写了一个MapReduce的任务,然后这个任务里面依赖了其他的第三方包,比如说是Lucene的,或者是Solr,ElasticSearch的,那么打包的时候就需要将这些依赖的jar包也一起的打包进去。

如果你用的是maven,那么事情就简单了,maven会自动把所有依赖的jar包,打成一个统一的jar,但是通常不需要maven,因为maven相对来说,还是比较复杂,我们更倾向于使用ant来打包,配置很灵活。

那么,如何向hadooop集群提交作业呢? 
通常的命令如下: 
hadoop jar  xxx.jar input out 
这样就会把jar包提交到hadoop集群上,只要包含依赖的jar也在这个jar包中,那么程序就不会出问题。

那么,问题来了? 我想定时执行一个作业,应该怎么写呢

如果直接在linux下的crontab中,写定时启动的脚本,没问题,但是如果你的脚本是启动一个mr的任务,那么就有可能出现问题了,因为执行MR,是需要Hadoop的环境变量的,在crontab启用的shell进程,默认是没有激活环境变量的,所以,你有可能发现,自己的写的crontab脚本,奇怪的失效了。

如何解决在crontab的进程里环境变量失效的问题?

很简单,在启动的脚本开始前,再次激活的环境变量即可,代码如下:

  1. #!/bin/bash
  2. ##下面的2行代码很重要,如果不再次激活环境变量,hadoop的jar就不能正确提交任务
  3. . /etc/profile
  4. . ~/.bash_profile

另外在crontab中,需要cd到当前目录下,执行,否则一些log不会被正确到该工程,或目录下:

  1. //在下午的14点39分启动一个定时任务,使用nohup 挂起后台运行,并将所有的log重定向到一个log文件里
  2. 39 14 * * *  cd /home/search/qindongliang/cr-dataload ; nohup sh start.sh 1  2015-04-10 all &> rate.log    &

另外一点需要注意,如果在crontab的进程中执行任务,那么最好使用nohup挂起后台运行,否则,hadoop的系统log会丢失,因为默认是在终端的界面上打印的。

  1. [search@fsedump01sand cr-dataload]$ cat start.sh
  2. #!/bin/bash
  3. ##下面的2行代码很重要,如果不再次激活环境变量,hadoop的jar就不能正确提交任务
  4. . /etc/profile
  5. . ~/.bash_profile
  6. echo "hadoop的home:"$HADOOP_HOME
  7. echo `pwd`
  8. if [ ! $# -eq 3  ] ; then
  9. echo "第一个参数:请输入要处理的dataload业务 1:rate 2:keyword  "
  10. echo "第二个参数:请输入读取HDFS上读取数据的开始日期, 例如: 2015-04-10  "
  11. echo "第三个参数:请输入读取HDFS上读取数据的结束日期, 例如: 2015-05-10  "
  12. exit
  13. fi
  14. #参数1,mapping文件的地址
  15. p1="/user/d1/mapping.xml"
  16. #参数4,是否清空上一次的保存目录,0=清除,1=不清除
  17. p4="0"
  18. if [ $1 -eq  1  ] ; then
  19. #参数2,处理数据的输入路径
  20. p2="1"
  21. p3="/fse2/conversions/rate/shard1/input"
  22. p5="rate"
  23. elif [ $1 -eq 2 ] ; then
  24. #参数2,处理数据的输入路径
  25. p2="2"
  26. p3="/fse2/conversions/keyword/shard1/input"
  27. #参数5,控制那个索引的
  28. p5="keyword"
  29. else
  30. echo  "不支持此参数,只能输入1或者2,请注意!"
  31. exit
  32. fi
  33. echo "==============参数信息=============="
  34. echo $p1
  35. echo $p2
  36. echo $p3
  37. echo $p4
  38. echo $p5
  39. echo $2
  40. echo $3
  41. echo "===================================="
  42. #exit
  43. #参数3,处理数据结果的保存路径
  44. #p3="/user/d1/uvoutput"
  45. #p3="/user/d1/kwoutput"
  46. #p3="/fse2/conversions/keyword/shard1/input"
  47. #p3="/fse2/conversions/uv/shard1/input"
  48. #参数4,是否清空上一次的保存目录,0=清除,1=不清除
  49. #p4="0"
  50. #参数5,控制那个索引的
  51. #p5="keyword"
  52. #p5="uv"
  53. cs='.:'
  54. root="`pwd`/"
  55. curr="`pwd`/conf"
  56. echo $curr
  57. libpath="`pwd`/lib/"
  58. FILES=`ls $libpath`
  59. for txt in $FILES;do
  60. cs=$cs$libpath$txt:
  61. done
  62. cs=$cs$curr:$root"cr-dataload.jar"
  63. echo $cs
  64. echo [`date`] "开始启动dataload!"
  65. #nohup sh offline.sh  2014-12-01 2014-12-15 &> nohup.out &
  66. #hadoop jar  cr-dataload.jar   com.dhgate.search.rate.convert.StoreConvert -libjars $cs
  67. #java -cp $cs  com.dhgate.search.rate.convert.StoreConvert  $p1 $p2 $p3 $p4 $p5 $2 $3
  68. #/home/search/hadoop/bin/hadoop jar  cr-dataload.jar   com.dhgate.search.rate.convert.StoreConvert  $p1 $p2 $p3 $p4 $p5 $2 $3  > $p2.log
  69. hadoop jar  cr-dataload.jar   com.dhgate.search.rate.convert.StoreConvert  $p1 $p2 $p3 $p4 $p5 $2 $3
  70. #echo $cs

如何向hadoop集群定时提交一个jar作业?的更多相关文章

  1. 深入理解Hadoop集群和网络

    导读:云计算和Hadoop中网络是讨论得相对比较少的领域.本文原文由Dell企业技术专家Brad Hedlund撰写,他曾在思科工作多年,专长是数据中心.云网络等.文章素材基于作者自己的研究.实验和C ...

  2. 深入理解Hadoop集群和网络【转】

    http://os.51cto.com/art/201211/364374.htm 本文将着重于讨论Hadoop集群的体系结构和方法,及它如何与网络和服务器基础设施的关系.最开始我们先学习一下Hado ...

  3. 初学Hadoop:利用VMWare+CentOS7搭建Hadoop集群

     一.前言 开始学习数据处理相关的知识了,第一步是搭建一个Hadoop集群.搭建一个分布式集群需要多台电脑,在此我选择采用VMWare+CentOS7搭建一个三台虚拟机组成的Hadoop集群. 注:1 ...

  4. 编写hadoop程序,并打包jar到hadoop集群运行

    windows环境下编写hadoop程序 新建:File->new->Project->Maven->next GroupId 和ArtifactId 随便写(还是建议规范点) ...

  5. Eclipse远程提交hadoop集群任务

    文章概览: 1.前言 2.Eclipse查看远程hadoop集群文件 3.Eclipse提交远程hadoop集群任务 4.小结   1 前言 Hadoop高可用品台搭建完备后,参见<Hadoop ...

  6. Eclipse提交任务至Hadoop集群遇到的问题

    环境:Windows8.1,Eclipse 用Hadoop自带的wordcount示例 hadoop2.7.0 hadoop-eclipse-plugin-2.7.0.jar //Eclipse的插件 ...

  7. hadoop 把mapreduce任务从本地提交到hadoop集群上运行

    MapReduce任务有三种运行方式: 1.windows(linux)本地调试运行,需要本地hadoop环境支持 2.本地编译成jar包,手动发送到hadoop集群上用hadoop jar或者yar ...

  8. 在windows远程提交任务给Hadoop集群(Hadoop 2.6)

    我使用3台Centos虚拟机搭建了一个Hadoop2.6的集群.希望在windows7上面使用IDEA开发mapreduce程序,然后提交的远程的Hadoop集群上执行.经过不懈的google终于搞定 ...

  9. 用Docker在一台笔记本电脑上搭建一个具有10个节点7种角色的Hadoop集群(上)-快速上手Docker

    如果想在一台电脑上搭建一个多节点的Hadoop集群,传统的方式是使用多个虚拟机.但这种方式占用的资源比较多,一台笔记本能同时运行的虚拟机的数量是很有限的.这个时候我们可以使用Docker.Docker ...

随机推荐

  1. HDU 4287 Intelligent IME(string,map,stl,make_pair)

    题目 转载来的,有些stl和string的函数蛮好的: //numx[i]=string(sx); //把char[]类型转换成string类型 // mat.insert(make_pair(num ...

  2. java 格式化代码 不进行换行

    此处无声胜有声.

  3. m_pMainWnd(转载)

    今天写程序时遇到个简单而又很有意思的问题,封装了一个网络接口类,发送数据以及网络的回调接口都在这个类里面,打算在回调函数里给AfxGetMainWnd()发送消息以更新主界面的数据,同时程序有一个登录 ...

  4. hdu 3118(二进制枚举)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3118 思路:题目要求是去掉最少的边使得图中不存在路径长度为奇数的环,这个问题等价于在图中去掉若干条边, ...

  5. 斐波那契数列公式算法-JS实现

    之前算斐波那契数列都是算前两个数相加实现的 比如0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597,2584,4181 ...

  6. Android 核心分析 之六 IPC框架分析 Binder,Service,Service manager

    IPC框架分析 Binder,Service,Service manager 我首先从宏观的角度观察Binder,Service,Service Manager,并阐述各自的概念.从Linux的概念空 ...

  7. jsp中如何用jstl实现if(){}else if(){}else{}

    <c:choose> <c:when test="${条件}"> 情况1........... </c:when> <c:when tes ...

  8. Python模块包中__init__.py文件的作用

    转载自:http://hi.baidu.com/tjuer/item/ba37ac4ce7482a0f6dc2f08b 模块包: 包通常总是一个目录,目录下为首的一个文件便是 __init__.py. ...

  9. ORACLE基本语法

    ORACLE基本语法 一.ORACLE的启动和关闭1.在单机环境下要想启动或关闭ORACLE系统必须首先切换到ORACLE用户,如下su - oraclea.启动ORACLE系统oracle>s ...

  10. SQL语句 递归

    --正向递归查询(根据ID查到自己和自己以下的所有数据)   connect by prior a.id = a. parentid   --反向递归查询(根据叶子ID查出自己和自己以上的根数据)   ...