Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

Sysinternals의 모든 툴을 한번에 업데이트 하는 방법


sysinternals 툴... 많이들 쓰시죠. 가끔 필요한 툴만 하나씩 받아서 쓰는 경우도 있지만... 저 같은 경우에는 모든 툴을 포함한 압축 파일을 다운로드 받아 설치합니다.

Download Sysinternals Suite
; https://download.sysinternals.com/files/SysinternalsSuite.zip

그런데, 가끔 보면 일부 툴들이 업데이트가 되기도 하는데 일일이 다운로드 받아 업데이트 하는 것도 귀찮고, 전체 압축된 파일을 다운로드 받아 다시 덮어쓰는 것도 번거롭습니다. 음... 간단히 배치 파일로 만들 수 없을까요? 그렇죠! 방법이 없다면 이번 글을 쓰지도 않았겠지요. ^^

먼저 말씀드리면, 이번 팁의 해답은 아래의 토픽을 읽고 배운 것입니다.

Sysinternals tools from the web? You betcha 
; http://blogs.msdn.com/bryangr/archive/2008/12/15/sysinternals-tools-from-the-web-you-betcha.aspx

cd into Sysinternals Tools from PowerShell
; http://thepowershellguy.com/blogs/posh/archive/2008/05/31/cd-into-sysinternals-tools-from-powershell.aspx

와~~~, 대단하지요. ^^ 심지어, 이를 이용하면 sysinternals에서 공개되는 툴들을 굳이 다운로드 받지 않고도 아래와 같이 사용할 수가 있습니다.

C:\>pushd \\live.sysinternals.com

Z:\>dir
 Volume in drive Z has no label.
 Volume Serial Number is 0000-0000

 Directory of Z:\

2008-11-20  오전 07:58    <DIR>          .
2008-11-20  오전 07:58    <DIR>          ..
2008-05-31  오전 12:55               668 About_This_Site.txt
2008-11-11  오후 08:10           312,176 accesschk.exe
2006-11-01  오후 10:06           174,968 AccessEnum.exe
2007-07-12  오후 02:26            50,379 AdExplorer.chm
2007-11-26  오후 09:21           422,952 ADExplorer.exe
2007-11-07  오후 06:13           401,616 ADInsight.chm

...[중간 생략]...

2008-01-10  오전 12:38           148,520 Tcpview.exe
2002-09-02  오후 09:13             7,983 TCPVIEW.HLP
2008-11-18  오전 10:22    <DIR>          Tools
2006-11-01  오후 10:05           154,424 Volumeid.exe
2006-11-01  오후 10:06           158,520 whois.exe
2008-11-18  오전 10:10    <DIR>          WindowsInternals
2006-11-01  오후 10:06           207,672 Winobj.exe
1999-12-30  오후 07:26             7,653 WINOBJ.HLP
2008-11-11  오전 01:25           244,592 ZoomIt.exe
             102 File(s)     25,051,515 bytes
               5 Dir(s)   4,031,688,704 bytes free

Z:\>autoruns     <=== autoruns.exe 실행

오호... 이거야말로, "NTD (No touch deployment)"를 만족하는 가장 기본적인 수준의 "Smart Client"가 아닐까요? ^^ 물론, 최초 실행 속도는 "언제나" 느립니다. (로컬에 캐쉬를 해놓지 않기 때문에.)

결국, pushd 기능을 이용하면 다음과 같은 배치 파일 또는 PowerShell 스크립트 하나로 간단하게 자신의 컴퓨터에 모두 복사할 수 있고, 가끔씩만 실행시켜주면 최신 버전으로 유지된다는 사실!

----- update_sysinternals_tools.bat ----
pushd \\live.sysinternals.com
robocopy . d:\sysinternals /S /XD Files Tools /XF *.asp /W:1 /R:1
popd

----- update_sysinternals_tools.ps1 ----
cd \\live.sysinternals.com\Tools\
robocopy . d:\sysinternals /S /XD Files Tools /XF *.asp /W:1 /R:1





여기서 만족하지 않고. 저도 그렇게 사용해 볼 수 있는 폴더를 갖고 싶어졌습니다. 어떻게 해야 할까요? ^^

우선, 네트워크 파일 공유가 되어야 하기 때문에 컴퓨터 및 Access Point에서 다음의 포트를 열어주어야 합니다.

139 : NetBIOS 세션 서비스
445 : SMB

또한, live.sysinternals.com처럼 모두에게 접근을 허용하기 위해서는 GPO 정책에서 "Computer Configuration" / "Windows Settings" / "Security Settings" / "Local Policies" / "Security Options"의 "Accounts: Guest account status" 값을 "Enabled"로 설정해 줍니다. (참고로, 보안상 저는 이 값을 Enabled로 해놓지는 않았습니다. 따라서 아래의 예제대로 실행하면 네트워크 암호가 틀리다고 나올 것입니다.)

그렇게 설정해 주고, 특정 폴더(ex: Live)를 파일 공유 설정해 주니... ^^

C:\>pushd \\www.sysnet.pe.kr\live

위와 같이 저도 pushd로 연결이 되었습니다. 그런데, 한가지 풀지 못한 문제가 있는데, sysinternals의 경우에는 도메인 이름 자체만으로 pushd 연결이 되었는데, 저 같은 경우에는 반드시 하위에 폴더를 공유하고 그 경로까지 써주어야만 가능했습니다. 음... UNC 명에 직접 폴더가 매핑되는 방법이 있다는 건데 알 수가 없네요. ^^




한가지 더, 아쉬운 점이 있다면... pushd로 live.sysinternals.com에 연결이 되는 컴퓨터가 있는가 하면, 그렇지 않은 컴퓨터도 있네요. 같은 네트워크에 있는 PC인데도 왜 그런 차이가 있는지에 대해서는 이유를 알 수가 없는데... 흠... 일단 오늘은 여기까지! ^^ (업데이트: 2021-04-06 - WebClient 서비스의 실행 유무에 따라 차이가 발생합니다.)



