Я использую следующие коды для записи некоторых данных в файл формата SequenceFile. когда программа запускается некоторое время, я прерываю программу с помощью красной кнопки на консоли eclipse. однако, когда я проверяю файл данных на hdfs, размер файла последовательности равен нулю. а также не может использовать команду «hadoop fs -text filename» для просмотра файла. когда я использую SequenceFile.Reader, прочитав ранее созданный файл, я встречаю исключение «Исключение в потоке» основного исключения «java.io.EOFException». В этом случае, как это сделать? моя среда разработки - eclipse3.7 (на окнах 7) и кластер hadoop (версия 1.0.0) для CentOS 6.use SequenceFile класс записать файл
класс Sequence расширяет тему {
private String uri = "hdfs://172.20.11.60:9000";
private String filePath = "/user/hadoop/input/";
private String fileName = "Sequence-01.seq";
public SequenceFile.Writer writer;
private static int cnt = 0;
private void init() {
Configuration conf = new Configuration();
try {
FileSystem fs = FileSystem.get(URI.create(uri), conf);
writer = SequenceFile.createWriter(fs, conf, new Path(filePath
+ fileName), LongWritable.class, Text.class);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public Sequence() {
init();
}
@Override
public void run(){
while(true){
try {
writer.append(new LongWritable(100), new Text("hello,world"));
cnt++;
if(cnt%100 == 0){
System.out.println("flush current data to file system");
writer.syncFs();
}
} catch (IOException e) {
// TODO Auto-generated catch block
System.out.println("append data error");
e.printStackTrace();
}
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
System.out.println("thread interupted");
e.printStackTrace();
}
}
}
}
класса TestSequenceFile общественности {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
new Sequence().start();
}
}