Microsoft MVP성태의 닷넷 이야기
WMI 를 사용하지 않고 하드웨어 정보를 가져올 수 없을까요? [링크 복사], [링크+제목 복사],
조회: 19966
글쓴 사람
이성환 (vactorman at naver.com)
홈페이지
첨부 파일
 

안녕하세요.

유용한 정보 매번 잘 보고 있습니다.

간단히 질문하자면...



C#으로 작업 하면서 하드웨어 정보를 가져오는 작업을 종종 했었는데요,

그 때마다 WMI를 사용하는 게 당연하다고 생각했습니다.

그런데 속도 문제가 좀 걸리더군요.

CPU, Mainboard, Memory, HDD 등의 일부 정보(예를 들면 시리얼이나 메모리는 전체 size 정도)를 WMI로 쿼리하는데

대략 1.5초 정도 걸리더군요.

많은 양을 쿼리한 건 아니고 그냥 CPU 1번, Mainboard 1번 이런 식으로 5번(CPU 개수가 1개 인 경우는 4번, 2개 인 경우는 5번) 정도 쿼리를 했습니다.

그러니까 최대 5번 쿼리 시 대략 1.5 정도의 시간이 걸렸습니다.

어플리케이션에서 1.5는 그렇다 치더라도

지금은 웹으로 하드웨어 정보를 가져와야하는 상황이라 (클라이언트 하드웨어 정보가 아니라 서버 정보입니다.)

WMI를 사용하기 적절하지 않다고 판단하고 있습니다. (웹에서 1.5초는 사용자가 다른 페이지를 선택하도록 만드는 시간이라..)



구글링을 약간 해서 얻은 결과는

'C#으로 WMI 없이 하드웨어 정보를 가져오는 게 불가능 하다.' 정도 였습니다...OTL
(물론 WMI 아닌 다른 방법으로 하드웨어 정보를 가져올 때 1.5 초 이상 걸린다면 그것도 의미가 없겠죠.)


아.. 그러면 제목에 쓴 질문을 바꾸는 게 더 좋을지도 모르겠네요.

더 속도 빠른 하드웨어 검색 방법이 있는 지 여쭤봐도 될까요?








[최초 등록일: ]
[최종 수정일: 5/4/2011]


비밀번호

댓글 작성자
 



2011-05-04 04시32분
적절하게 조합하시는 게 좋지 않을까요? Win32 API 로 가져올 수 있는 정보도 있을 것입니다. 일례로, 메모리 전체 크기 정도는 WMI 쓰실 필요없이 P/Invoke 로 Win32 API호출하면 됩니다. 그리고 약간의 캐시도 곁들이면 좋겠지요. Win32 API에서 제공되지 않는다면 WMI를 사용하더라도 약간의 데이터 캐시를 하는 것이 좋지 않을까 싶습니다. 예를 들어, 전체 메모리나 시리얼 번호 등은 쉽게 변하는 것은 아니니까요.

그리고, C++/CLI를 적절하게 곁들이면 더욱 좋을 것입니다.
정성태
2011-05-06 10시17분
[이성환] 답변 감사드립니다.

나머지 것들은 그냥 WMI 를 사용해도 무방할 듯하구요.(4번 쿼리 날리는 시간이 대략 0.2 초 내외 더군요.)

사실상 시간이 많이 걸리는 작업은 CPU의 ProcessorName을 가져오는 건데요. 이게 전체 작업 시간의 90% 이상을 차지 하더군요.

그래서 CPU ProcessorName 찾는 걸 Win32 API로 P/Invoke 해보려고 했는데요.

구글링해보니까 CPU ProcessorName만 가져오는 Win32 API는 찾기 힘들더군요.(제 검색 능력 부족이란 생각이 듭니다.)

이게 라이센스 관련된 부분이다보니 필요할 때마다 매번 새로 불러서 써야하는 제약이 좀 있구요.

