[유닉스] system 함수를 통한 tar 수행 실패 결과
안녕하세요
예전에는 잘 됐었는데, 어느 순간부터 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이 아닌데..압축은 정상적으로 되어있습니다.ㅠㅠ
압축을 풀어봐도..제대로 잘 압축이 된것 같구요..
어느 시점부터 이런 문제가 지속되고 있습니다
조언 주세요
버퍼에 스트링이
버퍼에 스트링이 쌓여서 그런것같군요.
파일 갯수가 아주적을 경우는 아마 에러가 안날겁니다. ^^;
tar에서 v옵션을 빼거나 std (out|err)에 쌓이는 메시지들을 계속 읽어내서 버퍼를 비우거나 해야할 듯합니다.
-----
오늘 나의 취미는 끝없는, 끝없는 인내다. 1973 法頂
-----
오늘 나의 취미는 끝없는, 끝없는 인내다. 1973 法頂
답변 감사합니다
말씀하신 내용을 정확히 이해하지 못하여 다시 질문드립니다.
버퍼라고 말씀하신 것이 tar에서 사용하는 버퍼를 말씀하시는건지요??
지금의 경우 파일을 압축은 하나의 파일만 진행되고 있습니다
하루에 한 개씩...
좀 더 자세한 설명 부탁드립니다
좋은 하루되세요^^
콘솔에서 프로그램을
콘솔에서 프로그램을 실행했을때 stdout, stderr로 메시지가 출력될겁니다.
system류의 함수를 실행시키면 그 메시지들이 버퍼에 쌓이게 된다는 말입니다.
버퍼크기보다 많은 메시지가 출력되면 문제가 될 수도 있고요.
파일 1개라면 문제가 안될거같은데... 그래도 한번 확인은 해보세요. 버퍼가 비정상적으로 작게 잡혔을지도 모르겠네요.
-----
오늘 나의 취미는 끝없는, 끝없는 인내다. 1973 法頂
-----
오늘 나의 취미는 끝없는, 끝없는 인내다. 1973 法頂
댓글 달기