Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

유닉스 계열의 tail 명령어가 제공되는 PowerShell

성태가 요즘 PowerShell에 푸~~~욱 빠졌습니다. ^^

PowerShell로 Visual Studio 빌드 스크립트 작성
; https://www.sysnet.pe.kr/2/0/1687

개발하면서 소소하게 반복하던 작업들을 PowerShell로 쉽게 자동화하면서 은근한 재미를 느끼고 있답니다. ^^

오늘은 아래의 책을 보다가,

개발자를 위한 파워셸
; http://www.yes24.com/24/goods/12759997?scode=032

유닉스 계열의 tail 명령어 구현이 PowerShell에서 어떻게 제공되는지 읽게 되었습니다. 명령어는 다음과 같이 간단합니다.

Get-Content ./test.log -Wait -Tail 1000

위와 같이 실행하면 ./test.log 파일을 읽어 마지막 1,000라인을 출력하고 이후로는 test.log 파일이 변경될 때마다 연속해서 화면에 출력해줍니다.

한가지 응용을 해볼까요? ^^

제 경우에 개발하고 있는 응용 프로그램에서 남기는 로그의 형식이 "[EXE이름]_[날짜YYYYMMDD]_[기타].log" 이렇습니다. 날짜가 하루마다 바뀌기 때문에 "Get-Content ./test.log -Wait -Tail 1000"과 같은 식으로 하면 매번 파일명을 바꿔서 실행해야 하는 불편함이 있는데요. 이를 다음과 같이 확장해 주면 문제가 말끔히 해결됩니다.

$logPath = [IO.Path]::Combine($PSScriptRoot)

$latestFileName = Get-ChildItem $logPath | Sort Name -Descending | Select-Object -First 1

$logFile = [IO.Path]::Combine($logPath, $latestFileName)
Get-Content $logFile -Wait -Tail 50

필요에 따라 Sort를 파일명이 아닌 LastWriteTime 기준으로 해도 될 것입니다.

$latestFileName = Get-ChildItem $logPath | Sort LastWriteTime -Descending | Select-Object -First 1

이렇게 작성한 후 PowerShell ISE에서 해당 파워셸 스크립트 파일을 로딩하고 필요할 때 마다 "F5(Run)"를 눌러주면 가장 최신의 파일을 자동으로 선택해서 tail 기능을 수행해 줍니다.

ps_tail_1.png

오~~~ 멋지죠? ^^

한 가지 더 첨언하면! 위의 "PowerShell ISE"에서 "File" / "New PowerShell Tab" 메뉴를 누르면 "PowerShell 콘솔"을 가진 또 하나의 탭이 추가됩니다. 이곳에 다시 다른 Tail 명령어를 수행하면, 아래의 화면처럼 로그 파일 모니터링을 한 윈도우에서 다중으로 수행할 수 있습니다.

ps_tail_2.png




며칠 사용하다 보니, PowerShell의 매력 요소가 꼽아집니다.

  • 닷넷 라이브러리를 쓸 수 있다.
  • 닷넷 전용 REPL 환경이라고 볼 수 있다. (닷넷에 동적 언어가 하나 추가되었다.)
  • REPL 환경이면서 '명령행 셸'과 통합되어 있다.

가령 python이 REPL 환경을 자랑하지만, Shell은 아니기 때문에 윈도우에서 수행되는 다양한 '반복적인' 일들을 수행하기에는 PowerShell만큼 편하지는 않습니다.

만약 여러분들이 닷넷 개발자라면, 오늘 당장 ^^ 꼬~~~옥 PowerShell을 익혀보시기 바랍니다. 강추입니다. ^^

개발자가 아니더라도, 윈도우 환경에서 일상적인 업무를 수행하시는 분이라면 역시 PowerShell을 추천합니다. 자신이 프로그램을 못하더라도 웹 상에 널려 있는 스크립트 예제가 풍부하기 때문에 원하는 일을 보다 쉽게 자동화할 수 있습니다.




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







