Microsoft MVP성태의 닷넷 이야기
RAW파일 생성 질문드립니다 [링크 복사], [링크+제목 복사],
조회: 13520
글쓴 사람
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)
888김재영7/5/201014366TFS에 반드시! SQL Report랑 SharePoint(or WSS)가 붙어야 합니까? [2]
887임동찬7/2/201015670WCF sendTimeout에 관하여... [1]
886김재영6/16/201015691스레드 선언시 (Parameterized/)ThreadStart에 정의되는 메소드의 위치에 질문이 있습니다. [3]
885장근배6/13/201023100Win32Exception 창 핸들 에러 [1]
883채동민6/10/201015283비동기 DB 쿼리관련 질문
884정성태6/10/201016737    답변글 [답변]: 비동기 DB 쿼리관련 질문
881최준영5/24/201016512load되지않은 아이템 load하는 방법? [1]
880임상일5/10/201018607VS2010 TestManager를 통한 UI Test 관련 질문입니다. [2]파일 다운로드1
879정용훈5/3/201019846wcf 인증 문제 [2]
878채동민4/20/201019042WCF에서 maxItemsInObjectGraph 오류 관련 질문드립니다. [2]
872날쌘돌이4/8/201021749Windows7 에서 IIS에서 폼인증 으로 디버깅.. [1]파일 다운로드1
871영초4/7/201017107실버라이트로 스캐너 구동 프로그램이 가능할까요? [1]
869김재영4/6/201015991이미 실행된 어셈블리 컨트롤 권한을 다른 어셈블리에서 가져올 수 있습니까? [2]
868Lime3/5/201019594WCF 에서의 DataTable 사용 [2]
867Dani...2/18/201019723Question - HTTP 401.3 on DELETE, PUT verbs [6]파일 다운로드1
865박근대2/16/201016204WCF 오류 문의. [1]
863날쌘돌이1/31/201018535ActiveX Cab에서 닷넷 dll 등록 [1]
862장근배1/28/201016274AppPolId를 알 수 있는 방법이 있는지요? [1]
864장근배2/1/201015933    답변글 [답변]: AppPolId를 알 수 있는 방법이 있는지요?
858생초보1/26/201016343안녕하세요.. 파일 생성 처리 문제로 .... [2]
857꼭지1/22/201022086How to support Basic + Windows authentication mode in WCF(RESTful service) [4]파일 다운로드2
856질의자1/13/201020045vcredist_x86 배포 관련 여쭙습니다. [1]
855임동찬1/13/201018143이벤트 핸들러와 쓰레드의 관계 2 [4]파일 다운로드2
854임동찬1/12/201018428이벤트 핸들러와 쓰레드의 관계 [1]
853장근배1/12/201018033압축 프로그램,, [1]
852임동찬1/6/201015425base.OnStart(agrs) [1]
... 61  62  63  64  65  66  67  [68]  69  70  71  72  73  74  75  ...