제가 C++에 문외한이라(오직 C# ;ㅅ;)

C++/CLI는 어떤 형태를 말씀하시건 지 잘 모르겠습니다. 혹시 C++로 dll을 작성한 후 참조하는 형식을 말씀하신 건가요?


[guest]
2011-05-07 10시38분
C++ 구문과 .NET 에서의 접속을 쉽게 하는 구문이 혼합된 것이 C++/CLI입니다. 그래서, 웹에 있는 C++ 코드가 있으면 그대로 가져다가 빌드한 후, 다른 .NET 언어에서 호출할 수 있도록 래퍼해주면 됩니다. 일단은 C++ 을 안해보셨다면 고려 대상은 안될 것 같지만, 간단한 C++ 소스 코드 정도는 굳이 언어를 몰라도 가져올 수 있으므로 적어본 것입니다.

어쨌든, CPU ProcessorName이라면 더더욱 캐쉬 한번으로 끝낼 수 있으므로 WMI를 써야하는데 그다지 제약이라고 할 건 아닌 것 같습니다. ^^
정성태

... 76  77  78  79  [80]  81  82  83  84  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
493안연준10/25/200614002스마트클라이언트 배포에서 Config 내용이 이해가 안되요
494안연준10/25/200612151    답변글 [답변]: 스마트클라이언트 배포에서 Config 내용이 이해가 안되요 [2]
489안연준10/23/200613337스마트 클라이언트 배포시 문제점
491안연준10/24/200614037    답변글 [답변]: 스마트 클라이언트 배포시 문제점 [2]
492안연준10/24/200613027        답변글 [답변]: [답변]: 스마트 클라이언트 배포시 문제점
488안연준10/23/200612776닷넷 프레임워크 때문에 일어난 어의없는 상황 [2]
484서민균10/20/200612914스마트 클라이언트 인쇄질문 올린 사람입니다.
486정성태10/22/200614167    답변글 [답변]: 스마트 클라이언트 인쇄질문 올린 사람입니다.
483guest10/19/200613208asp.net 에서 Com+ 등록된 dll 의 차이점이 무엇인지요?
485정성태10/22/200613836    답변글 [답변]: asp.net 에서 Com+ 등록된 dll 의 차이점이 무엇인지요?
490deve...10/23/200617041        답변글 [답변]: [답변]: asp.net 에서 Com+ 등록된 dll 의 차이점이 무엇인지요? [1]
478서민균10/17/200615017스마트 클라이언트로 만든 컴포넌트가 인쇄가 안되요.....ㅜㅜ [5]
477sagi...10/15/200614259bho 와 mfc 메시지 전송 관련 질문입니다.
479정성태10/17/200616016    답변글 [답변]: bho 와 mfc 메시지 전송 관련 질문입니다.
480sagi...10/17/200613955        답변글 [답변]: 감사합니다. [1]
481sagi...10/19/200613912            답변글 [답변]: 죄송합니다 .. 한가지 더 여쭤 볼께요
482정성태10/19/200613441                답변글 [답변]: [답변]: 죄송합니다 .. 한가지 더 여쭤 볼께요
496sagi...10/27/200614091                    답변글 [답변]: 감사드립니다.
476문태정10/11/200616439FarPointSpread로 출력 시 시트 암호설정문제 [1]
474임경훈10/9/200616952세션값이 유지가 안되는데요? [1]
470쿠리마9/29/200613248고수님들께 질문 올립니다. (C# COM Server에서 C++ Client에게 string맴버 포함한 구조체 배열 넘기기)파일 다운로드1
473정성태10/5/200615296    답변글 [답변]: 고수님들께 질문 올립니다. (C# COM Server에서 C++ Client에게 string맴버 포함한 구조체 배열 넘기기) [3]파일 다운로드1
469이방은9/29/200612937질문이 있어요.. [2]
466이승기9/25/200612716Attribute를 이용한 COM 구현 시 interface의 상속 [1]
467이승기9/27/200612291    답변글 [답변]: Attribute를 이용한 COM 구현 시 interface의 상속
4659/23/200611819vb.net에서 c에서 보내는 Post메쎄지를 잡아서 처리할수 없을가요? [1]
... 76  77  78  79  [80]  81  82  83  84  85  86  87  88  89  90  ...