heroku-모든 로그를 보는 방법
heroku에 작은 앱이 있습니다. 로그를보고 싶을 때마다 명령 줄로 이동하여
heroku logs
그것은 단지 약 100 줄을 보여줍니다. heroku에서 애플리케이션의 전체 로그를 볼 수있는 방법이 없습니까?
업데이트 (dawmail333 덕분에) :
heroku logs -n 1500
또는, 통나무를 라이브 꼬리로
heroku logs -t
수천 줄 이상이 필요한 경우 heroku의 Syslog Drains를 사용할 수 있습니다
또는 (이전 방법) :
$ heroku run rails c
File.open('log/production.log', 'r').each_line { |line| puts line }
heroku에서 로깅이 크게 향상되었습니다!
$ heroku logs -n 500
보다 나은!
$ heroku logs --tail
참조 : http://devcenter.heroku.com/articles/logging
업데이트
이들은 더 이상 애드온이 아니라 기본 기능의 일부입니다. :)
Heroku는 로그를 시간순으로 정렬 된 이벤트 스트림으로 취급합니다. *.log
이러한 환경에서는 여러 가지 이유로 파일 시스템의 파일에 액세스 하지 않는 것이 좋습니다.
첫째, 앱에 둘 이상의 dyno가있는 경우 각 로그 파일은 앱 이벤트에 대한 부분보기 만 나타냅니다. 전체 파일을 보려면 모든 파일을 수동으로 집계해야합니다.
둘째, Heroku의 파일 시스템은 dyno가 다시 시작되거나 이동 될 때마다 ( 일일 에 한 번 발생 ) 로그 파일이 손실 될 때마다 일시적인 의미를 갖 습니다. 그래서 당신은 그 단일 dyno의 로그를 하루에 최대로 볼 수 있습니다.
마지막으로 Cedar 스택이 실행 중이 heroku console
거나 heroku run bash
현재 실행중인 dyno에 연결되지 않습니다. bash
명령을 위해 특별히 새로운 것을 생성합니다 . 이것을 일회성 프로세스 라고합니다 . 따라서에 생성 된 프로세스에서 실제 http 프로세스를 실행중인 다른 dyno에 대한 로그 파일을 찾을 수 없습니다 heroku run
.
로깅 및 가시성은 일반적으로 Heroku의 일류 시민이며 이러한 문제를 해결하는 몇 가지 도구가 있습니다. 먼저 모든 dyno 및 애플리케이션 / 스택의 모든 계층 에서 실시간으로 애플리케이션 이벤트 스트림을 보려면 이 heroku logs -t
명령을 사용하여 출력을 터미널에 출력하십시오.
$ heroku logs -t
2010-09-16T15:13:46-07:00 app[web.1]: Processing PostController#list (for 208.39.138.12 at 2010-09-16 15:13:46) [GET]
2010-09-16T15:13:46-07:00 app[web.1]: Rendering template within layouts/application
2010-09-16T15:13:46-07:00 heroku[router]: GET myapp.heroku.com/posts queue=0 wait=0ms service=1ms bytes=975
2010-09-16T15:13:47-07:00 app[worker.1]: 2 jobs processed at 16.6761 j/s, 0 failed ...
이것은 현재 응용 프로그램의 동작을 관찰하는 데 효과적입니다. 로그를 장기간 저장하려면 로그 보존, 경고 및 트리거를 제공 하는 많은 로깅 추가 기능 중 하나를 사용할 수 있습니다 .
마지막으로, 로그 파일을 직접 저장하려면 Heroku에서 이벤트 스트림을 수신하고 사후 프로세스 / 분석을 수행하도록 자체 syslog 드레인 을 설정할 수 있습니다 .
요약 : 정적 로그 파일을 사용 heroku console
하거나 보지 마십시오 heroku run bash
. heroku logs
로깅 추가 기능을 사용하여 앱에 대한 Heroku의 로그 이벤트 스트림으로 파이프하십시오 .
개별 스트림 / 필터도 참조하십시오.
예를 들어 애플리케이션 로그 만 테일
heroku logs --source app -t
또는 라우터 로그 만보십시오
heroku logs --ps router
아니면 함께 묶어
heroku logs --source app --ps worker
너무 좋아 ..
위의 답변은 명령 줄에서 볼 수 있도록 도움이됩니다. 반면 GUI를 사용하려면 heroku 계정에 로그인 한 다음 응용 프로그램을 선택하고 마지막으로 로그보기를 클릭해야합니다
heroku 로깅을 따르십시오
우리는 당신의 로그를 볼 수 있습니다 :
- logs 명령은 기본적으로 100 개의 로그 라인을 검색합니다.
헤 로쿠 로그
- 최대 1500 줄, --num (또는 -n) 옵션을 표시합니다.
heroku logs -n 200
- 실시간으로 로그 표시
heroku logs-꼬리
- heroku에 많은 앱이 있다면
heroku logs --app your_app_name
heroku logs -t
라이브 로그를 보여줍니다.
Heroku의 명령 줄 인터페이스 ( CLI 사용법 )를 사용하여 로그 파일에 액세스 할 수 있습니다 .
Heroku의 CLI가 설치되어 있고 응용 프로그램 이름 (예 :)을 알고 있다면 https://myapp.herokuapp.com/
다음 명령을 실행할 수 있습니다.
heroku logs --tail --app=myapp
다음을 사용하여 실시간 스트림으로 로그에 액세스 할 수도 있습니다.
heroku logs --source app --tail --app=myapp
로그가 다음과 같이 말하는 경우 :
npm ERR! 이 실행의 전체 로그는 다음에서 찾을 수 있습니다.
npm ERR! /app/.npm/_logs/2017-07-11T08_29_45_291Z-debug.log
그런 다음 Heroku CLI를 통해 bash 터미널을 사용하여 액세스 할 수도 있습니다.
heroku run bash --app=myapp
less ./.npm/_logs/2017-07-11T08_29_45_291Z-debug.log
무료 Papertrail 계획 과 같은 것을 앱 에 추가하는 것이 좋습니다 . 구성이 필요 없으며 최대 10MB / 일의 7 일 분량의 로깅 데이터를 얻을 수 있으며 2 일의 로그를 다시 검색 할 수 있습니다.
WAR 파일의 경우 :
나는 github을 사용하지 않고 대신 WAR 파일을 직접 업로드했습니다 (이 파일은 훨씬 쉽고 빠릅니다).
그래서 다음이 도움이되었습니다.
heroku logs --app appname
누군가에게 도움이되기를 바랍니다.
자세한 로그를 보려면 production.rb
파일 에 두 줄을 입력해야 합니다.
config.logger = Logger.new(STDOUT)
config.logger.level = Logger::DEBUG
그런 다음
heroku logs -t
자세한 로그를 볼 수 있습니다.
이런 식으로하는 것을 선호합니다
heroku logs --tail | tee -a herokuLogs
스크립트를 백그라운드에서 실행중인 상태로두고 언제든지 원하는 방식으로 텍스트 파일의 로그를 필터링 할 수 있습니다.
내 솔루션은 응용 프로그램을 처음 시작할 때 다음과 같이 완전한 로그를 얻는 것입니다.
heroku logs -n 1500 > log
그런 다음 다음 fgrep -vf
과 같이 최신 상태로 유지하십시오.
heroku logs -n 1500 > newlog ; fgrep -vf log newlog >> log
연속 로깅의 경우 x 분 (또는 초)마다 watch를 사용하여 반복하십시오.
-t
또는 --tail
옵션 을 사용해야 하고 heroku 앱 이름을 정의해야합니다.
heroku logs -t --app app_name
나는 애드온을 사용하고 Logentries를 사용하는 것이 좋습니다. 이를 사용하려면 명령 행에서 실행하십시오.
heroku addons:create logentries:le_tryit
(이 명령은 무료 계정에 대한 애드온을 생성하지만 원하는 경우 분명히 업그레이드 할 수 있습니다)
Logentries를 사용하면 매월 최대 5GB의 로그 볼륨을 저장할 수 있습니다. 이 정보는 지난 7 일 이내에 명령 검색으로 검색 할 수 있으며 실시간 알림이 있습니다.
따라서이 애드온을 사용하여 Heroku가 기본적으로 저장하는 1500 줄에 도달 할 때 로그가 더 이상 손실되지 않도록하십시오. 도움이 되었기를 바랍니다! 좋은 하루 되세요!
heroku logs -t
라이브 로그를 보여줍니다. heroku logs -n 1500
특정 수의 로그
그러나 여전히 이점이 있지만 무료 기본 계획이있는 종이 흔적 추가 기능을 사용하는 것이 좋습니다.
당신이 사용할 수있는 heroku logs -n 1500
그러나 이것은 권장되는 접근법이 아닙니다 (즉, 실제 그림을 보여주지 않습니다)
로깅 도구를 연결하는 것이 좋습니다. 부가 기능으로 (sumoLogic, paper trail n all)
그들은 모두 무료 버전을 가지고 있습니다 (작은 앱이나 개발 환경에는 충분하지만 제한 사항이 거의 없지만 로그를 분석하는 데 유용한 통찰력과 도구를 제공합니다)
모든 로그를 보려면 로그 유출을 구현해야하며 로그를 비워야합니다 (모든 기록 로그 관리).
- 첫 번째 옵션 -Splunk를 사용할 수 있습니다. 다음과 같이 모든 로그를 비울 수 있습니다.
heroku drains:add syslog+tls://splunk-server.com:514 -a app_name
그런 다음 splunk 서버에 로그인하여 원하는 수의 로그를 검색하십시오. Splunk를 사용하고 있으며 완벽하게 작동합니다.
두 번째 옵션 -다음과 같이 앱에 추가 기능을 구입할 수 있습니다. (이 옵션은 사용하지 않았지만 사용 가능한 옵션입니다).
- Timber.io
- 스모 로직
- LogEnteries
- 로그 DNA
- 페이퍼 트레일
아래 옵션을 살펴볼 수도 있습니다. 로그를 JSON 형식으로 만들려면 Splunk / ELK와 같은 외부 시스템으로 로그를 푸시하는 데 도움이되므로 검색하기가 쉬워집니다 (성능도 현명합니다). JSON으로.
https://github.com/goodeggs/heroku-log-normalizer
Readme.md가 없지만 https://github.com/goodeggs/bites/issues/20에 대한 설명이 있습니다.
마지막으로
그리고 이미 다른 사용자가 언급 한대로 항상 아래 명령을 사용할 수 있습니다.
다음 명령은 heroku에서 생성 로그를 마무리합니다.
heroku logs -t -a <app_name>
다음 comand은 heroku 의 1000 줄의 로그를 보여줍니다.
heroku logs -n 1000 -a <app_name>
1500 줄의 최신 로그 만 사용할 수 있으며 나머지는 heroku dyno에서 삭제됩니다.
삼나무 스택은 다음을 참조하십시오.
https://devcenter.heroku.com/articles/oneoff-admin-ps
당신은 실행해야합니다 :
heroku run bash ...
참고 URL : https://stackoverflow.com/questions/2671454/heroku-how-to-see-all-the-logs
'development' 카테고리의 다른 글
.NET에서 콘솔 응용 프로그램의 종료 코드를 어떻게 지정합니까? (0) | 2020.02.16 |
---|---|
Array.prototype.slice.call ()은 어떻게 작동합니까? (0) | 2020.02.16 |
비트 맵을 위치에 저장 (0) | 2020.02.16 |
JavaScript 배열 정보를 CSV로 내보내는 방법 (클라이언트 측)? (0) | 2020.02.16 |
페이지의 관련 구성 데이터가 유효하지 않으므로 요청한 페이지에 액세스 할 수 없습니다. (0) | 2020.02.16 |