
Added new argument '-s' which takes additional argument composed of list of logfile identifiers. Logfiles listed with '-s' will be written on main memory instead of disk. In practice, the log file in question will be written in /dev/shm but corresponding symlink is added to log directory. In the case of name conflicts with log files and links, a differentiating sequence number is included in hte name of the file. This, however, is done only when existing file is not writable or is of different type (symlink <> file). Added new logfile LOGFILE_DEBUG whose contents will be largerly what was included up to date in trace log. Disabled feature which spreads writes to log files to others because of bug (#338) in the way block buffers are managed. Changed log manager parameters to match with the current implementation. List of arguments: "-h - help\n" "-a <debug prefix> ............(\"skygw_debug\")\n" "-b <debug suffix> ............(\".log\")\n" "-c <trace prefix> ............(\"skygw_trace\")\n" "-d <trace suffix> ............(\".log\")\n" "-e <message prefix> ............(\"skygw_msg\")\n" "-f <message suffix> ............(\".log\")\n" "-g <error prefix> ............(\"skygw_err\")\n" "-i <error suffix> ............(\".log\")\n" "-j <log path> ............(\"/tmp\")\n" "-s <shmem log file ids> ........(no default)\n"; dcb.c dcb_add_to_zombieslist, add dcb to the front of zombies list instead of inserting to the end of it. gateway.c Renamed shutdown_gateway to shutdown_server (Bug #131) Call skygw_logmanager_init so that trace and debug logs are written to shared memory. poll.c dcb.h Removed some dead code and references to unneeded mutexes. debugcmd.c Added enable/disable log command for debug log. skygw_utils.cc skygw_file_init now takes optional symlink name as a second argument. Symlink is created to point to the file being created.
75 lines
2.3 KiB
C
75 lines
2.3 KiB
C
/*
|
|
* This file is distributed as part of the SkySQL Gateway. It is free
|
|
* software: you can redistribute it and/or modify it under the terms of the
|
|
* GNU General Public License as published by the Free Software Foundation,
|
|
* version 2.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
* details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along with
|
|
* this program; if not, write to the Free Software Foundation, Inc., 51
|
|
* Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*
|
|
* Copyright SkySQL Ab 2013
|
|
*/
|
|
|
|
|
|
typedef struct filewriter_st filewriter_t;
|
|
typedef struct logfile_st logfile_t;
|
|
typedef struct fnames_conf_st fnames_conf_t;
|
|
typedef struct logmanager_st logmanager_t;
|
|
|
|
typedef enum {
|
|
LOGFILE_ERROR = 1,
|
|
LOGFILE_FIRST = LOGFILE_ERROR,
|
|
LOGFILE_MESSAGE = 2,
|
|
LOGFILE_TRACE = 4,
|
|
LOGFILE_DEBUG = 8,
|
|
LOGFILE_LAST = LOGFILE_DEBUG
|
|
} logfile_id_t;
|
|
|
|
|
|
typedef enum { FILEWRITER_INIT, FILEWRITER_RUN, FILEWRITER_DONE }
|
|
filewriter_state_t;
|
|
|
|
/**
|
|
* UNINIT means zeroed memory buffer allocated for the struct.
|
|
* INIT means that struct members may have values, and memory may
|
|
* have been allocated. Done function must check and free it.
|
|
* RUN Struct is valid for run-time checking.
|
|
* DONE means that possible memory allocations have been released.
|
|
*/
|
|
typedef enum { UNINIT = 0, INIT, RUN, DONE } flat_obj_state_t;
|
|
|
|
EXTERN_C_BLOCK_BEGIN
|
|
|
|
bool skygw_logmanager_init(int argc, char* argv[]);
|
|
void skygw_logmanager_done(void);
|
|
void skygw_logmanager_exit(void);
|
|
|
|
/**
|
|
* free private write buffer list
|
|
*/
|
|
void skygw_log_done(void);
|
|
int skygw_log_write(logfile_id_t id, char* format, ...);
|
|
int skygw_log_flush(logfile_id_t id);
|
|
int skygw_log_write_flush(logfile_id_t id, char* format, ...);
|
|
int skygw_log_enable(logfile_id_t id);
|
|
int skygw_log_disable(logfile_id_t id);
|
|
|
|
|
|
EXTERN_C_BLOCK_END
|
|
|
|
void writebuf_clear(void* data);
|
|
|
|
const char* get_trace_prefix_default(void);
|
|
const char* get_trace_suffix_default(void);
|
|
const char* get_msg_prefix_default(void);
|
|
const char* get_msg_suffix_default(void);
|
|
const char* get_err_prefix_default(void);
|
|
const char* get_err_suffix_default(void);
|
|
const char* get_logpath_default(void);
|