[최초 등록일: ]
[최종 수정일: 6/19/2014]

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

비밀번호

댓글 작성자
 



2024-10-02 11시21분
// 해당 디렉터리에서 가장 최신의 파일을 대상으로 tail 명령어 실행
$ tail -f `ls -t | head -1`

// 로그 파일명의 일부를 지정해 최신 파일을 대상으로!
$ tail -f `ls -t /tmp/myapp*.log | head -1`

// "systemctl status xxx.service"와 같은 서비스 상태를 실시간으로 추적하고 싶을 때
# journalctl --follow -u xxx.service
정성태

... 166  167  168  169  170  171  172  173  174  175  176  [177]  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
566정성태2/28/200825218.NET Framework: 99. AppDomain.GetEntryAssembly()를 우회하는 방법파일 다운로드1
564정성태2/16/200824734Windows: 30. TS Web Access + Vista SP1 [2]
563정성태2/16/200824125오류 유형: 51. Vista(UAC) + 웹 프로젝트 디버깅: System.UnauthorizedAccessException
562정성태2/12/200828535Windows: 29. Windows Server 2008 설치 [4]
561정성태1/10/200822224오류 유형: 50. IE 7 + 잘못된 HTC 파일 경로 = File not found [5]
559정성태1/1/200827107Windows: 28. Vista에서 끌어다 놓기로 GAC 등록하는 방법 [2]
558정성태1/1/200843763개발 환경 구성: 33. 32bit/64bit OLE DB Provider [1]
557정성태12/22/200722703개발 환경 구성: 32. WSCF와 VS.NET 2008
556정성태12/16/200720845기타: 22. 인기 순위 정리 : 조회수 1000 회 이상
555정성태12/16/200723577기타: 21. 인기 순위 정리 : 조회수 500 ~ 999회 글 목록
554정성태12/16/200728198기타: 20. 인기 순위 정리 : 조회수 250 ~ 499회 글 목록
553정성태12/16/200728482기타: 19. 인기 순위 정리 : 조회수 100 ~ 249회 글 목록
552정성태12/16/200722105기타: 18. 인기 순위 정리 : 조회수 000 ~ 099 회 글 목록
550정성태12/16/200721078Team Foundation Server: 23. TFS 2005에서 TFS 2008로 마이그레이션 [2]
549정성태12/16/200722505Team Foundation Server: 22. TFS 설정 - 주소를 도메인으로 변경
548정성태12/15/200740129오류 유형: 49. Report Server - 원격 서버에 연결할 수 없습니다
547정성태12/4/200728580.NET Framework: 98. .NET 비동기 Socket과 스레드
546정성태12/4/200719627Team Foundation Server: 21. Microsoft Office가 참조된 경우의 빌드 환경 구성
545정성태12/4/200726355Windows: 27. 눈으로 확인해 보는 ASLR 기능 [1]
544정성태11/25/200722277오류 유형: 48. VS.NET 2008 설치 오류 - Error code 1602 [5]
543정성태11/25/200725304개발 환경 구성: 31. ROBOCOPY XP026 버전 [1]
542정성태11/3/200740342VS.NET IDE: 55. XML/XSLT로 구현하는 매크로 확장 [5]파일 다운로드2
538정성태10/11/200726813스크립트: 10. VBScript - "Sub를 호출할 때는 괄호를 사용할 수 없습니다." [2]
537정성태9/28/200735439개발 환경 구성: 30. 64비트 OS에서의 ChartFX 라이선스 문제
536정성태9/12/200732257.NET Framework: 97. WCF : netTcpBinding에서의 각종 Timeout 값 설명 [11]
535정성태9/11/200729785.NET Framework: 96. WCF - PerSession에서의 클라이언트 연결 관리 [5]
... 166  167  168  169  170  171  172  173  174  175  176  [177]  178  179  180  ...