버그 관련 로그 남기는 이상적인 방법

paeksj98의 이미지

안녕하세요.
요즘 이래저래 해봤는데 딱히 좋은 방법이 없어서 질문드립니다.

우선 구현하고자 하는 목표는 타겟 보드에서 어플이 실행되는 동안에 nand에 파일을 하나 오픈해서 어플에 실시간 행동들을 파일에 저장하려고 합니다.
1. 어플이 실행되면 파일 오픈
2. 어플이 실행되는 동안 오픈된 파일에 로그 내용들을 차곡차곡 저장.
3. 파일 close 방법
3-1. 전원 버튼이 눌리면 바로 close 및 전원 차단.
3-2. 배터리 전원이 일정 전압 이하이면 close.
==>여기까지는 생각한데로 돌아가는데.
3-3. 어플이 중간에 뻣는 경우 (이경우는 콘솔 어플을 하나 돌려서 메인 어플이 죽으면 자동으로 다시 구동되도록 구현)
예기치 않은 오류로 어플이 죽는 경우 파일 클로즈를 못해서 이파일은 정상저장이 안되는 문제.
로그가 가장 필요한 이유는 예기치 않은 에러 사황에 대한 내용 저장입니다.

생각하는 대안.
1. 파일을 write 전 open, write 후 close (생각되는 문제(?) wirte 한번하는데 매번 open close를 하는게 매우 비효율적으로 느껴짐....
==> 매번 open close를 하는게 좋은 방법인가요..??
2. 어플이 죽었다 살아날경우 이전에 open해놓은 파일의 핸들을 가져올수 있는 방법이 있나요??(없을것 같음...)
==> 만약 가능하다면 어플이 죽었다 살아날때 파일 핸들을 가져다가 클로즈 하고 다시 open 해서 시작.

저와 같은 고민을 하신다면 어떤 방식으로 하는걸 추천하시나요...???
환경은 arm 보드에 linux 2.6 어플은 qt-3.3으로 작업 중입니다.

ktd2004의 이미지

그냥 fflush하시면 안될까요?

paeksj98의 이미지

file close를 안했는데 fflush만으로도 파일에 저장되는지 궁금합다.
지금 테스트를 해봐야겠네요.

익명 사용자의 이미지

콘솔어플에서 파일 작업하시면 안되나요?

paeksj98의 이미지

파일을 오픈해서 저장을 하는데 그걸 콘솔에서 대신한다는게 이해가 안가네요.
만약 메인 어플이 있고 메인 어플에서 보낸 로그를 콘솔에서 받아가지고 저장할수 있는 방법이 있나요.
키드라이버 값등을 메인 어플에서 받는데 이걸 콘솔에 보내서 자장되는(close) 시점을 잡을수 없을것 같은데.....
자세한 설명을 해주셨으면 좋았을텐데 콘솔이 이용하는건 써본적이 없어서 이해가 되질 않아서요.

aruee의 이미지

로그를 무조건 pipe로 보내버리고 다른 프로세스 상에서 파일로 저장해 보거나, 콘솔로 뿌리거나 했었습니다.

paeksj98의 이미지

어떻게 보내는지 알려주시면 안될까요.
pipe로 보내버린다고 하셨는데 그말이 어떻게 처리 해야되는건지는 이해가 안가서요..??

aruee의 이미지

named pipe를 미리 만들어서 이쪽으로만 한쪽은 쓰기만 하고 한쪽은 읽기만 하는거죠..

뷰어쪽은 대충 이렇게 썼었네요..

pre_mask = umask(0);
if (mknod(FIFO_FILE, S_IFIFO|0666, 0) == -1)
{
perror ("mknod failed\n");
}
umask(pre_mask);
fd = open(FIFO_FILE, O_RDONLY|O_NONBLOCK);
byte_read = read(fd,readbuf, 4096);
readbuf[byte_read] = '\0';
printf("%s", readbuf);

모듈쪽도 WRONLY|O_NONBLOCK 으로 주시고 write로 열심히 적으시면 될듯 합니다.
물론 문자열 만들땐 snprintf 같은걸로 만든 후 써야겠죠.. ( 이 부하는 어쩔 수 없는듯..)

사용이 가능하시다면 dlog 나 syslog를 사용하시는게 좋을것 같네요.

paeksj98의 이미지

전 fflush를 해도 close안하면 파일이 저장이 안되는 줄말 알았네요.

좋은 정보 감사합니다.

댓글 달기

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
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.