#1 2024-08-24 09:26:03

JD
Member
Registered: 2015-08-20
Posts: 126

mORMot 2 log file creation settings

Hi there everyone,

I would like my server to generate log files where events are recorded using local time (not UTC), limited to 10MB in size and rotated daily at midnight.

This is my current setting

  LogFamily                         := SQLite3Log.Family;
  LogFamily.Level                   := LOG_VERBOSE;
  LogFamily.PerThreadLog            := ptIdentifiedInOneFile;
  LogFamily.LocalTimestamp          := TRUE;      // Log events in local time
  LogFamily.RotateFileCount         := 1;         // > 0 enables RotateFileSizeKB / RotateFileDailyAtHour
                                                  // = 1 means logs are not compressed
                                                  // File will be rotated by size and hour
  LogFamily.RotateFileSizeKB        := 10*1024;   // rotate by 10 MB logs
  LogFamily.RotateFileDailyAtHour   := 0;         // Midnight
  ApplicationPath                   := Executable.ProgramFilePath;
  LogFamily.DestinationPath         := ExpandFileName(ApplicationPath + 'log\');
  LogFamily.FileExistsAction        := acAppend;

Is this correct? I cannot test the settings natively on Windows for now, but my tests in a Docker container did not yield the desired results.

In addition, I would like to know if it is possible to compress old log files in the ZIP format instead of the default synlz format if necessary.

Thanks a lot for your kind assistance.

Cheers,

JD

Offline

#2 2024-08-25 07:07:23

ab
Administrator
From: France
Registered: 2010-06-21
Posts: 15,247
Website

Re: mORMot 2 log file creation settings

My guess is that if you use

LogFamily.PerThreadLog            := ptIdentifiedInOneFile;

then rotation is disabled by design.

Because ptIdentifiedInOneFile means one file per thread, so it does not make any sense to rotate those files.

Offline

#3 2024-08-25 12:35:59

JD
Member
Registered: 2015-08-20
Posts: 126

Re: mORMot 2 log file creation settings

Hi there ab,

Thanks for the reply. I finally got it to rotate in the Docker container. I thought that a new log file will be created automatically immediately if it is past midnight because of the RotateFileDailyAtHour setting.

This morning, yesterday's log file was the only one in use, but when I made some requests to the server, it compressed yesterday's log file in the synlz format and created a new log file for today. I did not need to remove LogFamily.PerThreadLog := ptIdentifiedInOneFile; for this to work.

Now the next question is, can the archives be in the Zip format instead of synlz?

Thanks for your assistance.

Cheers,

JD

Last edited by JD (2024-08-25 12:38:08)

Offline

#4 2024-08-25 14:25:55

ab
Administrator
From: France
Registered: 2010-06-21
Posts: 15,247
Website

Re: mORMot 2 log file creation settings

You can just use EventArchiveZip() from mormot.core.zip:

TSynLog.Family.OnArchive := @EventArchiveZip;

to generate .zip files.
But the .zip files may become quite huge at the end.

Therefore, for log files, I would rather use .gz output, as it is more usual and useful.
Just assign AlgoGZFast() mormot.core.zip.pas into LogCompressAlgo global.

Offline

#5 2024-08-26 10:24:39

JD
Member
Registered: 2015-08-20
Posts: 126

Re: mORMot 2 log file creation settings

ab wrote:

Just assign AlgoGZFast() mormot.core.zip.pas into LogCompressAlgo global.

Thanks for your advice, ab. Much appreciated.

How do I assign AlgoGZFast into LogCompressAlgo? Do I have to modify the mormot.core.zip.pas to do this?

Cheers,

JD

Offline

#6 2024-08-26 10:44:38

ab
Administrator
From: France
Registered: 2010-06-21
Posts: 15,247
Website

Re: mORMot 2 log file creation settings

JD wrote:

How do I assign AlgoGZFast into LogCompressAlgo?

LogCompressAlgo := AlgoGZFast;

tongue

Offline

#7 2024-08-26 11:23:38

JD
Member
Registered: 2015-08-20
Posts: 126

Re: mORMot 2 log file creation settings

Yes, the joke is on me ;o) . I added it to the EventArchiveZip function in the mormot.core.zip source file as follows:

function EventArchiveZip(
  const aOldLogFileName, aDestinationPath: TFileName): boolean;
var
  n: integer;
  z, s: TStream;
  fsize: Int64;
  ftime: TUnixMSTime;
  zipname, decname: TFileName;
begin
  result := false;
  EventArchiveZipSafe.Lock;
  LogCompressAlgo := AlgoGZFast;       // <----- New addition to compress log files in GZ format

  //---- more code follows ----- 

