답변:
업데이트 (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 logs -n 1500
하면 Cedar에서 사용할 수있는 가장 좋은 방법입니다. 당신이 그 이상 선이 필요하면, 당신은 시스템 로그 드레인이 필요합니다 devcenter.heroku.com/articles/logging#syslog_drains
heroku run rails c
입니다. 업데이트!
heroku run cat log/production.log
합니까?
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 로깅을 따르십시오
귀하의 로그를 보려면
heroku logs
--num
(또는 -n
) 옵션.
heroku logs -n 200
heroku logs --tail
heroku logs --app your_app_name
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
/usr/bin/less: cannot execute binary files
무료 Papertrail 계획 과 같은 것을 앱 에 추가하는 것이 좋습니다 . 구성이 필요 없으며 최대 10MB / 일의 7 일 분량의 로깅 데이터를 얻을 수 있으며 2 일의 로그를 다시 검색 할 수 있습니다.
모든 로그를 보려면 로그 유출을 구현해야하며 로그를 비워야합니다 (모든 기록 로그 관리).
heroku drains:add syslog+tls://splunk-server.com:514 -a app_name
그런 다음 splunk 서버에 로그인하여 원하는 수의 로그를 검색하십시오. Splunk를 사용하고 있으며 완벽하게 작동합니다.
두 번째 옵션 -다음과 같이 앱에 추가 기능을 구입할 수 있습니다. (이 옵션은 사용하지 않았지만 사용 가능한 옵션입니다).
아래 옵션을 살펴볼 수도 있습니다. 로그를 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에서 삭제됩니다.
나는 애드온을 사용하고 Logentries를 사용하는 것이 좋습니다. 이를 사용하려면 명령 행에서 실행하십시오.
heroku addons:create logentries:le_tryit
(이 명령은 무료 계정에 대한 애드온을 생성하지만 원하는 경우 분명히 업그레이드 할 수 있습니다)
Logentries를 사용하면 한 달에 최대 5GB의 로그 볼륨을 저장할 수 있습니다. 해당 정보는 지난 7 일 이내에 명령 검색으로 검색 할 수 있으며 실시간 알림이 있습니다.
따라서이 애드온을 사용하여 Heroku가 기본적으로 저장하는 1500 줄에 도달 할 때 로그가 더 이상 손실되지 않도록하십시오. 도움이 되었기를 바랍니다! 좋은 하루 되세요!
삼나무 스택은 다음을 참조하십시오.
https://devcenter.heroku.com/articles/oneoff-admin-ps
당신은 실행해야합니다 :
heroku run bash ...
heroku run bash
에서 새로운 dyno를 가동하여 bash
명령 을 호스팅합니다 . 해당 dyno의 파일 시스템에는 'active'웹 dyno의 로그 파일이 포함되어 있지 않으므로이 방법은 작동하지 않습니다.