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
정성태

... [121]  122  123  124  125  126  127  128  129  130  131  132  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
10899정성태2/17/201623342개발 환경 구성: 282. kernel32.dll, kernel32legacy.dll, api-ms-win-core-sysinfo-l1-2-0.dll [1]
10898정성태2/17/201621798.NET Framework: 547. PerformanceCounter의 InstanceName 지정 시 주의 사항파일 다운로드1
10897정성태2/17/201621131디버깅 기술: 76. windbg 분석 사례 - 닷넷 프로파일러의 GC 콜백 부하
10896정성태2/17/201622297오류 유형: 320. FATAL: 28000: no pg_hba.conf entry for host "fe80::1970:8120:695:a41e%12"
10895정성태2/17/201621096.NET Framework: 546. System.AppDomain으로부터 .NET Profiler의 AppDomainID 구하는 방법 [1]
10894정성태2/17/201621828오류 유형: 319. Visual Studio에서 찾기는 성공하지만 해당 소스 코드 정보가 보이지 않는 경우
10893정성태2/16/201620474.NET Framework: 545. 닷넷 - 특정 클래스가 로드되었는지 여부를 알 수 있을까? - 두 번째 이야기
10892정성태2/16/201621091오류 유형: 318. 탐색기에서 폴더 생성/삭제 시 몇 초 동안 멈추는 현상
10891정성태2/16/201624112VC++: 95. 내 CPU가 MPX/SGX를 지원할까요? [1]
10890정성태2/15/201623977.NET Framework: 544. C# 5의 Caller Info를 .NET 4.5 미만의 응용 프로그램에 적용하는 방법 [5]
10889정성태2/14/201620267.NET Framework: 543. C++의 inline asm 사용을 .NET으로 포팅하는 방법 - 두 번째 이야기파일 다운로드1
10888정성태2/14/201618625.NET Framework: 542. 닷넷 - 특정 클래스가 로드되었는지 여부를 알 수 있을까?
10887정성태2/3/201619287VC++: 94. MPX(Memory Protection Extensions) 테스트파일 다운로드1
10886정성태2/3/201620522개발 환경 구성: 281. Intel MPX Runtime Driver 수동 설치
10885정성태2/2/201620210오류 유형: 317. Sybase.Data.AseClient.AseException: The command has timed out.
10884정성태1/11/201621433개발 환경 구성: 280. 닷넷에서 SAP Adaptive Server Enterprise 데이터베이스 사용파일 다운로드1
10882정성태1/6/201620728Windows: 113. 윈도우의 2179, 26143, 47001 TCP 포트 사용 [1]
10881정성태1/3/201622164오류 유형: 316. 윈도우 10 - 바탕/돋음 체가 사라져 한글이 깨지는 현상 [2]
10880정성태12/16/201519833오류 유형: 315. 닷넷 프로파일러의 오류 코드 정보
10879정성태12/16/201521768오류 유형: 314. Error : DEP0700 : Registration of the app failed. error 0x80070005
10878정성태12/9/201524831디버깅 기술: 75. UWP(유니버설 윈도우 플랫폼) 앱에서 global::System.Diagnostics.Debugger.Break 예외 발생 시 대응 방법
10877정성태12/9/201529269VC++: 93. std::thread 사용 시 R6010 오류 [2]
10876정성태11/26/201525323.NET Framework: 541. SignedXml을 이용한 ds:Signature만드는 방법 [3]파일 다운로드1
10875정성태11/26/201530312개발 환경 구성: 279. signtool.exe의 다중 서명 기능 [2]
10874정성태11/26/201526314개발 환경 구성: 278. 인증서와 인증서를 이용한 코드 사인의 해시 구분
10873정성태11/25/201525433.NET Framework: 540. C# - 부동 소수 계산 왜 이렇게 나오죠? (2) [3]파일 다운로드1
... [121]  122  123  124  125  126  127  128  129  130  131  132  133  134  135  ...