end;

However what this means is that I'll have to remember to add this like every time I update mORMot 2. So is it possible for you to modify the source so that the compression algorithm can be an option to be defined without having to touch mORMot 2 source files?

Thanks a million for your kind assistance.

Cheers,

JD

Offline

#8 2024-08-26 12:22:06

Coldzer0
Member
From: ::1
Registered: 2018-08-31
Posts: 36
Website

Re: mORMot 2 log file creation settings

You don't have to edit the mormot2 source code.
All you need to do is add "mormot.core.buffers, mormot.core.zip" in your uses.

And at the start of your app or the log init part
"LogCompressAlgo := AlgoGZFast;"


Mac, Windows, Linux
FPC Trunk, Lazarus Trunk, Delphi 13.x Latest

Offline

#9 2024-08-26 12:39:24

ab
Administrator
From: France
Registered: 2010-06-21
Posts: 15,247
Website

Re: mORMot 2 log file creation settings

No, no, EventArchiveZip() should not be modified.
Your modification breaks everything.

Offline

#10 2024-08-26 15:49:30

JD
Member
Registered: 2015-08-20
Posts: 126

Re: mORMot 2 log file creation settings

@ab and @Coldzer0

Thanks a lot for your advice. I've added your suggestions. I'll keep you posted on the results.

Cheers,

JD

Last edited by JD (2024-08-26 15:49:46)

Offline

#11 2024-08-27 07:47:28

flydev
Member
From: France
Registered: 2020-11-27
Posts: 136
Website

Re: mORMot 2 log file creation settings

you can find an example there: https://github.com/synopse/mORMot2/blob … #L160-L174

LogCompressAlgo is defined as global var in mormot.core.buffers, so include both units buffers and zip as @ColdZer0 said.

Last edited by flydev (2024-08-27 07:49:02)

Offline

#12 2024-08-27 13:28:09

JD
Member
Registered: 2015-08-20
Posts: 126

Re: mORMot 2 log file creation settings

@flydev Thanks a lot for the link.

Offline

#13 2024-09-02 07:05:57

JD
Member
Registered: 2015-08-20
Posts: 126

Re: mORMot 2 log file creation settings

UPDATE

After several days, I can now confirm that log compression (synlz, gz and Zip) works. I've tried and tested all 3 options successfully.

In addition, I was pleasantly surprised to discover that zip compression creates log archives grouped into months and years YYYYMM.zip. for example, a new Zip archive has just been created for the current month, September, while the old archive for August is still there with August log files inside it. It is nice to have this option for certain use cases.

Thanks a lot to ab and all the other contributors to mORMot for such a wonderful framework.

Cheers,

JD

Last edited by JD (2024-09-02 07:07:26)

Offline

#14 2025-04-02 10:28:55

dc1712
Member
Registered: 2025-04-02
Posts: 1

Re: mORMot 2 log file creation settings

Hi Guys,

I'm new to mORMot2 (MORMot in general) .
i would like to use mOrMot2 within a linux daemon and i've very specific specifications:

-On the target system we don't have access to the filesystem(only readonly), so i don't wanna write a log file at all.
  I already found the property NoFile within TSynLogFamily class - looks like this is exactly what i'm searching for.

- I still want to have Logout in the console, shouldn't be a problem at all: myLogFamily.EchoToConsole:= LOG_VERBOSE;   

- i want to use the logging within a Linux daemon; i inherited from "TSynDaemon", now i'm struggling hard to find the right place where to define and configure my logging.
   In most of the mormot2 demos/examples i found stuf like:
       - TSynLog.Family
      -  TSynLog

   Should my Application have own instances of TSynLogFamily and TSynLogFile ? If Yes, where is the best place to Create them ? AfterCreate of TSynDaemon ?
   Or should i have a global unit with my instances ?
   Or should i modify the Seetings to my needs over TSynLogFamily / TSynLog ?

   Bonus question: Later on i would like not only log to the console output, i would like to write into the SystemLog. Is there a ready to go way ? Or do i have to work with EchoCustom ? Or is there an other way i missed out ?

  Many thx in advance,

  DC

Last edited by dc1712 (2025-04-02 10:47:17)

Offline

#15 2025-04-02 14:40:10

ab
Administrator
From: France
Registered: 2010-06-21
Posts: 15,247
Website

Re: mORMot 2 log file creation settings

Everything should be setup in TSynLog.Family.
(also systemd or console output)

No need to call any constructor, nor wonder about any TSynLog instance.
Depending on the thread options, the TSynLogFamily will create and maintain the proper TSynLog instance(s) for you.

Offline

Board footer

Powered by FluxBB