Microsoft MVP성태의 닷넷 이야기
RAW파일 생성 질문드립니다 [링크 복사], [링크+제목 복사],
조회: 7137
글쓴 사람
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)
698정성태9/1/200710275    답변글 [답변]: [CardSpace 관련 질문] 정리해 좋으신 글 잘 보았습니다.
704이호정9/6/200710830        답변글 답변해주신 내용 잘 봤습니다. ^_^b
705정성태9/6/20079681            답변글 [답변]: 답변해주신 내용 잘 봤습니다. ^_^b
706이호정9/7/200710202                답변글 후후... 이러다가 CardSpace 전용게시판 되는 것 아닌지 모르겠습니다. ^_^a;;
693장근배8/29/20079709매핑 구간이 열려 있습니다 [2]
710장근배9/17/20079642    답변글 [답변]: 매핑 구간이 열려 있습니다
692채영사랑8/29/20079401<질문> Ms stress tool 로 부하테스트중.
697정성태9/1/20079078    답변글 [답변]: <질문> Ms stress tool 로 부하테스트중. [1]
690한귀순8/28/200710013ClickOnce 배포 추가질문 [4]
689clev...8/27/20079598SmartClient에서도 Exe COM과 같이 여러곳에서 변수 공유가 가능한가요? [2]
688한귀순8/24/200711845ClickOnce 배포 [1]
686이상욱8/21/200710770[질문] VS.NET 2008 - WCF 를 위한 디버깅 환경 개선 테스트 중에
687정성태8/21/20079350    답변글 [답변]: [질문] VS.NET 2008 - WCF 를 위한 디버깅 환경 개선 테스트 중에
685김동진8/19/200711326Vista에서 WSDL관련 IIs7세팅 질문입니다. [4]
683조스7/31/200710293스마트 클라이언트에서 다른 어셈블리(.NET component) 사용시 에러 [1]
682정해봉7/30/200711224비스타에서 CAS설정하기... 소스 첨부 [1]파일 다운로드1
684정해봉8/14/200711242    답변글 [답변]: 비스타에서 CAS설정하기... 소스 첨부 [3]
681박희진7/27/20079712caspol로 설정된 권한집합 웹에서 읽어올 수 있나요?? [1]
680창민이7/27/200710584COM+등록시 에러 부분 때문에.. [2]
678정해봉7/24/20079513비스타에서 CAS 설정하기... [1]
677첫사랑7/24/20079026SSL에 관한 질문입니다.
679정성태7/26/20079614    답변글 [답변]: SSL에 관한 질문입니다. [1]
676kiuk7/11/20079960웹폐이지상의 이미지 상태 저장을 하고싶습니다. [1]
675안연준7/6/200710417안녕하세요 ^^ [1]
674황태욱7/5/200711534utf-8 환경에서 파라미터 값에 한글이 있을 경우 깨지는 현상이.. [1]
672땡초7/4/200711084Remoting 객체를 호출하는 순간 Timer 의 Elapsed 이벤트가 멈추는 현상 [2]
... 61  62  63  64  65  66  67  68  69  70  71  72  [73]  74  75  ...