테스트

aion-server 4.8

Gitteol
최고관리자 · 1 · 💬 0 클론/새로받기
 4.8 61f661d · 1 commits 새로받기(Pull)
game-server/src/com/aionemu/gameserver/dataholders/loadingutils/XmlDataLoader.java
package com.aionemu.gameserver.dataholders.loadingutils;

import java.io.File;
import java.io.Reader;
import java.util.concurrent.Future;

import javax.xml.transform.sax.SAXSource;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.xml.sax.InputSource;

import com.aionemu.gameserver.GameServerError;
import com.aionemu.gameserver.dataholders.StaticData;
import com.aionemu.gameserver.utils.ThreadPoolManager;
import com.aionemu.gameserver.utils.xml.JAXBUtil;
import com.aionemu.gameserver.utils.xml.XmlUtil;

/**
 * This class is responsible for loading xml files. It uses JAXB to do the job.<br>
 * In addition, it uses @{link {@link XmlMerger} to create input file from all xml files.
 * 
 * @author Luno
 */
public class XmlDataLoader {

	private static final Logger log = LoggerFactory.getLogger(XmlDataLoader.class);

	private static final String CACHE_XML_FILE = "./cache/static_data.xml";
	private static final String MAIN_XML_FILE = "./data/static_data/static_data.xml";
	private final static String XML_SCHEMA_FILE = "./data/static_data/static_data.xsd";

	/**
	 * Creates {@link StaticData} object based on xml files, starting from static_data.xml
	 * 
	 * @return StaticData object, containing all game data defined in xml files
	 */
	public static StaticData loadStaticData() {
		log.info("Preparing static data cache file...");
		XmlMerger.MergeResult mergeResult;
		try {
			mergeResult = new XmlMerger(new File(MAIN_XML_FILE), new File(CACHE_XML_FILE)).merge();
		} catch (Throwable e) {
			throw new GameServerError("Error while merging xml files", e);
		}

		try {
			log.info("Processing cache file...");
			// passing the xsd for auto schema validation in JAXBUtil.deserialize slows down the server start, so we validate manually in another thread and don't let the server start on error
			Future<?> validationTask = mergeResult.fileIsModified() ? validateAsync(mergeResult) : null;
			StaticData staticData = JAXBUtil.deserialize(mergeResult.newReader(), StaticData.class);
			staticData.setValidationTask(validationTask);
			return staticData;
		} catch (Throwable e) {
			throw new GameServerError("Error while loading static data", e);
		}
	}

	private static Future<?> validateAsync(XmlMerger.MergeResult mergeResult) {
		return ThreadPoolManager.getInstance().submitLongRunning(() -> {
			log.info("Validating " + mergeResult.getFile() + " in background...");
			try {
				if (!mergeResult.waitUntilFileIsWritten()) {
					throw new RuntimeException();
				}
				long time = System.currentTimeMillis();
				try (Reader reader = mergeResult.newReader()) {
					XmlUtil.getSchema(XML_SCHEMA_FILE).newValidator().validate(new SAXSource(new InputSource(reader)));
				}
				log.info("Validated " + mergeResult.getFile() + " in " + (System.currentTimeMillis() - time) + "ms");
			} catch (Throwable t) {
				mergeResult.getFile().setLastModified(0); // mark file as outdated so validation will run again on next start
				throw new GameServerError("Error validating " + CACHE_XML_FILE, t);
			}
		});
	}
}

📎 첨부파일

댓글 작성 권한이 없습니다.
🏆 포인트 랭킹 TOP 10
순위 닉네임 포인트
1 no_profile 타키야겐지쪽지보내기 자기소개 아이디로 검색 전체게시물 102,949
2 no_profile 동가리쪽지보내기 자기소개 아이디로 검색 전체게시물 63,733
3 no_profile 라프텔쪽지보내기 자기소개 아이디로 검색 전체게시물 51,771
4 no_profile 불멸의행복쪽지보내기 자기소개 아이디로 검색 전체게시물 36,923
5 서번트쪽지보내기 자기소개 아이디로 검색 전체게시물 35,011
6 no_profile 닥터스쪽지보내기 자기소개 아이디로 검색 전체게시물 29,470
7 no_profile 검은고양이쪽지보내기 자기소개 아이디로 검색 전체게시물 29,077
8 no_profile Revolution쪽지보내기 자기소개 아이디로 검색 전체게시물 28,199
9 no_profile 보거스쪽지보내기 자기소개 아이디로 검색 전체게시물 26,731
10 no_profile 호롤롤로쪽지보내기 자기소개 아이디로 검색 전체게시물 17,020
알림 0