Merge pull request #482 from google/revert-19-master
Revert "Added fixed log name support"
This commit is contained in:
commit
e0a2521e3d
@ -330,9 +330,6 @@ typedef unsigned __int64 uint64;
|
|||||||
using fLS::FLAGS_##name
|
using fLS::FLAGS_##name
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Set whether appending a timestamp to the log file name
|
|
||||||
DECLARE_bool(timestamp_in_logfile_name);
|
|
||||||
|
|
||||||
// Set whether log messages go to stderr instead of logfiles
|
// Set whether log messages go to stderr instead of logfiles
|
||||||
DECLARE_bool(logtostderr);
|
DECLARE_bool(logtostderr);
|
||||||
|
|
||||||
|
|||||||
@ -109,9 +109,6 @@ static bool BoolFromEnv(const char *varname, bool defval) {
|
|||||||
return memchr("tTyY1\0", valstr[0], 6) != NULL;
|
return memchr("tTyY1\0", valstr[0], 6) != NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
GLOG_DEFINE_bool(timestamp_in_logfile_name,
|
|
||||||
BoolFromEnv("GOOGLE_TIMESTAMP_IN_LOGFILE_NAME", true),
|
|
||||||
"put a timestamp at the end of the log file name");
|
|
||||||
GLOG_DEFINE_bool(logtostderr, BoolFromEnv("GOOGLE_LOGTOSTDERR", false),
|
GLOG_DEFINE_bool(logtostderr, BoolFromEnv("GOOGLE_LOGTOSTDERR", false),
|
||||||
"log messages go to stderr instead of logfiles");
|
"log messages go to stderr instead of logfiles");
|
||||||
GLOG_DEFINE_bool(alsologtostderr, BoolFromEnv("GOOGLE_ALSOLOGTOSTDERR", false),
|
GLOG_DEFINE_bool(alsologtostderr, BoolFromEnv("GOOGLE_ALSOLOGTOSTDERR", false),
|
||||||
@ -452,7 +449,7 @@ class LogFileObject : public base::Logger {
|
|||||||
int64 next_flush_time_; // cycle count at which to flush log
|
int64 next_flush_time_; // cycle count at which to flush log
|
||||||
|
|
||||||
// Actually create a logfile using the value of base_filename_ and the
|
// Actually create a logfile using the value of base_filename_ and the
|
||||||
// optional argument time_pid_string
|
// supplied argument time_pid_string
|
||||||
// REQUIRES: lock_ is held
|
// REQUIRES: lock_ is held
|
||||||
bool CreateLogfile(const string& time_pid_string);
|
bool CreateLogfile(const string& time_pid_string);
|
||||||
};
|
};
|
||||||
@ -995,54 +992,20 @@ void LogFileObject::FlushUnlocked(){
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool LogFileObject::CreateLogfile(const string& time_pid_string) {
|
bool LogFileObject::CreateLogfile(const string& time_pid_string) {
|
||||||
string string_filename = base_filename_+filename_extension_;
|
string string_filename = base_filename_+filename_extension_+
|
||||||
if (FLAGS_timestamp_in_logfile_name) {
|
time_pid_string;
|
||||||
string_filename += time_pid_string;
|
|
||||||
}
|
|
||||||
const char* filename = string_filename.c_str();
|
const char* filename = string_filename.c_str();
|
||||||
|
int fd = open(filename, O_WRONLY | O_CREAT | O_EXCL, FLAGS_logfile_mode);
|
||||||
//only write to files, create if non-existant.
|
|
||||||
int flags = O_WRONLY | O_CREAT;
|
|
||||||
if (FLAGS_timestamp_in_logfile_name) {
|
|
||||||
//demand that the file is unique for our timestamp (fail if it exists).
|
|
||||||
flags = flags | O_EXCL;
|
|
||||||
}
|
|
||||||
int fd = open(filename, flags, FLAGS_logfile_mode);
|
|
||||||
|
|
||||||
if (fd == -1) return false;
|
if (fd == -1) return false;
|
||||||
#ifdef HAVE_FCNTL
|
#ifdef HAVE_FCNTL
|
||||||
// Mark the file close-on-exec. We don't really care if this fails
|
// Mark the file close-on-exec. We don't really care if this fails
|
||||||
fcntl(fd, F_SETFD, FD_CLOEXEC);
|
fcntl(fd, F_SETFD, FD_CLOEXEC);
|
||||||
|
|
||||||
// Mark the file as exclusive write access to avoid two clients logging to the
|
|
||||||
// same file. This applies particularly when !FLAGS_timestamp_in_logfile_name
|
|
||||||
// (otherwise open would fail because the O_EXCL flag on similar filename).
|
|
||||||
// locks are released on unlock or close() automatically, only after log is
|
|
||||||
// released.
|
|
||||||
// This will work after a fork as it is not inherited (not stored in the fd).
|
|
||||||
// Lock will not be lost because the file is opened with exclusive lock (write)
|
|
||||||
// and we will never read from it inside the process.
|
|
||||||
static struct flock w_lock;
|
|
||||||
|
|
||||||
w_lock.l_type = F_WRLCK;
|
|
||||||
w_lock.l_start = 0;
|
|
||||||
w_lock.l_whence = SEEK_SET;
|
|
||||||
w_lock.l_len = 0;
|
|
||||||
|
|
||||||
int wlock_ret = fcntl(fd, F_SETLK, &w_lock);
|
|
||||||
if (wlock_ret == -1) {
|
|
||||||
close(fd); //as we are failing already, do not check errors here
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//fdopen in append mode so if the file exists it will fseek to the end
|
|
||||||
file_ = fdopen(fd, "a"); // Make a FILE*.
|
file_ = fdopen(fd, "a"); // Make a FILE*.
|
||||||
if (file_ == NULL) { // Man, we're screwed!
|
if (file_ == NULL) { // Man, we're screwed!
|
||||||
close(fd);
|
close(fd);
|
||||||
if (FLAGS_timestamp_in_logfile_name) {
|
unlink(filename); // Erase the half-baked evidence: an unusable log file
|
||||||
unlink(filename); // Erase the half-baked evidence: an unusable log file, only if we just created it.
|
|
||||||
}
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -40,11 +40,9 @@
|
|||||||
#ifdef HAVE_UNISTD_H
|
#ifdef HAVE_UNISTD_H
|
||||||
# include <unistd.h>
|
# include <unistd.h>
|
||||||
#endif
|
#endif
|
||||||
#include <sys/wait.h>
|
|
||||||
|
|
||||||
#include <iomanip>
|
#include <iomanip>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <fstream>
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
@ -105,8 +103,6 @@ static void TestCHECK();
|
|||||||
static void TestDCHECK();
|
static void TestDCHECK();
|
||||||
static void TestSTREQ();
|
static void TestSTREQ();
|
||||||
static void TestBasename();
|
static void TestBasename();
|
||||||
static void TestBasenameAppendWhenNoTimestamp();
|
|
||||||
static void TestTwoProcessesWrite();
|
|
||||||
static void TestSymlink();
|
static void TestSymlink();
|
||||||
static void TestExtension();
|
static void TestExtension();
|
||||||
static void TestWrapper();
|
static void TestWrapper();
|
||||||
@ -180,7 +176,6 @@ BENCHMARK(BM_vlog);
|
|||||||
|
|
||||||
int main(int argc, char **argv) {
|
int main(int argc, char **argv) {
|
||||||
FLAGS_colorlogtostderr = false;
|
FLAGS_colorlogtostderr = false;
|
||||||
FLAGS_timestamp_in_logfile_name = true;
|
|
||||||
#ifdef HAVE_LIB_GFLAGS
|
#ifdef HAVE_LIB_GFLAGS
|
||||||
ParseCommandLineFlags(&argc, &argv, true);
|
ParseCommandLineFlags(&argc, &argv, true);
|
||||||
#endif
|
#endif
|
||||||
@ -232,8 +227,6 @@ int main(int argc, char **argv) {
|
|||||||
FLAGS_logtostderr = false;
|
FLAGS_logtostderr = false;
|
||||||
|
|
||||||
TestBasename();
|
TestBasename();
|
||||||
TestBasenameAppendWhenNoTimestamp();
|
|
||||||
TestTwoProcessesWrite();
|
|
||||||
TestSymlink();
|
TestSymlink();
|
||||||
TestExtension();
|
TestExtension();
|
||||||
TestWrapper();
|
TestWrapper();
|
||||||
@ -673,8 +666,7 @@ static void DeleteFiles(const string& pattern) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//check string is in file (or is *NOT*, depending on optional checkInFileOrNot)
|
static void CheckFile(const string& name, const string& expected_string) {
|
||||||
static void CheckFile(const string& name, const string& expected_string, const bool checkInFileOrNot = true) {
|
|
||||||
vector<string> files;
|
vector<string> files;
|
||||||
GetFiles(name + "*", &files);
|
GetFiles(name + "*", &files);
|
||||||
CHECK_EQ(files.size(), 1UL);
|
CHECK_EQ(files.size(), 1UL);
|
||||||
@ -683,16 +675,13 @@ static void CheckFile(const string& name, const string& expected_string, const b
|
|||||||
CHECK(file != NULL) << ": could not open " << files[0];
|
CHECK(file != NULL) << ": could not open " << files[0];
|
||||||
char buf[1000];
|
char buf[1000];
|
||||||
while (fgets(buf, sizeof(buf), file) != NULL) {
|
while (fgets(buf, sizeof(buf), file) != NULL) {
|
||||||
char* first = strstr(buf, expected_string.c_str());
|
if (strstr(buf, expected_string.c_str()) != NULL) {
|
||||||
//if first == NULL, not found.
|
|
||||||
//Terser than if (checkInFileOrNot && first != NULL || !check...
|
|
||||||
if (checkInFileOrNot != (first == NULL)) {
|
|
||||||
fclose(file);
|
fclose(file);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fclose(file);
|
fclose(file);
|
||||||
LOG(FATAL) << "Did " << (checkInFileOrNot? "" : "not ") << " find " << expected_string << " in " << files[0];
|
LOG(FATAL) << "Did not find " << expected_string << " in " << files[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TestBasename() {
|
static void TestBasename() {
|
||||||
@ -711,60 +700,6 @@ static void TestBasename() {
|
|||||||
DeleteFiles(dest + "*");
|
DeleteFiles(dest + "*");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TestBasenameAppendWhenNoTimestamp() {
|
|
||||||
fprintf(stderr, "==== Test setting log file basename without timestamp and appending properly\n");
|
|
||||||
const string dest = FLAGS_test_tmpdir + "/logging_test_basename_append_when_no_timestamp";
|
|
||||||
DeleteFiles(dest + "*");
|
|
||||||
|
|
||||||
ofstream out(dest.c_str());
|
|
||||||
out << "test preexisting content" << endl;
|
|
||||||
out.close();
|
|
||||||
|
|
||||||
FLAGS_timestamp_in_logfile_name=false;
|
|
||||||
SetLogDestination(GLOG_INFO, dest.c_str());
|
|
||||||
LOG(INFO) << "message to new base, appending to preexisting file";
|
|
||||||
FlushLogFiles(GLOG_INFO);
|
|
||||||
FLAGS_timestamp_in_logfile_name=true;
|
|
||||||
|
|
||||||
//if the logging overwrites the file instead of appending it will fail.
|
|
||||||
CheckFile(dest, "test preexisting content");
|
|
||||||
CheckFile(dest, "message to new base, appending to preexisting file");
|
|
||||||
|
|
||||||
// Release file handle for the destination file to unlock the file in Windows.
|
|
||||||
LogToStderr();
|
|
||||||
DeleteFiles(dest + "*");
|
|
||||||
}
|
|
||||||
|
|
||||||
static void TestTwoProcessesWrite() {
|
|
||||||
fprintf(stderr, "==== Test setting log file basename and two processes writing - second should fail\n");
|
|
||||||
const string dest = FLAGS_test_tmpdir + "/logging_test_basename_two_processes_writing";
|
|
||||||
DeleteFiles(dest + "*");
|
|
||||||
|
|
||||||
//make both processes write into the same file (easier test)
|
|
||||||
FLAGS_timestamp_in_logfile_name=false;
|
|
||||||
SetLogDestination(GLOG_INFO, dest.c_str());
|
|
||||||
LOG(INFO) << "message to new base, parent";
|
|
||||||
FlushLogFiles(GLOG_INFO);
|
|
||||||
|
|
||||||
pid_t pid = fork();
|
|
||||||
CHECK_ERR(pid);
|
|
||||||
if (pid == 0) {
|
|
||||||
LOG(INFO) << "message to new base, child - should only appear on STDERR not on the file";
|
|
||||||
ShutdownGoogleLogging(); //for children proc
|
|
||||||
exit(0);
|
|
||||||
} else if (pid > 0) {
|
|
||||||
wait(NULL);
|
|
||||||
}
|
|
||||||
FLAGS_timestamp_in_logfile_name=true;
|
|
||||||
|
|
||||||
CheckFile(dest, "message to new base, parent");
|
|
||||||
CheckFile(dest, "message to new base, child - should only appear on STDERR not on the file", false);
|
|
||||||
|
|
||||||
// Release
|
|
||||||
LogToStderr();
|
|
||||||
DeleteFiles(dest + "*");
|
|
||||||
}
|
|
||||||
|
|
||||||
static void TestSymlink() {
|
static void TestSymlink() {
|
||||||
#ifndef OS_WINDOWS
|
#ifndef OS_WINDOWS
|
||||||
fprintf(stderr, "==== Test setting log file symlink\n");
|
fprintf(stderr, "==== Test setting log file symlink\n");
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user