* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
|
개발PC Win7 64bit, 서버 CentOS |
|
CUBRID 2008 R4.3 (8.4.3.1005) |
|
CUBRID 매니저 2013 빌드 0039 (64bit) |
|
Java, Eclipse |
* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 | 재현 가능한 Source와 SQL |
관련 테이블(인덱스, 키정보 포함) 정보 | CUBRID 홈 디렉토리 아래 log 디렉토리 압축 |
-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
Clob 컬럼에 100메가 넘는 파일을 Insert 할 시 Java heap Space 오류가 발생합니다.
조언해주신다면 어떤것이든 감사하게 받겠습니다.
1. http://www.cubrid.com/zbxe/343796 를 참고하여 코딩하였구요.
2. 이클립스의 프로젝트 설정에서 Java VM arguments 를 1024m으로 늘려줬습니다.
-Xms256m -Xmx1024m 으로 설정
3. 아래는 해당 코드 입니다.
StringBuilder str = new StringBuilder();//여기에 text 내용 삽입
Clob clob = conn.createClob();
clob.setString(1, str.toString()); //여기서 오류발생
reader.close();
sql.setLength(0);
sql.append("n INSERT INTO TBL_AGENT_FILECONTENT ");
sql.append("n (MD5, CONTENT, CONTENTTYPE) ");
sql.append("n values ");
sql.append("n ((?), (?), (?))");
pstmt = conn.prepareStatement(sql.toString());
pstmt.setString(1, sMD5);
pstmt.setClob(2, clob);
pstmt.setString(3, sType);
4. str.toString에 text파일에서 읽어온 작은 텍스트인 경우 정상 Insert 되나
100메가 짜리 text인 경우 주석처리한 부분에서 에러가 발생합니다.
5. 에러 로그는 다음과 같습니다.
2013. 5. 10 오전 10:04:28 com.sun.xml.internal.ws.server.sei.EndpointMethodHandler invoke
심각: Java heap space
java.lang.OutOfMemoryError: Java heap space
at java.util.Arrays.copyOfRange(Unknown Source)
at java.lang.String.<init>(Unknown Source)
at java.lang.StringBuilder.toString(Unknown Source)
... 이하 생략
6. 테이블 스키마 입니다.
CREATE TABLE "tbl_agent_filecontent"
(
"md5" CHARACTER VARYING(100) NOT NULL,
"contenttype" INTEGER,
"content" CLOB,
CONSTRAINT pk_tbl_agent_filecontent PRIMARY KEY("md5")
);
7. 마지막으로 전체코드 첨부드려봅니다.
File f = new File(fileName);
if (f.isFile()) {
StringBuilder str = new StringBuilder();
FileReader fileReader = new FileReader(fileName); //파일경로
BufferedReader reader = new BufferedReader(fileReader);
//파일로딩
char[] c = new char[(int)f.length()];
reader.read(c);
str.append(c);
//Insert
Clob clob = conn.createClob();
clob.setString(1, str.toString()); //여기서 에러발생
reader.close();
sql.setLength(0);
sql.append("n INSERT INTO TBL_AGENT_FILECONTENT ");
sql.append("n (MD5, CONTENT, CONTENTTYPE) ");
sql.append("n values ");
sql.append("n ((?), (?), (?))");
pstmt = conn.prepareStatement(sql.toString());
pstmt.setString(1, sMD5);
pstmt.setClob(2, clob);
pstmt.setString(3, sType);
ResultType = pstmt.executeUpdate();