分享

windows 下编译及使用flume

desehawk 2015-1-22 17:38:22 发表于 实操演练 [显示全部楼层] 回帖奖励 阅读模式 关闭右栏 3 69265

问题导读


1.编译flume需要哪些步骤?
2.flume如何在window下使用?





版本:flume 1.3.1

网友提供,非常好,借鉴之


windows下flume 1.0以上没有官方版本,但一些系统需要收集windows下程序和服务的日志。可以自己编译windows下版本。
编译所需环境:
1.maven 3.x
  1. http://mirror.bit.edu.cn/apache/maven/maven-3/3.0.4/binaries/apache-maven-3.0.4-bin.zip
复制代码

2.java sdk 1.6 以上
我的java安装在D:\Program Files\Java\jdk1.6.0_24\。
可以到oracle下载:
  1. http://www.oracle.com/technetwork/java/javase/downloads/index.html
复制代码

3.git
可以安装msysgit,下载地址:https://code.google.com/p/msysgi ... taller+official+git
4.解压工具,如winrar,haozip
5.编辑工具ultraedit,用于编辑conf文件
环境变量修改
右键点桌面上“我的电脑”,“属性”,进入“控制面板\系统和安全\系统”
点“高级系统设置”,设置“环境变量”
JAVA_HOME设为”D:\Program Files\Java\jdk1.6.0_24\”
M2_HOME设为D:\apache-maven-3.0.4-bin
M2 为 “%M2_HOME%\bin
MAVEN_OPTS 为 “-XX:MaxPermSize=1024M”
PATH里添加D:\apache-maven-3.0.4-bin\bin;%JAVA_HOME%\bin;
测试
cmd里输入mvn,git,java,看是否有相应输出。
编译flume
下载源文件:
http://www.apache.org/dyn/closer.cgi/flume/1.3.1/apache-flume-1.3.1-src.tar.gz
解压到D:\apache-flume-1.3.1-src
  1. D:\apache-flume-1.3.1-src>mvn clean
  2. D:\apache-flume-1.3.1-src>mvn package -DskipTests
  3. [INFO] Apache Flume ……………………………….. SUCCESS [32:00.307s]
  4. [INFO] Flume NG SDK ……………………………….. SUCCESS [1:06.691s]
  5. [INFO] Flume NG Configuration ………………………. SUCCESS [2.331s]
  6. [INFO] Flume NG Core ………………………………. SUCCESS [7.444s]
  7. [INFO] Flume NG Sinks ……………………………… SUCCESS [1.146s]
  8. [INFO] Flume NG HDFS Sink ………………………….. SUCCESS [4.112s]
  9. [INFO] Flume NG IRC Sink …………………………… SUCCESS [1.800s]
  10. [INFO] Flume NG HBase Sink …………………………. SUCCESS [4.246s]
  11. [INFO] Flume NG ElasticSearch Sink ………………….. SUCCESS [3.510s]
  12. [INFO] Flume Sources ………………………………. SUCCESS [1.093s]
  13. [INFO] Flume Scribe Source …………………………. SUCCESS [2.744s]
  14. [INFO] Flume NG Channels …………………………… SUCCESS [1.132s]
  15. [INFO] Flume NG JDBC channel ……………………….. SUCCESS [2.943s]
  16. [INFO] Flume NG Node ………………………………. SUCCESS [3.817s]
  17. [INFO] Flume NG file-based channel ………………….. SUCCESS [7.614s]
  18. [INFO] Flume NG file backed Memory channel …………… SUCCESS [4.066s]
  19. [INFO] Flume legacy Sources ………………………… SUCCESS [2.347s]
  20. [INFO] Flume legacy Avro source …………………….. SUCCESS [4.311s]
  21. [INFO] Flume legacy Thrift Source …………………… SUCCESS [6.173s]
  22. [INFO] Flume NG Clients ……………………………. SUCCESS [2.050s]
  23. [INFO] Flume NG Log4j Appender ……………………… SUCCESS [4.352s]
  24. [INFO] Flume NG distribution ……………………….. SUCCESS [48.551s]
  25. [INFO] Flume NG Integration Tests …………………… SUCCESS [3.277s]
  26. [INFO] ————————————————————————
  27. [INFO] BUILD SUCCESS
  28. [INFO] ————————————————————————
  29. [INFO] Total time: 35:06.425s
  30. [INFO] Finished at: Mon Feb 18 12:03:59 CST 2013
  31. [INFO] Final Memory: 140M/247M
  32. [INFO] ————————————————————————
