Background Image

FORUM

?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
Window7 32bit, Linux 64bit 등
CUBRID Ver.
[cubrid_rel] 수행 결과
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
java, php, odbc 등 입력

* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
http://www.cubrid.com/qna/3821016

에서 답변을 받은 후 아래와 같이 수정했습니다.


 private DataTable SelectDB(string query, string tableName)

        {

            DataSet ds = new DataSet(tableName);

            DataTable dt = null;

            CUBRIDConnection sqlConn = null;

            try

            {

                sqlConn = OpenDB();

                CUBRIDCommand sqlComm = new CUBRIDCommand(query, sqlConn);

                CUBRIDDataAdapter adapter = new CUBRIDDataAdapter(query, sqlConn);                

                adapter.Fill(ds, tableName);


                if (ds != null || ds.Tables.Count > 0)

                {

                    dt = ds.Tables[0];

                }


                adapter.Dispose();

                sqlComm.Close();

                sqlComm.Dispose();               

                ds.Dispose();                   

                CloseDB(sqlConn);

            }

            catch (Exception ex)

            {

                CloseDB(sqlConn);

                //Console.WriteLine("SelectDB-" + ex.Message);

                wMain.UI_LogAdd("SelectDB-" + ex.Message);

            }

            return dt;

        }

이후 일반적인 상황에서는 보호된 메모리 에러가 발생하지 않습니다만,

SELECT를 매우 빠르게 반복할경우 다시 문제가 발생합니다.


SELECT-> 결과 받고 -> SELECT 식으로 진행하고 있고,

서버와 클라이언트 같의 통신 및 SELECT 데이터 처리를 합치면 DB에 SELECT 하는 주기는 50ms 정도 되고요

이걸 100회 정도 1세트로 반복할때 두번에 한번은 메모리 에러가 발생합니다.


다음은 에러 내용 풀스택 입니다.

예외 발생: 'System.AccessViolationException'(CUBRID.Data.dll)

처리되지 않은 'System.AccessViolationException' 형식의 예외가 CUBRID.Data.dll에서 발생했습니다.

보호된 메모리를 읽거나 쓰려고 했습니다. 대부분 이러한 경우는 다른 메모리가 손상되었음을 나타냅니다.


'SPM_Server.exe'(CLR v4.0.30319: SPM_Server.exe): 'C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\Common7\Packages\Debugger\Visualizers\Microsoft.VisualStudio.DebuggerVisualizers.dll'을(를) 로드했습니다. PDB 파일을 찾거나 열 수 없습니다.

'SPM_Server.exe'(CLR v4.0.30319: SPM_Server.exe): 'C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\Common7\Packages\Debugger\Visualizers\Microsoft.VisualStudio.Debugger.DataSetVisualizer.dll'을(를) 로드했습니다. PDB 파일을 찾거나 열 수 없습니다.

0x7f3c 스레드가 종료되었습니다(코드: 0 (0x0)).


처리되지 않은 예외: System.AccessViolationException: 보호된 메모리를 읽거나 쓰려고 했습니다. 대부분 이러한 경우는 다른 메모리가 손상되었음을 나타냅니다.

   위치: System.Runtime.InteropServices.Marshal.CopyToManaged(IntPtr source, Object destination, Int32 startIndex, Int32 length)

   위치: CUBRID.Data.CUBRIDClient.CciInterface.cci_get_result_info(CUBRIDConnection conn, Int32 req_handle)

   위치: CUBRID.Data.CUBRIDClient.CUBRIDCommand.ExecuteInternal()

   위치: CUBRID.Data.CUBRIDClient.CUBRIDCommand.ExecuteDbDataReader(CommandBehavior behavior)

   위치: System.Data.Common.DbDataAdapter.FillInternal(DataSet dataset, DataTable[] datatables, Int32 startRecord, Int32 maxRecords, String srcTable, IDbCommand command, CommandBehavior behavior)

   위치: System.Data.Common.DbDataAdapter.Fill(DataSet dataSet, Int32 startRecord, Int32 maxRecords, String srcTable, IDbCommand command, CommandBehavior behavior)

   위치: System.Data.Common.DbDataAdapter.Fill(DataSet dataSet, String srcTable)

   위치: SPM_Server.DataControl.SelectDB(String query, String tableName) 파일 D:\Projects\Sbk\SbkProductManagement\SPM_Server\DataControl.cs:줄 121

   위치: SPM_Server.DataControl.Select_ViewHistroy(String sql, Int32 order) 파일 D:\Projects\Sbk\SbkProductManagement\SPM_Server\DataControl.cs:줄 849

   위치: SPM_Server.DataFunction.VHis_GetTable(Int64 sess, Int32 cnt) 파일 D:\Projects\Sbk\SbkProductManagement\SPM_Server\DataFunction.cs:줄 339

   위치: SPM_Server.TCPServer.ReqPacket(Packet packet) 파일 D:\Projects\Sbk\SbkProductManagement\SPM_Server\TCPServer.cs:줄 758

   위치: SPM_Server.TCPServer.waitText(Object key) 파일 D:\Projects\Sbk\SbkProductManagement\SPM_Server\TCPServer.cs:줄 343

   위치: System.Threading.ExecutionContext.RunInternal(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)

   위치: System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)

   위치: System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)

   위치: System.Threading.ThreadHelper.ThreadStart(Object obj)



