hadoop - 使用python hdfs模块或者其他类似模块过滤HDFS上的日志日志内容
问题描述
目前公司使用HDFS存储各个节点服务器上传的日志。因为历史遗留问题,所以日志比较混杂。就是各种数据都会存入日志中。一个日志文件200mb左右。有时候要过滤一些内容,则需要根据时间戳,然后使用hdfs 的cat命令,之后再grep关键字。再通过stdin输入到一个python脚本中,把相关的数据做一些处理。现在我想把他做成输入要查询的时间、节点、关键字以及匹配模型,然后一条龙完成这个任务。这样就可以把这个小工具推向所有需求数据的人,而不是每次让运维来查询。于是开始研究python的相关模块,这个hdfs可以上传下载,查询目录文件内容。但是到读这块,就比较麻烦了。with client.read(hdfs_path=.....,其他参数)as reader:
content = reader.read()然后再对content处理
这种方式并不可行,因为一次要匹配的内容实在太多,大概有几gb的数据,根本不可能全部读出来然后再做处理。肯定得在读的过程就进行筛选和处理
我尝试了for line in content,也匹配不出内容。应该如何解决这个问题呢?难道用python把符合条件的文件路径记录下来,然后再执行HDFS命令,再把匹配的数据传入python?那样也显得太麻烦了,而且稳定性肯定不好
后来我看了一下,hdfs这个模块,创建客户端的时候,连的是hadoop 50070这个web管理页面,想了下是不是这个模块本身就不是为了做数据分析用的?希望各位能给点帮助
问题解答
回答1:多线程呢,并行计算呢?你这样一次性读几个Gb自然慢。既然是hadoop框架,用好mapreduce应该就行了吧。这玩意应该就不是为了快速而设计的。
相关文章:
1. objective-c - 从朋友圈跳到我的APP 如何实现?2. java - PHP开发微信无法获取到signature,timestamp,nonce3. 请教一个python字符串处理的问题?4. HTML5禁止img预览该怎么解决?5. 怎么可以实现在手机浏览器看到链接的title属性,就是鼠标放上去会有一个tip效果的6. 如何分别在Windows下用Winform项模板+C#,在MacOSX下用Cocos Application项目模板+Objective-C实现一个制作游戏的空的黑窗口?7. 网页爬虫 - python爬虫用BeautifulSoup爬取<s>元素并写入字典,但某些div下没有这一元素,导致自动写入下一条,如何解决?8. html5 - h5+中webview的show方法有延迟9. javascript - vscode alt+shift+f 格式化js代码,通不过eslint的代码风格检查怎么办。。。10. javascript - html 中select如何修改样式,鼠标悬浮时改变option样式,有没有插件啊