[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 12/24/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2014-12-02 12시45분
Sysinternals의 모든 도구에 대해 eula 여부를 통과시키는 레지스트리 설정

Sysinternals’ Eulagoogoolizer
; http://www.hexacorn.com/blog/2014/11/30/sysinternals-eulagoogoolizer/

Windows Registry Editor Version 5.00

[HKEY_CURRENT_USER\Software\Sysinternals\A]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Active Directory Explorer]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Autologon]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\AutoRuns]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\C]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\CacheSet]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\ClockRes]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Coreinfo]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Ctrl2cap]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\DbgView]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Desktops]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Disk2Vhd]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Diskmon]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\DiskView]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\EFSDump]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\FindLinks]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Handle]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Hex2Dec]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Junction]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\LdmDump]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\ListDLLs]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\LoadOrder]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Movefile]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\PageDefrag]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\PendMove]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\PipeList]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Portmon]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\ProcDump]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Process Explorer]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Process Monitor]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\PsExec]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\psfile]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\PsGetSid]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\PsInfo]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\PsKill]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\PsList]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\PsLoggedon]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\PsLoglist]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\PsPasswd]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\PsService]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\PsShutdown]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\PsSuspend]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\RegDelNull]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Regjump]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Regsize]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\RootkitRevealer]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Share Enum]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\ShellRunas - Sysinternals: www.sysinternals.com]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\SigCheck]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Streams]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Strings]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Sync]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\TCPView]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\VMMap]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\VolumeID]
"EulaAccepted"=dword:00000001
[HKEY_CURRENT_USER\Software\Sysinternals\Winobj]
"EulaAccepted"=dword:00000001
정성태

... 16  17  18  [19]  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13179정성태12/2/20224663Windows: 216. Windows 11 - 22H2 업데이트 이후 Terminal 대신 cmd 창이 뜨는 경우
13178정성태12/1/20225254Windows: 215. Win32 API 금지된 함수 - IsBadXxxPtr 유의 함수들이 안전하지 않은 이유파일 다운로드1
13177정성태11/30/20225945오류 유형: 829. uwsgi 설치 시 fatal error: Python.h: No such file or directory
13176정성태11/29/20224785오류 유형: 828. gunicorn - ModuleNotFoundError: No module named 'flask'
13175정성태11/29/20226670오류 유형: 827. Python - ImportError: cannot import name 'html5lib' from 'pip._vendor'
13174정성태11/28/20225093.NET Framework: 2073. C# - VMMap처럼 스택 메모리의 reserve/guard/commit 상태 출력파일 다운로드1
13173정성태11/27/20225846.NET Framework: 2072. 닷넷 응용 프로그램의 스레드 스택 크기 변경
13172정성태11/25/20225563.NET Framework: 2071. 닷넷에서 ESP/RSP 레지스터 값을 구하는 방법파일 다운로드1
13171정성태11/25/20225234Windows: 214. 윈도우 - 스레드 스택의 "red zone"
13170정성태11/24/20225474Windows: 213. 윈도우 - 싱글 스레드는 컨텍스트 스위칭이 없을까요?
13169정성태11/23/20226050Windows: 212. 윈도우의 Protected Process (Light) 보안 [1]파일 다운로드2
13168정성태11/22/20225391제니퍼 .NET: 31. 제니퍼 닷넷 적용 사례 (9) - DB 서비스에 부하가 걸렸다?!
13167정성태11/21/20225409.NET Framework: 2070. .NET 7 - Console.ReadKey와 리눅스의 터미널 타입
13166정성태11/20/20225128개발 환경 구성: 651. Windows 사용자 경험으로 WSL 환경에 dotnet 런타임/SDK 설치 방법
13165정성태11/18/20224957개발 환경 구성: 650. Azure - "scm" 프로세스와 엮인 서비스 모음
13164정성태11/18/20225957개발 환경 구성: 649. Azure - 비주얼 스튜디오를 이용한 AppService 원격 디버그 방법
13163정성태11/17/20225877개발 환경 구성: 648. 비주얼 스튜디오에서 안드로이드 기기 인식하는 방법
13162정성태11/15/20226955.NET Framework: 2069. .NET 7 - AOT(ahead-of-time) 컴파일
13161정성태11/14/20226246.NET Framework: 2068. C# - PublishSingleFile로 배포한 이미지의 역어셈블 가능 여부 (난독화 필요성) [4]
13160정성태11/11/20226120.NET Framework: 2067. C# - PublishSingleFile 적용 시 native/managed 모듈 통합 옵션
13159정성태11/10/20229433.NET Framework: 2066. C# - PublishSingleFile과 관련된 옵션 [3]
13158정성태11/9/20225529오류 유형: 826. Workload definition 'wasm-tools' in manifest 'microsoft.net.workload.mono.toolchain' [...] conflicts with manifest 'microsoft.net.workload.mono.toolchain.net7'
13157정성태11/8/20226173.NET Framework: 2065. C# - Mutex의 비동기 버전파일 다운로드1
13156정성태11/7/20227148.NET Framework: 2064. C# - Mutex와 Semaphore/SemaphoreSlim 차이점파일 다운로드1
13155정성태11/4/20226595디버깅 기술: 183. TCP 동시 접속 (연결이 아닌) 시도를 1개로 제한한 서버
13154정성태11/3/20226098.NET Framework: 2063. .NET 5+부터 지원되는 GC.GetGCMemoryInfo파일 다운로드1
... 16  17  18  [19]  20  21  22  23  24  25  26  27  28  29  30  ...