/////////////////////추가////////////////////////

adapter.Dispose();

                sqlComm.Close();

                sqlComm.Dispose();               

                ds.Dispose();                  

부분을 추가 하면서 빈도가 조금 줄었습니다.


그리고 강제로 지연을 주어 SELECT 주기를 70ms, 100ms 식으로 늘릴경우 예외발생 빈도가 줄어듭니다.

하지만 총 시간이 그만큼 늘어나다보니 방법을 찾고 싶네요 ㅜ

  • ?
    큐브리드_김주현 2019.02.19 16:26
    큐브리드를 이용해 주셔서 감사합니다.


    우선, 불편을 드려 죄송합니다.

    말씀하신 사항이 SelectDB()함수를 호출하되, SelectDB()호출 주기가 50ms일 경우, 100회 반복 시 발생하는 것이지요??
    ++++++++++++++++++++++++++++++++++++++++++++++++++++++
    SELECT-> 결과 받고 -> SELECT 식으로 진행하고 있고,
    서버와 클라이언트 같의 통신 및 SELECT 데이터 처리를 합치면 DB에 SELECT 하는 주기는 50ms 정도 되고요
    이걸 100회 정도 1세트로 반복할때 두번에 한번은 메모리 에러가 발생합니다.
    ++++++++++++++++++++++++++++++++++++++++++++++++++++++
    재현테스트를 진행하여 문제원인을 찾아보도록 하겠습니다.

    감사합니다.
  • ?
    큐브리드_김주현 2019.02.20 16:17
    안녕하세요.

    상세히 알려주신 덕분에 내부 점검 결과 cs코드에서 Marshal.Copy() 메서드를 사용하는 부분에서 오류가 될만한 부분을 찾았습니다.
    되도록 빠른 시일안에 수정하여 release하도록 하겠습니다.

    상세한 설명 감사드립니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 110
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4473
3960 객체 컬럼에 데이터 인서트 하는 방법 문의 1 Devin 2008.12.29 14987
3959 Cubrid2008 관련 문의 입니다. 1 김트리 2008.12.31 16898
3958 asp.net 의 oledb 연동 3 webdoors 2009.01.04 38313
3957 JDBC드라이버 접속에러... 1 서종률 2009.01.07 17661
3956 "Token length is too long" 오류에 관하여 질문 드립니다. 4 file 김우람 2009.01.09 21478
3955 cubrid manager 로 연결이 안되네요... 1 자유 2009.01.09 15335
3954 서버에접속할수없습니다... 1 file 가라 가라~ 2009.01.14 15812
3953 cubrid에 대량 데이터 insert 시 에러 1 비니뷘 2009.01.15 22630
3952 데이타 베이스 복구에 관하여 질문 있습니다. 2 김우람 2009.01.16 14777
3951 zeroboard XE 설치시 'database connect fail' error 4 윤희서 2009.01.16 78165
3950 DB / PW 자릿수를 늘려주세요. 3 윤희서 2009.01.16 35846
3949 CUBRID 2008 데이터베이스 사용자 권한상속 에러. 6 윤희서 2009.01.17 25834
3948 CUBRID 7.3 + zeroboard XE 관리자 로그인 에러 1 윤희서 2009.01.17 62131
3947 CUBRID 7.3 + zeroboard XE 관리자 로그인 에러 1 윤희서 2009.01.17 83643
3946 데이터베이스 자동시작 설정 메뉴 2 윤희서 2009.01.19 21976
3945 업데이트 보완 문제 해결요청 1 가라 가라~ 2009.01.20 17592
3944 설치 및 삭제의 편의성 증대 요청 1 윤희서 2009.01.20 21699
3943 [문의]임베디드 SQL 개발시 참고해야 할 기술문서가 어디있는지요? 1 victory 2009.01.22 16269
3942 설치시 오류 :cubrid: error while loading shared libraries: libstdc++.so.6: cannot open shared object file: No such file or directory 2 victory 2009.01.22 32144
3941 쿼리플랜 문의 3 asteroid 2009.01.23 16982
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 200 Next
/ 200

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales