除了使用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. 全7 天玩转 ASP.NET MVC — 第 2 天

    0. 前言 我相信在开始第 2 天的学习时,你已经顺利地完成了第 1 天的课程. 我们回顾一下第 1 天的主要关注点: 为什么选择 ASP.NET MVC ? ASP.NET Webforms 和 A ...

  2. call by reference and copy/restore

    转自:http://stackoverflow.com/questions/8848402/whats-the-difference-between-call-by-reference-and-cop ...

  3. 机器学习之逻辑回归(Logistic Regression)

    1. Classification 这篇文章我们来讨论分类问题(classification problems),也就是说你想预测的变量 y 是一个离散的值.我们会使用逻辑回归算法来解决分类问题. 之 ...

  4. poj 3522(最小生成树应用)

    题目链接:http://poj.org/problem?id=3522思路:题目要求最小生成树中最大边与最小边的最小差值,由于数据不是很大,我们可以枚举最小生成树的最小边,然后kruskal求最小生成 ...

  5. JS中的内部类

     js内部类 javascript中本身有提供一些可以直接使用的类,这种类就是内部类.主要有:Object.Array.Math.Boolean.String.Number.Date.RegExp. ...

  6. Java 获取本机IP

    import java.io.*; import java.util.*; import java.net.*; public class GetIP { public static void mai ...

  7. 快速创建maven 工程:simple java工程,webapp

    http://www.cnblogs.com/buhaiqing/archive/2012/11/04/2754187.html 会从maven的Repository里查找所有支持的arche typ ...

  8. IE9 JSON未定义

    原文:http://social.msdn.microsoft.com/Forums/ie/en-US/fc41127c-0243-4d2e-8e7c-2b311f12e390/ie9-json-no ...

  9. SWD接口:探索&泄密&延伸

    http://bbs.21ic.com/icview-871133-1-1.html 文买了个JLINKV9,以为神器,拿到手发现根本不是,完全没必要替换V8,想自己做个另类的调试器,当然想只是想而已 ...

  10. Keil MDK编译器(V4.03)与J-LINK使用

    前几天进手了一个J-LINK,因为H-JTAG毕竟对MDK支持的不是太完美,比如用keil mdk上面的下载按钮烧录程序,不是直接就能烧录进去,而是弹出H-Flash软件,再手工选择文件烧录:而且用H ...