log4j+flume+HDFS实现日志存储

本文详细介绍了Apache Flume的配置方法,包括如何设置Avro source、内存channel及HDFS sink,同时还展示了如何利用log4j进行日志记录,最终实现将日志数据上传至HDFS的过程。
摘要由CSDN通过智能技术生成
Flume配置文件

apache-flume-1.7.0-bin/data/weblog.conf

a1.sources = s1
a1.channels = c1
a1.sinks = k1

a1.sources.s1.type = avro
a1.sources.s1.bind = 0.0.0.0
a1.sources.s1.port = 44444
//配置拦截器
a1.sources.s1.interceptors = i1
a1.sources.s1.interceptors.i1.type = timestamp

a1.channels.c1.type = memory
a1.channels.c1.capacity = 1000
a1.channels.c1.transactionCapacity = 100

a1.sinks.k1.type = hdfs
a1.sinks.k1.hdfs.path = hdfs://hadoop01:9000/weblog/reporttime=%Y-%m-%d
a1.sinks.ke.hdfs.fileType = DataStream
a1.sinks.k1.hdfs.rollInterval = 30
a1.sinks.k1.hdfs.rollSize = 0
a1.sinks.k1.hdfs.rollCount = 0

a1.sources.s1.channels = c1
a1.sinks.k1.channel = c1
log4j.properties
log4j.rootLogger = info,stdout,flume

log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = %m%n

log4j.appender.flume = org.apache.flume.clients.log4jappender.Log4jAppender
log4j.appender.flume.Hostname = 192.168.197.128
log4j.appender.flume.Port = 44444
log4j.appender.flume.UnsafeMode = true
LogServlet.java
package cn.tedu;

import java.io.IOException;
import java.net.URLDecoder;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.log4j.Logger;



public class LogServlet extends HttpServlet {
	private Logger logger = Logger.getLogger(LogServlet.class);
	
	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		
		String info = URLDecoder.decode(request.getQueryString(),"utf-8");
		
		
		//按照&将属性切分出来
		String[] kvs = info.split("\\&");
		
		//将所有的value拼接在一起,形式:value|value|value
		StringBuffer buffer = new StringBuffer();
		for	(String kv : kvs) {
			//注意:ref是来自页面的属性,可能没有value,为了避免报错,需要进行处理
			String value = kv.split("=").length == 2 ? kv.split("=")[1] : "";
			buffer.append(value + "|");
		}
		//拼接上用户的ip地址
		buffer.append(request.getRemoteAddr());
		System.out.println(buffer);
		logger.info(buffer);
		
		//将数据封装成日志
		//记录日志的级别从低到高依次是:debug->info->warn->error->fatall
		//记录日志必须要有log4j.properties属性配置文件
		//在属性配置文件中,一是指定最低的日志记录级别
		//如果记录的级别小于配置的最低级别,则不会输出日志
		//二是指定记录的日志的输出的目的地
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

}

JSP随便写一个
启动Tomcat服务
启动Hadoop
启动Flume

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WA0kGcGb-1598961442313)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20200901195712699.png)]

刷新JSP页面即可获得请求信息,并将请求信息写到日志中,日志文件上传到HDFS

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lXL3zrBX-1598961442317)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20200901195646251.png)]在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

夜色如墨

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

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

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

打赏作者

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

抵扣说明:

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

余额充值