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

... 91  92  93  94  95  96  97  98  [99]  100  101  102  103  104  105  ...
NoWriterDateCnt.TitleFile(s)
11457정성태2/17/201824024.NET Framework: 732. C# - Task.ContinueWith 설명 [1]파일 다운로드1
11456정성태2/17/201829778.NET Framework: 731. C# - await을 Task 타입이 아닌 사용자 정의 타입에 적용하는 방법 [7]파일 다운로드1
11455정성태2/17/201818663오류 유형: 451. ASP.NET Core - An error occurred during the compilation of a resource required to process this request.
11454정성태2/12/201827542기타: 71. 만료된 Office 제품 키를 변경하는 방법
11453정성태1/31/201819499오류 유형: 450. Azure Cloud Services(classic) 배포 시 "Certificate with thumbprint ... doesn't exist." 오류 발생
11452정성태1/31/201825021기타: 70. 재현 가능한 최소한의 예제 프로젝트란? [3]파일 다운로드1
11451정성태1/24/201819246디버깅 기술: 111. windbg - x86 메모리 덤프 분석 시 닷넷 메서드의 호출 인자 값 확인
11450정성태1/24/201834524Windows: 146. PowerShell로 원격 프로세스(EXE, BAT) 실행하는 방법 [1]
11449정성태1/23/201821888오류 유형: 449. 단위 테스트 - Could not load file or assembly 'Microsoft.VisualStudio.QualityTools.VideoRecorderEngine' or one of its dependencies. [1]
11448정성태1/20/201819409오류 유형: 448. Fakes를 포함한 단위 테스트 프로젝트를 빌드 시 CS0619 관련 오류 발생
11447정성태1/20/201820743.NET Framework: 730. dotnet user-secrets 명령어 [2]파일 다운로드1
11446정성태1/20/201821762.NET Framework: 729. windbg로 살펴보는 GC heap의 Segment 구조 [2]파일 다운로드1
11445정성태1/20/201819633.NET Framework: 728. windbg - 눈으로 확인하는 Workstation GC / Server GC
11444정성태1/19/201819729VS.NET IDE: 125. Visual Studio에서 Selenium WebDriver를 이용한 웹 브라우저 단위 테스트 구성파일 다운로드1
11443정성태1/18/201820325VC++: 124. libuv 모듈 살펴 보기
11442정성태1/18/201818122개발 환경 구성: 353. ASP.NET Core 프로젝트의 "Enable unmanaged code debugging" 옵션 켜는 방법
11441정성태1/18/201816637오류 유형: 447. ASP.NET Core 배포 오류 - Ensure that restore has run and that you have included '...' in the TargetFrameworks for your project.
11440정성태1/17/201819921.NET Framework: 727. ASP.NET의 HttpContext.Current 구현에 대응하는 ASP.NET Core의 IHttpContextAccessor/HttpContextAccessor 사용법파일 다운로드1
11439정성태1/17/201824785기타: 69. C# - CPU 100% 부하 주는 프로그램파일 다운로드1
11438정성태1/17/201819527오류 유형: 446. Error CS0234 The type or namespace name 'ITuple' does not exist in the namespace
11437정성태1/17/201818839VS.NET IDE: 124. Platform Toolset 설정에 따른 Visual C++의 헤더 파일 기본 디렉터리
11436정성태1/16/201821096개발 환경 구성: 352. ASP.NET Core (EXE) 프로세스가 IIS에서 호스팅되는 방법 - ASP.NET Core Module(AspNetCoreModule) [4]
11435정성태1/16/201822193개발 환경 구성: 351. OWIN 웹 서버(EXE)를 IIS에서 호스팅하는 방법 - HttpPlatformHandler (Reverse Proxy)파일 다운로드2
11434정성태1/15/201822560개발 환경 구성: 350. 사용자 정의 웹 서버(EXE)를 IIS에서 호스팅하는 방법 - HttpPlatformHandler (Reverse Proxy)파일 다운로드2
11433정성태1/15/201820643개발 환경 구성: 349. dotnet ef 명령어 사용을 위한 준비
11432정성태1/11/201826394.NET Framework: 726. WPF + Direct2D + SharpDX 출력 C# 예제파일 다운로드2
... 91  92  93  94  95  96  97  98  [99]  100  101  102  103  104  105  ...