使用RandomAccessFile来读取不断增长的文件

本文详细介绍了如何通过后台日志文件实时读取并将其内容展示至客户端socket中,包括文件路径获取、输出流创建、日志信息显示等关键步骤。实现了将日志信息按行读取并发送至客户端,确保客户端能够接收到完整更新的日志内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

实现的功能是将后台产生的日志文件读取到客户端sokect中,并显示出来

package code.thread;

import java.io.File;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.io.RandomAccessFile;
import java.net.Socket;


public class RunStatusThread extends Thread{
	private Socket clientRequestStatus;  //客户端套接字
	private PrintWriter output;   //向文本输出流打印对象的格式化表示形式
	 
	//构造函数
	public RunStatusThread(Socket clientRequestStatus){
				this.clientRequestStatus = clientRequestStatus;
	}
	
	/**
     * 以行为单位读取文件,常用于读面向行的格式化文件
     */
	public void run(){
		String aFile = "forPath";
		File f = new File(aFile);
		//创建文件后得到path为/home/gxudonghe/workspace/HDVer/forPath
		String path = f.getAbsoluteFile().toString();
	
	try {
		output = new PrintWriter(new OutputStreamWriter(clientRequestStatus.getOutputStream()));
	} catch (IOException e1) {
		// TODO Auto-generated catch block
		e1.printStackTrace();
	}	
	
	output.println("Welcome to the Status Server! Now is "+new java.util.Date()+" "+"Port: "+clientRequestStatus.getLocalPort());
	output.println("=========================The log information is============================");
	output.flush();

	
	
		// 用创建一个文件的方法,得出当前的目录为/home/gxudonghe/workspace/HDVer/,类型为字符串
		String curDir = path.substring(0, path.indexOf(aFile));
		String fileName=curDir+"Daemon_log.txt";
		 File file = new File(fileName);
	        try {
	        	//实用随机文件读取的方法来处理不断增长的文件
	        	RandomAccessFile raf=new RandomAccessFile(file,"r");
	           
	            // 获取当前文件的总长度
	        	long fileLen=0;
	        	long strSumLen=0;
	            while (true) {
	            	raf.getFilePointer();
	            	String tempString=raf.readLine();
	            	if(null!=tempString){
	                output.println( tempString);
	                output.flush();
	                strSumLen+=tempString.length();
	            	}
	            	fileLen=raf.length();
	            	if(fileLen<=strSumLen){
	            		sleep(1000);
	            	}
	            }
	       

	        } catch (IOException e) {
	            e.printStackTrace();
            } catch (InterruptedException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			} 
	           
	}
	
}


 

纠结了好久才搞定,因为如果不使用RandomAccessFile对象,客户端读到的文件都是部分长度,新增的并没有读取。客户端的代码如下:

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.Socket;


public class StatusCommand {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		try{
			Socket socket=new Socket("192.168.1.110",56533);
	
			BufferedReader is=new BufferedReader(new InputStreamReader(socket.getInputStream()));
			
			while(is.readLine()!=null)
			{
				String responseline=is.readLine();
				System.out.println(responseline);
			}
			
			is.close();
			socket.close();
		}catch(IOException e){
			e.printStackTrace();
		}
			}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值