Microsoft MVP성태의 닷넷 이야기
RAW파일 생성 질문드립니다 [링크 복사], [링크+제목 복사],
조회: 6906
글쓴 사람
JaeSSG (998go at naver.com)
홈페이지
첨부 파일
[raw.zip]    
(연관된 글이 1개 있습니다.)

안녕하십니까

친구와 c#을 이용해 디스크의 바이너리 값을 가져오는 코드를 작성하고 있습니다.
많은 시도와 구글링으로도 해결하지 못했고,
우연히 C#으로 다루는 MBR(Master Boot Record)(https://www.sysnet.pe.kr/Default.aspx?mode=2&sub=0&pageno=0&detail=1&wid=10913)
를 보게되어 질문드리게 되었습니다.
위 글의 코드를 받아 분석하면서 적용해보려 노력했으나 실패했습니다.

목표 : 특정 드라이브(ex D:\ E:\)를 선택하여 RAW형식으로 이미지를 만드는 코드를 작성중입니다.

현재 상황 : 값을 읽어와 raw 파일을 생성할 수 있습니다.

문제점 : -값을 읽어오는 속도가 상당히 느립니다. ★ (10만 섹터 파일 생성에 약 1분 8초 걸렸습니다)
        - 코드로 읽은 섹터값과 실제 물리적 섹터값이 다릅니다.
        - 실제 입력한 섹터 범위와 출력되는 섹터의 범위가 다릅니다.


문제점 1을 해결하기 위해 하루 6시간씩 5일동안 많은 고민과 시도를 해봤으나 결국 단 한줄도 변화된 것이 없어서 질문드립니다.
문제점 2는 차이나는 값이 2GB 기준 40 섹터 차이가 났고, 8GB 기준 4101섹터 정도 차이가 났습니다. 차이의 비율이 너무 커서 원인을 모르겠습니다.
문제점 3은 100섹터 입력시 85섹터만 출력 / 1000섹터 입력시 848섹터 / 100000 섹터 입력시 84880섹터 이런 식으로 약 85%의 섹터만 출력이 됩니다.
          약 15%의 섹터가 누락되는 것이 왜인지 모르겠습니다.

문제점 1과 2,3 모두 조언을 해주시면 감사하겠지만,
문제점 2,3이 질문 주의 사항에 걸린다면 문제점 1만이라도 부탁드립니다.

감사합니다


[연관 글]






[최초 등록일: ]
[최종 수정일: 3/9/2020]


비밀번호

댓글 작성자
 



2020-03-09 01시00분
우선 1번만 먼저 보겠습니다. 그러니까,

startSector = 0;
endSector = 100000;
            for (uint i = startSector; i <= endSector; i++)
            {
                blist.Add(DumpSector(handle, i, bps));
            }

위의 코드만을 대상으로 해서 시간을 잴 경우, 그래도 1분이 넘게 걸리나요?
정성태
2020-03-09 01시20분
[JaeSSG] 파일 입력과 foeach문을 주석하고 말씀하신 for문과 위의 코드만 살린 상태에서도 1분 7초가 걸렸습니다
[guest]
2020-03-09 01시36분
다른 단서를 또 달아서,,, 혹시나 싶어 묻는 건데요, 그러니까 아래의 코드 결과가 1분 7초 걸린다는 건가요?

            Console.WriteLine(System.DateTime.Now.ToString("HH : mm : ss"));
            for (uint i = startSector; i <= endSector; i++)
            {
                blist.Add(DumpSector(handle, i, bps));
            }
            Console.WriteLine(System.DateTime.Now.ToString("HH : mm : ss"));
정성태
2020-03-09 01시47분
[JaeSSG] 네 맞습니다. 제가 깜빡하고 말씀 못드린게 있는데, 관리자로 vs실행하셔야 합니다... 죄송합니다
[guest]
2020-03-09 02시15분
글쎄요... 1번 문제는 환경 상의 문제가 있을 것 같은데요. 제 경우에 테스트해 보면 10만 섹터에 해당 for 루프 처리가 4초 걸립니다. 1분이나 걸렸다는 것은 해당 범위 내에 배드 섹터가 있거나... 하는 문제가 있을 듯합니다. 혹시, 여러 개의 하드 디스크를 대상으로도 실행해 보셨나요? 또는, raw 입출력을 하는 다른 공개 프로그램이 있다면 그걸로도 위의 코드와 성능 비교를 해보는 것이 좋겠습니다.

