Microsoft MVP성태의 닷넷 이야기
파일 저장 방법에 대해 조언 부탁드립니다. [링크 복사], [링크+제목 복사],
조회: 15079
글쓴 사람
C#초보
홈페이지
첨부 파일
 

안녕하세요. 현재 제가 만들고 있는 프로그램에서 어떤 방식으로 파일을 저장해야 좋을지에 대해 조언을 부탁드리고 싶습니다.

이 프로그램은 평일에 계속 시계열 자료를 받는 용도로 만들고 있습니다.

인덱스값, 발생시각, 자료값들 중에서 인덱스 값을 제외한 모든 값을 string 형태로 받고 있습니다.

중간에 자료형을 변환하는 비용을 없애기 위해, 자료 수신시마다 자료형 변환 없이 구조체를 사용해서 리스트 안에 이 구조체를 저장하고 있습니다.

기존에는 이렇게 리스트에 자료값이 든 구조체를 저장하다가, 구조체의 수가 특정 수(50이나 100)가 되면

csv형태로 디스크에 append하고(for loop 이용), 해당 리스트는 Clear()로 다시 비웠습니다.

그런데 Serialization에 대해 알게 되어서, 이걸 이용해서 자료를 디스크에 쓰게 되면 훨씬 더 효율적일 수 있다는 생각이 들었습니다.

저는 단순히 디스크에 저장할 용도로 사용하길 바라기 때문에 BinaryFormatter를 사용해 볼까 하는데요.

이게 제가 설명드린 사용 목적 - 실시간으로 받은 자료를 중간 중간 이어서 디스크의 동일 파일에 저장 - 에 부합하는 방법일까요?

가능은 하겠지만, 이게 과연 표준적으로 사용하는 방법인지, 퍼포먼스적인 관점에서 더 나은 방법이 있는지 조언을 얻고 싶습니다.








[최초 등록일: ]
[최종 수정일: 11/10/2019]


비밀번호

댓글 작성자
 



2019-11-10 07시30분
지금 csv 형태로 쓰고 있던 그것도 일종의 수동 serialization이라고 보면 됩니다. .NET BCL에서 자동으로 해주는 Serialization은 그 과정을 Reflection 등의 정보를 통해 자동화하는 것 뿐입니다.

따라서 BinaryFormatter로 바꾸시면 동일한 목적을 이룰 수 있습니다. 하지만, 성능이나 저장 공간 측면에서 보면 기존에 비해 만족스럽진 않을 것입니다. 왜냐하면 직렬화 시 데이터의 크기라든지 타입 등의 정보도 함께 출력이 되기 때문에 다소 늘어날 수 있습니다. (이 부분은 약간의 샘플 데이터로 테스트해 해보세요.)

제 생각에는 현재 인덱스를 제외한 각 자료값들의 타입 정보가 크게 중요하지 않고 데이터들의 내용이 CSV를 써도 될 만큼 간단한 것 같은데, 그렇다면 그냥 기존의 방식을 쓰시는 것도 나쁘지 않은 선택으로 보입니다.
정성태
2019-11-10 11시03분
[C#초보] 조언해 주셔서 감사합니다.
네, 말씀하신대로 실제 데이터를 넣어서 바이너리로 저장을 하니까 용량이 꽤 되네요. 아무래도 이 방법도 사용하기는 힘들 듯합니다.
제가 걱정되는 부분은 csv로 파일 쓰기 반복문이 실행되는 사이에 수신되는 데이터를 놓치는 부분인데요. 이 부분은 고민을 좀 해 봐야겠네요.
[guest]
2019-11-11 08시42분
얼마나 수신 데이터가 많은지는 모르겠지만, 그렇다면 쓰기 처리를 하는 부분을 별도의 스레드로 분리하면 되지 않을까요? 50~100개가 list에 담기면 그 리스트 인스턴스를 Queue에 저장하고 이후의 데이터는 새로운 list에서 담도록 만들고 Queue에 담긴 것은 다른 스레드에서 쓰기 처리를 하면 될 것입니다.
정성태

... 61  62  63  64  [65]  66  67  68  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
981김창욱7/11/201121218주식형태의 프로그램 처럼 SQL서버의 특정 필드 데이터의 변화가 있을때 재 클라이언트가 정보를 갱신 할 수 있게 하는 방법은 없을까요? [2]
980YJ7/7/201120968App Pool idle time 과 WCF 서비스의 비동기 function 호출. [3]
979왕초보7/1/201119257Apache + IIS Redirect [2]
9776/16/201123185웹컨트롤 어느거 쓰는게 좋나요 [1]
976박성준6/13/201118698VS2008 Add-in 구현 관련 질문 [4]
972김길6/6/201120957메모리 해제 예외 처리 관련.. [2]
971강동원5/29/201118496firebird install건 [1]
970임동찬5/18/201119279ASP.net 솔루션 디버깅 관련 [1]
969이성환5/4/201120939WMI 를 사용하지 않고 하드웨어 정보를 가져올 수 없을까요? [3]
968김동미4/28/201120366안녕하세요 다시 한번 문의를 드립니다.. [2]파일 다운로드1
967임동찬4/22/201123053C# using문 관련 [9]
964김동미4/18/201120685wcf IsOneWay 속성관련 문의 입니다..
965정성태4/18/201121990    답변글 [답변]: wcf IsOneWay 속성관련 문의 입니다..
966김동미4/19/201119600        답변글 [답변]: [답변]: wcf IsOneWay 속성관련 문의 입니다.. [1]
963최재훈4/12/201118257wcf inactivityTimeout 설정시 문의 사항이 있습니다. [2]
962임동찬4/8/201117910TFS 사용관련 [1]
961임동찬4/7/201118218XSD & XML & XmlCodeGenerator [2]
960임동찬4/5/201119906XML Schema Editor [4]
959immm3/24/201117669로그인 연동 어려운 건가요? [1]
958꼭지3/3/201119776Supporting compressed request in WCF 3.5 [5]
957임동찬2/21/201120210WCF channel faulted 관련 [2]
956윤용한2/18/201123676WaitHandle.WaitOne 과 Stopwatch에 관한 질문 [3]
955최광욱2/17/201120359TFS 에서 소스 영구 제거 방법 [1]
954한장우2/16/201118030atl activeX 질문이요~ [1]
952박용운2/16/201118909IE8.0에서 BHO [1]
953박용운2/16/201118852    답변글 [답변]: IE8.0에서 BHO
... 61  62  63  64  [65]  66  67  68  69  70  71  72  73  74  75  ...