⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rebuildpostindextask.java

📁 解觖java技术中后台无法上传数给的情况
💻 JAVA
字号:
/*
 * $Header: /cvsroot/mvnforum/mvnforum/src/com/mvnforum/search/post/RebuildPostIndexTask.java,v 1.10 2006/04/14 17:05:27 minhnn Exp $
 * $Author: minhnn $
 * $Revision: 1.10 $
 * $Date: 2006/04/14 17:05:27 $
 *
 * ====================================================================
 *
 * Copyright (C) 2002-2006 by MyVietnam.net
 *
 * All copyright notices regarding mvnForum MUST remain 
 * intact in the scripts and in the outputted HTML.
 * The "powered by" text/logo with a link back to
 * http://www.mvnForum.com and http://www.MyVietnam.net in 
 * the footer of the pages MUST remain visible when the pages
 * are viewed on the internet or intranet.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 * Support can be obtained from support forums at:
 * http://www.mvnForum.com/mvnforum/index
 *
 * Correspondence and Marketing Questions can be sent to:
 * info at MyVietnam net
 *
 * @author: Minh Nguyen  
 * @author: Dejan Krsmanovic dejan_krsmanovic@yahoo.com
 */
package com.mvnforum.search.post;

import java.io.IOException;
import java.util.*;

import com.mvnforum.MVNForumConfig;
import com.mvnforum.db.DAOFactory;
import com.mvnforum.db.PostBean;
import net.myvietnam.mvncore.exception.DatabaseException;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.store.Directory;

/**
 * Rebuilding indices task. This task do indexing of all documents
 */
public class RebuildPostIndexTask extends TimerTask
{
    private static Log log = LogFactory.getLog(RebuildPostIndexTask.class);

    public static final int POSTS_PER_FETCH = 200;

    public static final int MERGE_FACTOR  = 20;

    private int maxPostID = 0;

    private static boolean isRebuilding = false;

    public static boolean isRebuilding() {
        return isRebuilding;
    }

    /*
     * Contructor with default access, prevent new an instance from outside package
     */
    RebuildPostIndexTask(int maxPostID) {
        this.maxPostID = maxPostID;
    }

    /**
     * Create new index. If anything exist already - delete it
     */
    public void run() {
        isRebuilding = true;
        long start = System.currentTimeMillis();

        Directory directory = null;
        IndexWriter writer = null;
        try {
            directory = MVNForumConfig.getSearchPostIndexDir();
            writer = PostIndexer.getIndexWriter(directory, true);
            writer.mergeFactor = MERGE_FACTOR;
            // note that the maxPostID is get at the begining of the method
            // so that it will index only these posts. Later while indexing,
            // if new posts are added, then other task will take care it
            if (maxPostID <= 0) {
                maxPostID = DAOFactory.getPostDAO().getMaxPostID();
            }
            int count = 0;

            for (int fromID = 0; fromID <= maxPostID /* <= is correct */; fromID += POSTS_PER_FETCH) {
                int toID = fromID + POSTS_PER_FETCH - 1;
                if (toID > maxPostID) {
                    toID = maxPostID;
                }
                Collection posts = DAOFactory.getPostDAO().getPosts_fromIDRange(fromID, toID);

                for (Iterator iter = posts.iterator(); iter.hasNext(); ) {
                    PostBean post = (PostBean) iter.next();
                    PostIndexer.doIndexPost(post, writer);
                    count++;
                }
            } //end for

            writer.optimize();
            log.info("Rebuilt index finished successfully! " + count + " post(s) indexed.");
        } catch (DatabaseException ex) {
            log.error("RebuildPostIndexTask.run : cannot get posts from database for indexing", ex);
        } catch (Exception e) {
            log.error("Error while rebuilding index", e);
        } finally {
            if (writer != null) {
                try {
                    writer.close();
                } catch (IOException e) {
                    log.debug("Error closing Lucene IndexWriter", e);
                }
            }
            if (directory != null) {
                try {
                    directory.close();
                } catch (IOException e) {
                    log.debug("Cannot close directory.", e);
                }
            }
        }
        log.info("RebuildPostIndexTask took " + (System.currentTimeMillis() - start) + " ms");
        isRebuilding = false;
    }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -