Alachisoft.NCache.Common.Logger.JLogger Maven / Gradle / Ivy
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package Alachisoft.NCache.Common.Logger;
import Alachisoft.NCache.Common.*;
import Alachisoft.NCache.Common.Enum.EventType;
import java.io.File;
import java.io.FilenameFilter;
import java.io.IOException;
import java.io.PrintStream;
import java.lang.management.ManagementFactory;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.logging.FileHandler;
import java.util.logging.Handler;
import java.util.logging.Level;
import java.util.logging.Logger;
public class JLogger implements ILogger {
private static final String DIRNAME = ServicePropValues.LOGS_FOLDER;
private static String s_configDir = "";
private static int bufferDefaultSize = 1;
private static String _nodeIP = "";
static {
s_configDir = Common.getConfigPath();
try {
String strHostName = InetAddress.getLocalHost().getHostName();
InetAddress addr = InetAddress.getByName(strHostName);
_nodeIP = addr.getHostAddress();
} catch (Exception ex) {
}
try {
s_configDir = new File(s_configDir, DIRNAME).getPath();
} catch (java.lang.Exception e) {
}
}
private final String NEW_LINE = "\r\n";
private Logger logger;
private String _path = "";
private String _loggerName = null;
/**
* File size limit of log files.
*/
private int _limit = 5000000; // 5 Mb;
/**
* Number of max log files that can be written. Currently set to 1000 increasing it any further is causing extreme delays in reply as Filehandler is calling new File() doing
* some IO. In short logging needs to be reviewed particularly configurelogger() .
*/
private int _numLogFiles = 1000;
private String _logFileNamePattern = "log";
private boolean _append = true;
public int getLimit() {
return this._limit;
}
public void setLimit(int limit) {
this._limit = limit;
}
public int getNumLogFiles() {
return this._numLogFiles;
}
public void setNumLogFiles(int count) {
this._numLogFiles = count;
}
public String getLogFileNamePattern() {
return this._logFileNamePattern;
}
public void setLogFileNamePattern(String pattern) {
this._logFileNamePattern = pattern;
}
public boolean getAppend() {
return this._append;
}
public void setAppend(boolean append) {
this._append = append;
}
@Override
public String Initialize(java.util.Map properties, String partitionID, String cacheName) throws Exception {
return Initialize(properties, partitionID, cacheName, false, false);
}
@Override
public final String Initialize(java.util.Map properties, String partitionID, String cacheName, boolean isStartedAsMirror, boolean inproc) throws Exception {
if (this.logger != null) {
throw new Exception("Multiple Initialize calls for same logger");
}
if (_loggerName != null) {
return _loggerName;
}
try {
_loggerName = cacheName;
if (partitionID != null && partitionID.length() > 0) {
_loggerName += "-" + partitionID;
}
if (isStartedAsMirror) {
_loggerName += "-" + "replica";
}
if (inproc && !isStartedAsMirror) {
_loggerName += "." + ManagementFactory.getRuntimeMXBean().getName();
}
String LogExceptions = "";
if (_loggerName.equals("LogExceptions")) {
LogExceptions = "/LogExceptions";
}
DateFormat dateFormat = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
Date date = new Date();
String currTime = dateFormat.format(date).replace('/', '-').replace(':', '-').replace(' ', '-');
boolean defaultPath = true;
String initialPath = "";
if (properties != null) {
if (properties.containsKey("log-path")) {
initialPath = (String) (properties.get("log-path"));
if (!initialPath.equals(""))
defaultPath = !isValidLocation(initialPath, cacheName);
}
}
if (defaultPath)
initialPath = GetLogPath();
String fileName = initialPath + LogExceptions + "/" + _loggerName + "_" + currTime + "_" + _nodeIP + "_%g.txt";
//
//append should b true
PrintStream out = new PrintStream(fileName.replace("%g", "0"));
out.print(String.format("%-28s", "TIMESTAMP") +
String.format("%-45s", "LOGGERNAME") +
String.format("%-35s", "THREAD-ID") +
String.format("%-20s", "LEVEL") +
"MESSAGE\r\n");
out.close();
this.ConfigureLogger(fileName);
if (properties != null) {
if (properties.containsKey("trace-errors")) {
if (Boolean.parseBoolean(properties.get("trace-errors").toString())) {
this.SetLevel(JLevel.Error);
}
}
if (properties.containsKey("trace-notices")) {
if (Boolean.parseBoolean(properties.get("trace-notices").toString())) {
this.SetLevel(JLevel.INFO);
}
}
if (properties.containsKey("trace-warnings")) {
if (Boolean.parseBoolean(properties.get("trace-warnings").toString())) {
this.SetLevel(JLevel.WARNING);
}
}
if (properties.containsKey("trace-debug")) {
if (Boolean.parseBoolean(properties.get("trace-debug").toString())) {
this.SetLevel(JLevel.ALL);
}
}
if (properties.containsKey("enabled")) {
if (!Boolean.parseBoolean(properties.get("trace-errors").toString())) {
this.SetLevel(JLevel.OFF);
}
}
} else {
this.SetLevel(JLevel.WARNING);
}
} catch (Exception e) {
}
return _loggerName;
}
public final void Initialize(LoggerNames loggerNameEnum, boolean isEventLogs) throws Exception {
if (logger != null) {
throw new Exception("Multiple Initialize calls for same logger");
}
_loggerName = loggerNameEnum.toString();
String filepath = "";
tangible.RefObject tempRef_filepath = new tangible.RefObject(filepath);
boolean tempVar = !DirectoryUtil.SearchGlobalDirectory(ServicePropValues.LOGS_FOLDER, false, tempRef_filepath);
filepath = tempRef_filepath.argvalue;
if (tempVar) {
try {
tangible.RefObject tempRef_filepath2 = new tangible.RefObject(filepath);
DirectoryUtil.SearchLocalDirectory(ServicePropValues.LOGS_FOLDER, true, tempRef_filepath2);
filepath = tempRef_filepath2.argvalue;
} catch (Exception ex) {
throw new Exception("Unable to initialize the log file", ex);
}
}
try {
filepath = Common.combinePath(filepath, loggerNameEnum.toString().toLowerCase());
if (!(new java.io.File(filepath)).isDirectory()) {
(new java.io.File(filepath)).mkdir();
}
filepath = Common.combinePath(filepath, loggerNameEnum.toString().toLowerCase());
this.ConfigureLogger(filepath);
} catch (Exception e) {
throw e;
}
}
@Override
public final void Initialize(LoggerNames loggerName) throws Exception {
if (loggerName != LoggerNames.Licence) {
Initialize(loggerName, null);
}
}
@Override
public final void Initialize(LoggerNames loggerNameEnum, String cacheName) throws Exception {
if (logger != null) {
throw new Exception("Multiple Initialize calls for same logger");
}
if(cacheName == null)
cacheName = "";
String filename = "";
_loggerName = loggerNameEnum.toString();
if (loggerNameEnum != LoggerNames.ClientLogs) {
filename = cacheName;
} else {
filename = _loggerName.toLowerCase() + "." + cacheName + "." + ProcessHandle.current().pid();
_loggerName = cacheName + ProcessHandle.current().pid() + new java.util.Date();
}
String localMachine = null;
try {
localMachine = InetAddress.getLocalHost().getHostAddress().trim();
} catch (UnknownHostException unknownHostException) {
throw new Exception(unknownHostException.toString());
}
DateFormat format = new SimpleDateFormat("dd-MM-yy_HH-mm-ss");
if(filename.isEmpty())
filename = loggerNameEnum==LoggerNames.LoaderService?
format.format(new Date()) + "_" + localMachine + "_" + "java" +"_%g"+ ".txt":
format.format(new Date()) + "_" + localMachine +"_%g"+ ".txt";
else
filename = loggerNameEnum==LoggerNames.LoaderService?
filename + "." + format.format(new Date()) + "_" + localMachine + "_" + "java" +"_%g"+ ".txt":
filename + "." + format.format(new Date()) + "_" + localMachine +"_%g"+ ".txt";
String filepath = "";
tangible.RefObject tempRef_filepath = new tangible.RefObject(filepath);
boolean tempVar = DirectoryUtil.SearchGlobalDirectory(ServicePropValues.LOGS_FOLDER, false, tempRef_filepath);
filepath = tempRef_filepath.argvalue;
if (!tempVar) {
try {
tangible.RefObject tempRef_filepath2 = new tangible.RefObject(filepath);
DirectoryUtil.SearchLocalDirectory(ServicePropValues.LOGS_FOLDER, true, tempRef_filepath2);
filepath = tempRef_filepath2.argvalue;
} catch (Exception ex) {
throw new Exception("Unable to initialize the log file", ex);
}
}
try {
filepath = Common.combinePath(filepath, loggerNameEnum.toString());
if (!(new java.io.File(filepath)).isDirectory()) {
(new java.io.File(filepath)).mkdir();
}
if(loggerNameEnum == LoggerNames.LoaderService)
configureLoggerForLoader(filepath, filename);
else
{
filepath = Common.combinePath(filepath, filename);
this.ConfigureLogger(filepath);
//append should b true
writeHeader(filepath);
}
} catch (Exception e) {
throw e;
}
}
private void writeHeader(String filepath) throws IOException{
PrintStream out = new PrintStream(filepath.replace("%g", "0"));
out.print(String.format("%-28s", "TIMESTAMP") +
String.format("%-45s", "LOGGERNAME") +
String.format("%-35s", "THREAD-ID") +
String.format("%-20s", "LEVEL") +
"MESSAGE\r\n");
out.close();
}
private void configureLoggerForLoader(String filepath , String filename) throws IOException {
File dir = new File(filepath);
File[] matches = dir.listFiles(new FilenameFilter()
{
public boolean accept(File dir, String name)
{
return name.startsWith(_loggerName) && name.endsWith("_0.txt");
}
});
if(matches.length == 0){
filename = _loggerName + "." + filename;
filepath = Common.combinePath(filepath, filename);
this.setNumLogFiles(1);
this.ConfigureLogger(filepath);
//append should b true
writeHeader(filepath);
}
else{
filepath = matches[0].getPath();
this.setNumLogFiles(1);
this.ConfigureLogger(filepath);
}
}
private void ConfigureLogger(String filePath) throws IOException {
this.logger = Logger.getLogger(_loggerName);
this.logger.setUseParentHandlers(false);
this.setLogFileNamePattern(filePath);
FileHandler fh = new FileHandler(this.getLogFileNamePattern(), this.getLimit(), this.getNumLogFiles(), this.getAppend());
fh.setFormatter(new JFormatter());
this.logger.addHandler(fh);
}
/**
* Assigns the new level to the logger
*
* @param levelName ALL, DEBUG, INFO, ERROR, FATAL
*/
@Override
public final void SetLevel(String levelName) {
logger.setLevel(JLevel.parse(levelName));
}
public final void SetLevel(Level level) {
logger.setLevel(level);
}
/**
* Use {@link #Error(java.lang.String, java.lang.String) }
*
* @param message
*/
@Override
public final void Error(String message) {
logger.log(JLevel.Error, message);
}
/**
* Use {@link #Fatal(java.lang.String, java.lang.String) }
*
* @param message
*/
@Override
public final void Fatal(String message) {
logger.log(JLevel.SEVERE, message);
}
/**
* Use {@link #CriticalInfo(java.lang.String, java.lang.String) }
*
* @param message
*/
@Override
public final void CriticalInfo(String message) {
logger.log(JLevel.CriticalInfo, message);
}
/**
* Use {@link #Info(java.lang.String, java.lang.String) }
*
* @param message
*/
@Override
public final void Info(String message) {
logger.info(message);
}
/**
* Use {@link #DevTrace(java.lang.String, java.lang.String) }
*
* @param message
*/
@Override
public final void Debug(String message) {
logger.fine((message));
}
/**
* Use {@link #Debug(java.lang.String, java.lang.String) }
*
* @param message
*/
@Override
public final void Warn(String message) {
logger.log(Level.WARNING, message);
}
@Override
public final boolean getIsInfoEnabled() {
return logger.isLoggable(JLevel.INFO);
}
/**
* @return
*/
@Override
public final boolean getIsErrorEnabled() {
return logger.isLoggable(JLevel.Error);
}
/**
* @return
*/
@Override
public final boolean getIsWarnEnabled() {
return logger.isLoggable(JLevel.WARNING);
}
/**
* @return
*/
@Override
public final boolean getIsDebugEnabled() {
return logger.isLoggable(Level.FINE);
}
/**
* @return
*/
@Override
public final boolean getIsFatalEnabled() {
return logger.isLoggable(Level.SEVERE);
}
public final String GetLogPath() {
if (_path.length() < 1) {
_path = s_configDir;
}
try {
//Basit: Not required
//log4net.LogManager.GetRepository().getLevelMap().Add(criticalInfo);
if (!(new java.io.File(_path)).isDirectory()) {
(new java.io.File(_path)).mkdir();
}
} catch (Exception e) {
//Basit: System Even Viewer not available
//AppUtil.LogEvent("NCache", e.toString(), System.Diagnostics.EventLogEntryType.Error, EventCategories.Error, EventID.GeneralError);
}
return _path;
}
public final boolean isValidLocation(String location, String cache) {
try {
Exception ex = new Exception("Invalid Directory Specified");
if (location.equals("")) {
throw ex;
}
if ((new File(location)).isDirectory()) {
return true;
} else {
throw ex;
}
} catch (Exception e) {
EventLogger.LogEvent("NCache", "The custom path given for logging cache :\"" + cache + "\" info data is not valid", EventType.ERROR, EventCategories.Error, EventID.GeneralError);
}
return false;
}
private void RemoveAllAppender() {
//Basit: Is it even required ?
// log4net.Repository.Hierarchy.Logger l = (log4net.Repository.Hierarchy.Logger) log.getLogger();
//
// l.RemoveAllAppenders();
}
//Basit: This might not write files synchronously even when the buffersize is 1
/**
* Creates Buffer Appender, Responsible for storing all logging events in memory buffer and writing them down when by passing the logging events on to the file appender it
* holds when its buffer becomes full Can also be made a lossy logger which writes only writes down to a file when a specific crieteria/condition is met
*
* @param cacheName CacheName used to name the Buffer Appender
* @param fileName File name to log into
* @return Returns the created Appender
*/
public final boolean[] ReadConfig(tangible.RefObject bufferAppender) {
try {
//Basit: TODO
// String EnableLogs = System.Configuration.ConfigurationManager.AppSettings["EnableLogs"];
// String EnableDetailedLogs = System.Configuration.ConfigurationManager.AppSettings["EnableDetailedLogs"];
// String BufferSize = System.Configuration.ConfigurationManager.AppSettings["BufferSize"];
String EnableLogs = "False";
String EnableDetailedLogs = "False";
String BufferSize = "False";
try {
if (BufferSize != null) {
bufferAppender.argvalue = Integer.parseInt(BufferSize);
} else {
bufferAppender.argvalue = bufferDefaultSize;
}
} catch (Exception e) {
bufferAppender.argvalue = bufferDefaultSize;
}
if (EnableDetailedLogs == null && EnableLogs == null) {
return new boolean[]
{
false,
false
};
} else if (EnableDetailedLogs != null && EnableLogs == null) {
return new boolean[]
{
false,
Boolean.parseBoolean(EnableDetailedLogs)
};
} else if (EnableDetailedLogs == null && EnableLogs != null) {
return new boolean[]
{
Boolean.parseBoolean(EnableLogs),
false
};
} else {
return new boolean[]
{
Boolean.parseBoolean(EnableLogs),
Boolean.parseBoolean(EnableDetailedLogs)
};
}
} catch (Exception ex) {
bufferAppender.argvalue = bufferDefaultSize;
return new boolean[]
{
false,
false
};
}
}
public final boolean[] ReadClientConfig(tangible.RefObject bufferAppender) {
try {
String EnableLogs = System.getProperty("ENABLE_CLIENT_LOGS");
String EnableDetailedLogs = System.getProperty("ENABLE_DETAILED_CLIENT_LOGS");
String BufferSize = System.getProperty("BufferSize");
try {
if (BufferSize != null) {
bufferAppender.argvalue = Integer.parseInt(BufferSize);
} else {
bufferAppender.argvalue = bufferDefaultSize;
}
} catch (Exception e) {
bufferAppender.argvalue = bufferDefaultSize;
}
if (EnableDetailedLogs == null && EnableLogs == null) {
return new boolean[]
{
false,
false
};
} else if (EnableDetailedLogs != null && EnableLogs == null) {
return new boolean[]
{
false,
Boolean.parseBoolean(EnableDetailedLogs)
};
} else if (EnableDetailedLogs == null && EnableLogs != null) {
return new boolean[]
{
Boolean.parseBoolean(EnableLogs),
false
};
} else {
return new boolean[]
{
Boolean.parseBoolean(EnableLogs),
Boolean.parseBoolean(EnableDetailedLogs)
};
}
} catch (Exception ex) {
bufferAppender.argvalue = bufferDefaultSize;
return new boolean[]
{
false,
false
};
}
}
//
/**
* No need to call this flush, its automatic there is no force flush available for AsynAppenders, this is by implementation and only close is available which stops and
* interrupts all the threads and perfmos their operations forcefully
*/
@Override
public final void Flush() {
}
@Override
/**
* Closes the appenders and removes them
*/
public final void close() {
for (Handler handler : this.logger.getHandlers()) {
handler.close();
handler.flush();
logger.removeHandler(handler);
}
SetLevel("OFF");
}
/**
* Error logs
*
* @param module Module Name
* @param message Message to log, append the stackTrace
*/
@Override
public final void Error(String module, String message) {
int space2 = 50;
if (module.length() == 0) {
space2 = 4;
} else {
space2 = 50 - module.length();
if (space2 <= 0) {
space2 = 40;
}
}
Error(module + String.format("%" + space2 + "s", " ") + message);
}
/**
* Fatal logs
*
* @param module Module Name
* @param message Message to log, append the stackTrace
*/
@Override
public final void Fatal(String module, String message) {
int space2 = 50;
if (module.length() == 0) {
space2 = 4;
} else {
space2 = 50 - module.length();
if (space2 <= 0) {
space2 = 40;
}
}
Fatal(module + String.format("%" + space2 + "s", " ") + message);
}
/**
* Critical Information, Level higher than Fatal
*
* @param module Module name
* @param message Message to log, append the stackTrace
*/
@Override
public final void CriticalInfo(String module, String message) {
int space2 = 50;
if (module.length() == 0) {
space2 = 4;
} else {
space2 = 50 - module.length();
if (space2 <= 0) {
space2 = 40;
}
}
CriticalInfo(module + String.format("%" + space2 + "s", " ") + message);
}
/**
* Information level debugging
*
* @param module Module Name
* @param message Message to log, append the stackTrace
*/
@Override
public final void Info(String module, String message) {
int space2 = 50;
if (module.length() == 0) {
space2 = 4;
} else {
space2 = 50 - module.length();
if (space2 <= 0) {
space2 = 40;
}
}
Info(module + String.format("%" + space2 + "s", " ") + message);
}
/**
* Debug level information
*
* @param module Module Name
* @param message Message to log, append the stackTrace
*/
@Override
public final void Debug(String module, String message) {
int space2 = 50;
if (module.length() == 0) {
space2 = 4;
} else {
space2 = 50 - module.length();
if (space2 <= 0) {
space2 = 40;
}
}
Debug(module + String.format("%" + space2 + "s", " ") + message);
}
/**
* Warning messages
*
* @param module Module name
* @param message Message to log, append the stackTrace
*/
@Override
public final void Warn(String module, String message) {
int space2 = 50;
if (module.length() == 0) {
space2 = 4;
} else {
space2 = 50 - module.length();
if (space2 <= 0) {
space2 = 40;
}
}
Warn(String.format("%" + space2 + "s", " ") + message);
}
/**
* Used only for Dev tracing To be removed in production
*
* @param message Message to log, append the stackTrace
*/
@Override
public final void DevTrace(String message) {
logger.log(Level.SEVERE, message);
}
/**
* Used only for Dev tracing To be removed in production
*
* @param module Module name
* @param message Message to log, append the stackTrace
*/
@Override
public final void DevTrace(String module, String message) {
int space2 = 50;
if (module.length() == 0) {
space2 = 4;
} else {
space2 = 50 - module.length();
if (space2 <= 0) {
space2 = 40;
}
}
DevTrace(String.format("%" + space2 + "s", " ") + message);
}
//
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy