文档章节

使用java读取大文本文件(2G)

abcijkxyz
 abcijkxyz
发布于 2016/07/08 16:29
字数 296
阅读 11
收藏 0

 最忌服务器不稳定一直出现各种问题,莫名其妙的出现404,500的等错误,并且时好时坏。

只有分析web 服务器的日志,上去一看,我滴个神呢~~~2G。

工具各种尝试,各种卡死,各种缓慢。折腾半天,,没辙~~

只好使用java写个读取的吧,开始打算使用commons-io来读取,一运行,OOM了。

看来只能使用一点点读取了,写了下面的代码。居然可以了。

 

public class AnlyLogApache {
 
 public static void main(String[] args) throws Exception {
//  List<String> lines = FileUtils.readLines(new File("D:/工作资料-微软/项目资料/市民网(一期)/2011-10-28_102apache分析/access20111026.log"));
//  for (String string : lines) {
//   if(string.indexOf("HTTP/1.1\" 500") != -1 && string.indexOf("HTTP/1.1\" 404")!=-1) {
//    System.out.println(string);
//   }
//  }
  
  File file = new File("access20111027.log");
  
  BufferedReader 
  bin   =   new   BufferedReader(new   InputStreamReader(new   FileInputStream( file)));
  String   str=   null;  
  
  Map<String, String> map = new HashMap<String, String>();
  int sum = 0;
  int start = 0;
  int end = 0;
  while((str=   bin.readLine())   !=   null)
  {

   
   if( (str.indexOf("/gzns") != -1 || str.indexOf("/p-homepage") != -1 )&&(str.indexOf("HTTP/1.1\" 500") != -1 /*|| str.indexOf("HTTP/1.1\" 404")!=-1*/)) {
    
    start = str.indexOf("GET");
    if(start == -1) {
     start = str.indexOf("POST");
    }
    if(start == -1) {
     start = 0;
    }
    end = str.indexOf("Mozilla/4.0");
    if(end == -1) {
     end = str.length();
    }
    sum++;
    //System.out.println(start+"   "+end);
    map.put(str.substring(start,end), str);
   }
  }
  
  Set<String> keys = map.keySet();
  for (String string : keys) {
   System.out.println(map.get(string));
  }
  System.out.println("==================="+sum+"=================");
  bin.close();

  
 }

 

本文转载自:http://blog.csdn.net/yuwenruli/article/details/6913570

共有 人打赏支持
abcijkxyz
粉丝 63
博文 6196
码字总数 1876
作品 0
深圳
项目经理
私信 提问
java 读写大文件用nio出错了

最近在学习java io 试了下java读写大文件(2G+的一部电影)。单纯使用io,花费了259秒如下: 使用ByteBuffer,花费98秒: 浏览jdk文档的时候发现TransferFrom 和TransferTo能够把直接把两个通道相...

chen1922
2012/01/11
724
1
Java读带有BOM的UTF-8文件乱码原因及解决方法

最近在处理文件时发现了同样类型的文件使用的编码可能是不同的。所以想将文件的格式统一一下(因为UTF-8的通用性,决定往UTF-8统一),遇见的第一个问题是:如何查看现有文件的编码方式。 上网...

张志浩
2012/11/06
0
0
基于Java Properties类设置本地配置文件

一、Java Properties类介绍 Java中有个比较重要的类Properties(Java.util.Properties),主要用于读取Java的配置文件,各种语言都有自己所支持的配置文件,配置文件中很多变量是经常改变的,...

HM巧克力酱
08/22
0
0
Ant 中 *Log4j.properties 找不到文件的问题

在用 Ant 进行构建,部署,运行过程中,发现一小问题,就是在运行时总是提示“系统找不到指定的文件”。害得我花了不少时间,最后终于弄清楚了问题的原因。以下的错误代码(贴出来好让后面的...

xiaofer2008
2011/01/14
0
0
Java: I/O(1/3)字节流与字符流的纵向与横向比较

Summary 总述 java.io包中的类非常繁多,但其实只要归成4类: & 、 & ,由于功能和命名上都相当接近,因此只要掌握了其中一种,将会很容易理解其他3种。 横向归类: & (字节流)、 & (字符...

大鱼BIG_FISH
2015/11/16
0
2

没有更多内容

加载失败,请刷新页面

加载更多

《Maven官方文档》-Maven依赖机制简介

《Maven官方文档》-Maven依赖机制简介 原文地址 译者:Tyrian 依赖机制是Maven最为用户熟知的特性之一,同时也是Maven所擅长的领域之一。单个项目的依赖管理并不难, 但是当你面对包含数百个...

tantexian
15分钟前
0
0
基于 Docker 快速部署多需求 Spark 自动化测试环境

引言 在进行数据分析时,Spark 越来越广泛的被使用。在测试需求越来越多、测试用例数量越来越大的情况下,能够根据需求快速自动化部署 Spark 环境、快速完成所有测试越来越重要。 本文基于 ...

呐呐丶嘿
32分钟前
2
0
支付宝APP支付之查看支付宝商户ID

1、登录支付宝蚂蚁金服开放平台 2、查看账号详情,选择合作伙伴管理,账户管理,查看角色身份,此处的PID就是商户ID 3、点击秘钥管理,可查看绑定的相关应用及其APPID等信息

Code辉
35分钟前
2
0
崛起于Springboot2.X之通讯WebSocket(40)

技术简介:Springboot2.0.3+freemaker+websocket 1、添加pom依赖 <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-bo......

木九天
44分钟前
1
0
Java常用四大线程池用法以及ThreadPoolExecutor详解

为什么用线程池? 1.创建/销毁线程伴随着系统开销,过于频繁的创建/销毁线程,会很大程度上影响处-理效率 2.线程并发数量过多,抢占系统资源从而导致阻塞 3.对线程进行一些简单的管理 在Java中...

孟飞阳
46分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部