버그 관련 로그 남기는 이상적인 방법
안녕하세요.
요즘 이래저래 해봤는데 딱히 좋은 방법이 없어서 질문드립니다.
우선 구현하고자 하는 목표는 타겟 보드에서 어플이 실행되는 동안에 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으로 작업 중입니다.
그냥 fflush하시면 안될까요?
그냥 fflush하시면 안될까요?
fflush 가 가능한가요.
file close를 안했는데 fflush만으로도 파일에 저장되는지 궁금합다.
지금 테스트를 해봐야겠네요.
콘솔어플
콘솔어플에서 파일 작업하시면 안되나요?
메일 어플에서
파일을 오픈해서 저장을 하는데 그걸 콘솔에서 대신한다는게 이해가 안가네요.
만약 메인 어플이 있고 메인 어플에서 보낸 로그를 콘솔에서 받아가지고 저장할수 있는 방법이 있나요.
키드라이버 값등을 메인 어플에서 받는데 이걸 콘솔에 보내서 자장되는(close) 시점을 잡을수 없을것 같은데.....
자세한 설명을 해주셨으면 좋았을텐데 콘솔이 이용하는건 써본적이 없어서 이해가 되질 않아서요.
예전에 전...
로그를 무조건 pipe로 보내버리고 다른 프로세스 상에서 파일로 저장해 보거나, 콘솔로 뿌리거나 했었습니다.
pipe로 보낸다고 하셨는데
어떻게 보내는지 알려주시면 안될까요.
pipe로 보내버린다고 하셨는데 그말이 어떻게 처리 해야되는건지는 이해가 안가서요..??
named pipe를 미리 만들어서 이쪽으로만 한쪽은
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를 사용하시는게 좋을것 같네요.
fflush 로 저장하니 원하는 대로 되네요.
전 fflush를 해도 close안하면 파일이 저장이 안되는 줄말 알았네요.
좋은 정보 감사합니다.
댓글 달기