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

1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5828김재영2/19/20233141장기적으로는 this 구문을 안쓰는게 맞을까요? [2]
5827lee2/18/20233058파이썬 설치 오류 질문입니다 [1]
5826Syong2/14/20233639Socket 관련 Leak (OverlappedAsyncResult, OverlappedData) 관련 문의 [7]파일 다운로드1
5825박성원2/14/20233211Listview 컨트롤의 화면 전환 시 갱신 속도 [1]
5823검은콩2/13/20233811catch(Exception ex)의 line번호를 쉽게 알 수 없는지요? [7]
5822김지우2/11/20233085책을 보면서 sync, async 이해가 되지 않는 부분이 있습니다. [5]파일 다운로드2
5821검은콩2/9/20233112Async 신뢰성과 소켓데이터 [4]
5820차가워2/8/20233172다른 프로세스 실행 후 포커스 가져오기 [3]
5819취준생2/7/20233327WPF 관련 실무가 궁금합니다. [3]
5818윤길2/7/20232776ObservableCollection 에서 INotifyPropertyChanged 구현해야하나요? [2]
5817흰털너부리2/7/20232915배포 시 winform 실행 콘솔로그 보는 방법 [1]
5816흰털너부리2/6/20232726.net core json array validation 질문 드립니다. [1]
5815김재영2/6/20232850종단간 암호화에 대해 시나리오인데 타당한 시나리오일까요? [2]
5814한예지 donator2/6/20233184decompile? [9]
5813김재영2/5/20233079openssl genrsa 2048시 키 생성이 다르게 됩니다. - 파일첨부 [4]파일 다운로드1
5812김재영2/5/20233357openssl genrsa 2048시 키 생성이 다르게 됩니다. [2]
5811치르바2/3/20233185MiniDumpWriteDump API로 덤프수집을 했는데요.. [3]
5810이건우1/31/20233289윈도우서비스를 통한 웹통신관련 질문입니다 [3]
5809이상훈1/31/20233730다채널 영상 디스플레이어 개발 관련 질문입니다. [3]
5808근우1/30/20233407WPF 에서 UserControl 과 ControlTemplate 의 차이점은 무엇인가요? [6]
5807궁금맨1/28/20234561C# 10 책에 나온 예제의 결과가 제 컴에서는 좀 달라서요. 이유가 궁금합니다. [1]
5806스레드1/25/20233077총정리 - 다양한 스레드들 [초안] [1]파일 다운로드1
5805어웨이트1/25/20232940Taskcontinuewith vs Async/Await [2]파일 다운로드1
5804나이많은...1/25/20232798MS의 Dependency Injection(DI)에 AddSingleton으로 등록된 객체의 Event 등록후 사용시 앱 종료시 별도로 Event를 해지해야 하나요? [2]
5803dssc...1/24/20233030드라이브 문자를 통해서 물리 디스크 명칭을 알아내고 싶습니다. [1]
5802모바일앱1/22/20232920XAMARINE vs Android Studio [7]
1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...