데몬 프로그램에서 stdout 리다이렉션

익명 사용자의 이미지

아래와 같이 데몬 프로세스로 만들고, 이후 stdout을 리다이렉션하여
printf 문장으로 로그를 찍고자 합니다.
그런데 생각처럼 안되는군요.
데몬 프로세스를 만드는 루틴을 빼면 정상적으로 log.dat 파일에 로그가
생기나 다시 집어넣으면 로그를 찍지 못하는데 이유를 잘 모르겠네요.
많은 조언 부탁드립니다.

if(start_daemon() != 0) {
printf("can't start daemon\n");
exit(1);
}

/* close all open files.. */
for(nIdx=0; nIdx<10; nIdx++) close(nIdx);

/* open null file for 0.. */
nFd0 = open("./zero.dat", O_CREAT|O_RDWR, 0666);
nFd1 = open("./log.dat", O_CREAT|O_RDWR, 0666);

/* log message.. */
for(nIdx=0; nIdx<10; nIdx++) printf("This is test message..\n");

익명 사용자의 이미지

데몬으로 프로세스를 띄우려면 stdin/out 을 끊어버려야 합니다. 그래서
데몬에서는 stdin/out 입출력이 안되죠..

익명 사용자의 이미지


데몬 프로세스를 만드는 경우,

현 디렉토리를 모 디렉토리로 (/) 이동하기에 파일을 만들때

./filename을 주어 open 하면 안되는것 같습니다.

말씀하신대로 데몬 프로세스 만드는 루틴에서 열려있는 모든 file
descriptor를 닫았고,

그외에도 만약을 대비해서 다시 10번까지 닫았습니다.

그리고 나서 파일의 전체 경로 명을 써주니 로그가 쌓이는 군요.

그럼 좋은 하루 되세요.

p.s. 대답 감사합니다.

익명 사용자의 이미지

file descriptor는 1부터 close하는게 좋습니다.

mysqlclient등의 라이브러리를 호출해서 사용하는 경우
문제가 생깁니다.

오래돼서 왜 그런지는 다시 차근차근 생각해봐야 될거 같은데
일반적인 유닉스 데몬 프로그래밍 하는 거랑 차이가 있는 부분이
여깁니다.

그냥 참조하세요

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.