复制代码

编译成功后,查看
  1. D:\apache-flume-1.3.1-src\flume-ng-dist\target
  2. apache-flume-1.3.1-bin.tar.gz
  3. apache-flume-1.3.1-src.tar.gz
复制代码

测试flume
解压apache-flume-1.3.1-bin.tar.gz到D:\apache-flume-1.3.1-bin
修改log4j
  1. D:\apache-flume-1.3.1-bin\conf\log4j.properties
复制代码


  1. #flume.root.logger=DEBUG,console
  2. flume.root.logger=INFO,LOGFILE
复制代码

改为
  1. flume.root.logger=DEBUG,console
  2. #flume.root.logger=INFO,LOGFILE
  3. 新建一个testconsole.conf文件,用console做输出
  4. syslog-agent.sources = Syslog
  5. syslog-agent.channels = MemoryChannel-1
  6. syslog-agent.sinks = Console
  7. syslog-agent.sources.Syslog.type = syslogTcp
  8. syslog-agent.sources.Syslog.port = 5140
  9. syslog-agent.sources.Syslog.channels = MemoryChannel-1
  10. syslog-agent.sinks.Console.channel = MemoryChannel-1
  11. syslog-agent.sinks.Console.type = logger
  12. syslog-agent.channels.MemoryChannel-1.type = memory
复制代码

保存到D:\apache-flume-1.3.1-bin\conf目录下
执行flume agent
linux下类似
  1. bin/flume-ng agent -n syslog-agent -f conf/syslog-agent.cnf
复制代码

windows下有点不一样,-Xmx最少可以到20m。
  1. D:\apache-flume-1.3.1-bin> “D:\Program Files\Java\jdk1.6.0_24\bin\java.exe” -Xmx50m -Dlog4j.configuration=file:///D:\apache-flume-1.3.1-bin\conf\log4j.properties -cp “D:\apache-flume-1.3.1-bin\lib\*” org.apache.flume.node.Application -f D:\apache-flume-1.3.1-bin\conf\testconsole.conf -n syslog-agent
复制代码

可以看到输出:
  1. 2013-02-18 15:44:58,370 (conf-file-poller-0) [DEBUG - org.apache.flume.conf.file
  2. .AbstractFileConfigurationProvider$FileWatcherRunnable.run(AbstractFileConfigura
  3. tionProvider.java:188)] Checking file:D:\apache-flume-1.3.1-bin\conf\testconsole
  4. .conf for changes
复制代码

到另一台linux机器下往windows 5140端口发syslog消息:
  1. [zhouhh@Hadoop48 trunk]$ echo “<13>zhh write a syslog message from zhh” > /tmp/foo
  2. [zhouhh@Hadoop48 trunk]$ nc -v 192.168.20.81 5140 < /tmp/foo
  3. Connection to 192.168.20.81 5140 port [tcp/*] succeeded!
复制代码

其中20.81是我刚运行了flume的windows机器。
这时,在windows命令行看到:
  1. 2013-02-18 15:48:08,922 (SinkRunner-PollingRunner-DefaultSinkProcessor) [INFO -
  2. org.apache.flume.sink.LoggerSink.process(LoggerSink.java:70)] Event: { headers:{
  3. Severity=5, Facility=1} body: 7A 68 68 20 77 72 69 74 65 20 61 20 73 79 73 6C zh
  4. h write a sysl }
复制代码

已经收到syslog消息。
参考:
下面这两篇博文是clouder公司flume的开发者Alex发的。我编译测试主要参考他的博文,一次通过。
http://mapredit.blogspot.com/2012/07/run-flume-13x-on-windows.html?showComment=1361158732748#c3717966993715817903
http://mapredit.blogspot.de/2012/03/flumeng-evolution.html











周海汉/文






已有(3)人评论

跳转到指定楼层
stark_summer 发表于 2015-1-23 17:49:14
回复

使用道具 举报

chinaboy2005 发表于 2015-3-17 18:09:02
回复

使用道具 举报

sprite101 发表于 2015-5-12 17:09:00
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

推荐上一条 /2 下一条