Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- gradle
- DP
- 주키퍼
- 알고리즘
- leetcode
- 문제풀이
- 튜토리얼
- OOM
- programmers
- redis
- 파이썬
- docker
- zookeeper
- 자바
- dynamic programming
- codewars
- 코드워
- 동적프로그래밍
- go
- Java
- 프로그래머스
- 스칼라
- Go언어
- scala
- Python
- golang
- boj
- Linux
- 리눅스
- HBase
Archives
- Today
- Total
파이문
파이썬 백그라운드로 돌릴 때 로그 실시간 보기 본문
728x90
파이썬 프로그램을 백그라운드로 돌리는 방법은 다음과 같다.
$ python filename.py &
그러나 이 방법은 현재 창을 종료하면 terminate된다는 단점이 있다.
이를 위해 nohup 키워드를 사용할 수 있다.
$ nohup python filename.py &
해당 명령어를 입력하면 로그 파일로 nohup.out이라는 파일에 쌓이게 된다.
문제는 print 문으로 찍었던 내용이 바로 nohup.out에 쌓이는게 아니다.
즉 시작해서
$ tail -f nohup.out
명령어를 친다고 하더라도 바로 print문으로 했던 것이 화면에 나오는 것이 아니라는 것이다.
어느 정도 쌓였다가, 한 꺼번에 출력하곤 하는데 로그를 보고 싶다면 이는 옳은 방법이 아니다.
만약 print문을 바로 바로 보고 싶다면 파이썬의 자체에 가지고 있는 옵션이 있다.
$ nohup python -u filename.py &
위 명령어를 해 주고
$ tail -f nohup.out
바로 print 문이 찍히는 것을 볼 수 있다.
리다이렉트 옵션을 써서 애초에 nohup.out이라는 파일 자체가 안나오게 할 수도 있고 파일 명도 바꿀 수 있지만
역시 가장 좋은 방법은 logging 모듈을 그냥 갖다 쓰는 것인 것 같다.
Comments