Microsoft MVP성태의 닷넷 이야기
RAW파일 생성 질문드립니다 [링크 복사], [링크+제목 복사],
조회: 6552
글쓴 사람
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 코드에 버그가 있기 때문입니다. 자세히 확인해 보세요.
정성태

... 31  32  33  34  35  36  37  38  [39]  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
4884user8/31/20179335    답변글 [답변]: UI 변경 작업 여러개를 동시에 사용하려면 어떻게 해야되나요 ??파일 다운로드1
4881kmi8/30/20179499진행속도가 중간에 더뎌지는 문제가 있는데 해결할 수 있는 방법이 있나 궁금합니다. [3]
4880김호종8/29/20179930HTTP JSON POST 관련 질문 드립니다. [1]
4879aos8/27/201710086DateTime 표시할 때 포맷 설정시 밀리초까지 포함하는 법이 궁금합니다 [1]
4878heyh...8/25/201710178프로세스의 프로세스 찾기(?) [2]
4877강준8/24/20179381SQLite journal_mode=wal 관련하여 질문드립니다. [1]
4876heyh...8/23/20179614프로세스 초기화하기 [1]
4874ho8/22/20179685파일 확장자명을 이용해 파일의 실행 프로그램의 전체 경로를 얻어 올 수 있을까요? [1]
4875ho8/23/201710669    답변글 [답변]: 파일 확장자명을 이용해 파일의 실행 프로그램의 전체 경로를 얻어 올 수 있을까요? [1]
4873kmi8/21/201711481전역 변수를 쓰지 않고 여러 군데에서 같은 변수를 공용하는 방법이 궁금합니다. [4]
4872abcd8/18/201710167프로세스를 초기화 하는 명령어도 있나요? [1]
4871kmi8/17/201711487메모리 부족으로 종료되는 현상의 여러가지 이유가 무엇인지 궁금합니다. [2]
4870heyh...8/14/201710283프로그램 실행시 중복일 때 버튼 색깔 원래대로 돌리기 [1]
4868kmi8/4/20179607string[] 에 Reverse 적용방법 질문해봅니다 [3]
4867heyh...8/4/20179087EventHandler에 관한 [1]
486610년차8/3/20179507dsoframer axframer open시 기존 오픈되어있는 엑셀을 먹어버리는 현상 [1]
4865heyh...7/31/201711083클릭원스로 배포 한 프로젝트가 끝났는지 알 수 있는 방법 [8]
4864초보자7/28/201710076DllIImport질문 드립니다. [1]
4863다연아빠7/23/201710299전역 예외처리에 대해 질문있습니다. [3]
4861라르크7/17/201715573window form 예제 따라하는 중인데 12.3 서비스 응용 프로그램에서 진행이 안됩니다. [3]파일 다운로드1
4859heyh...7/10/201710219다른 환경에서 실행하기 [1]
4858heyh...7/10/201710060Clickonce update에 관한질문입니다. [1]
4857heyh...7/7/201710696제가 여태까지 작성한 보고서입니다. [2]파일 다운로드1
4856heyh...7/6/20179404성태님 다른질문입니다. [4]
4855JP7/6/201710093Dispose 패턴 구현시 Finalize 재정의에 대한 질문드립니다. [2]
4854heyh...7/6/20179517
... 31  32  33  34  35  36  37  38  [39]  40  41  42  43  44  45  ...