[유닉스] system 함수를 통한 tar 수행 실패 결과

0
points

안녕하세요

예전에는 잘 됐었는데, 어느 순간부터 tar를 수행하는 시스템 결과가 이상합니다.

코드는 아래와 같습니다.

sprintf( system_command, "cd %s ; /usr/local/bin/tar cvfz %s.tgz %s.log ", gLogInfo.sIPLogPath, dayfile, dayfile );

result = system( system_command );
printf("%s\n", system_command );

if( result != 0 ) {
printf( "[LDR_t] ZipNasFile> WARN.. Zip file fail %s\n", strerror(errno));
bNasZipResult = CN_FALSE;
}
else {
bNasZipResult = CN_TRUE;
}

제가 알고 있기로는 system 함수가 실패하면 -1이고
성공이면 system 함수에서 수행하는 명령어의 수행 결과 값이 리턴된다고 알 고 있습니다.

그래서 tgz 파일로 정상으로 묶이면 0이 리턴되고, 예를 들어 압축하려는 파일이 없으면 512와 같은 값이 리턴되는 걸로 알고있습니다.

그런데..문제는 system 결과가 0이 아닌데..압축은 정상적으로 되어있습니다.ㅠㅠ
압축을 풀어봐도..제대로 잘 압축이 된것 같구요..

어느 시점부터 이런 문제가 지속되고 있습니다

조언 주세요

M.W.Park의 이미지
7173
points

버퍼에 스트링이

1
point

버퍼에 스트링이 쌓여서 그런것같군요.
파일 갯수가 아주적을 경우는 아마 에러가 안날겁니다. ^^;
tar에서 v옵션을 빼거나 std (out|err)에 쌓이는 메시지들을 계속 읽어내서 버퍼를 비우거나 해야할 듯합니다.

-----
오늘 의 취미는 끝없는, 끝없는 인내다. 1973 法頂

답변 감사합니다

0
points

말씀하신 내용을 정확히 이해하지 못하여 다시 질문드립니다.
버퍼라고 말씀하신 것이 tar에서 사용하는 버퍼를 말씀하시는건지요??
지금의 경우 파일을 압축은 하나의 파일만 진행되고 있습니다
하루에 한 개씩...

좀 더 자세한 설명 부탁드립니다

좋은 하루되세요^^

M.W.Park의 이미지
7173
points

콘솔에서 프로그램을

0
points

콘솔에서 프로그램을 실행했을때 stdout, stderr로 메시지가 출력될겁니다.
system류의 함수를 실행시키면 그 메시지들이 버퍼에 쌓이게 된다는 말입니다.
버퍼크기보다 많은 메시지가 출력되면 문제가 될 수도 있고요.
파일 1개라면 문제가 안될거같은데... 그래도 한번 확인은 해보세요. 버퍼가 비정상적으로 작게 잡혔을지도 모르겠네요.

-----
오늘 의 취미는 끝없는, 끝없는 인내다. 1973 法頂

댓글 보기 옵션

원하시는 댓글 전시 방법을 선택한 다음 "설정 저장"을 누르셔서 적용하십시오.