재현되는 문제가 아니라면, 딱히 저도 더 조언해 드릴 것이 없습니다.
정성태
2020-03-09 02시41분
[JaeSSG] 기존 USB 2개를 이용해 테스트를 진행했었는데
HDD 1개 + USB 3개를 이용해 테스트 해보니
HDD 1분 8초 USB 2개 1분 8초 새로 추가한 USB 16초 이렇게 나왔습니다.
배드섹터가 있거나 저장장치의 문제 + 환경이 요인인 것 같습니다.
정말 정말 감사합니다.
[guest]
2020-03-11 09시17분
[asd] 저도 disk 이미징에 관련된 프로그램을 하나 만들고 싶어서 자료조사를 하고있기는한데
jaessg님께서 작성하신 코드 돌려봤더니 winhex에서 확인한 값이랑 code로 확인한 값이랑 상이해서 여쭤보려고했는데 질문에 적혀있네요
관리자님 sector값을 다르게 불러오는 이유는 뭔가요??
[guest]
2020-03-11 10시13분
@asd 그것은 jaessgs님의 fs.WriteByte 코드에 버그가 있기 때문입니다. 자세히 확인해 보세요.
정성태

... 61  62  63  64  65  66  67  68  69  70  71  72  73  [74]  75  ...
NoWriterDateCnt.TitleFile(s)
672땡초7/4/200710960Remoting 객체를 호출하는 순간 Timer 의 Elapsed 이벤트가 멈추는 현상 [2]
670조성택7/3/200710462.Net에서 Timer클래스.. [1]
667홍석헌6/29/20079979[c#] 윈도우 활성화에 관한 질문
669정성태6/30/200710449    답변글 [답변]: [c#] 윈도우 활성화에 관한 질문
666오야6/25/20079394System.Transactions 에서 트랜잭션 실패를 체크하는 방법 [1]
665김성태6/20/20078794안녕하세요^^
668정성태6/30/20079913    답변글 [답변]: 안녕하세요^^
663모름이6/19/20078638Microsoft.Framework 에서 OLE DB 사용하려면.. [1]
664모름이6/20/20079342    답변글 [추가질문]: 다른 OLE DB 를 사용하려면..
662조성택6/13/20079979C#에서 string클래스.. [1]
660신동열6/11/200711305ClickOnce 업데이트시 이전 버젼 제거오류 [1]
659한귀순6/11/200712602윈폼 프로그램 및 디자인. [2]
661한귀순6/12/200710135    답변글 [추가질문]: 윈폼 프로그램 및 디자인. [3]
657정해봉6/8/200720309요청 시간 초과 오류 [2]
655이방은5/28/200710939성태님 UML 도구 뭐 쓰십니까??? [1]
654임정훈5/23/20079954카드스페이스 관련질문
658정성태6/9/200710473    답변글 [답변]: 카드스페이스 관련질문 [1]
653사다수스5/22/200731343아래한글(HwpCtrl) ocx 메모리 릭 문제입니다. [4]파일 다운로드1
645송원석5/15/200712604ASP 의 ByVal 과 ByRef 특성
646정성태5/15/200712462    답변글 [답변]: ASP 의 ByVal 과 ByRef 특성
647송원석5/16/200712797        답변글 [답변]: [답변]: ASP 의 ByVal 과 ByRef 특성 [1]
648정성태5/16/200711568            답변글 [답변]: [답변]: [답변]: ASP의 ByVal과 ByRef 특성 [1]
649장윤태5/16/200710705                답변글 [답변]: [답변]: [답변]: [답변]: ASP 의 ByVal 과 ByRef 특성
650정성태5/16/20078933                    답변글 [답변]: [답변]: [답변]: [답변]: [답변]: ASP의 ByVal과 ByRef 특성 [2]
643해운대끓...5/15/20078575Singleton 패턴 테스트중 하나의 윈폼만 열기 오류파일 다운로드1
644정성태5/15/20079207    답변글 [답변]: Singleton 패턴 테스트중 하나의 윈폼만 열기 오류 [1]
... 61  62  63  64  65  66  67  68  69  70  71  72  73  [74]  75  ...