Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Consider Migrating to Microsoft.Extensions.Logging.ILogger #679

Open
emanuel-v-r opened this issue Feb 5, 2021 · 11 comments
Open

Consider Migrating to Microsoft.Extensions.Logging.ILogger #679

emanuel-v-r opened this issue Feb 5, 2021 · 11 comments

Comments

@emanuel-v-r
Copy link

Hi,

Currently, this lib is using proprietary logging interfaces, but as you know in .NET Core the standard way to do logging is using Microsoft.Extensions.Logging.ILogger, which allows having some general .NET Core convention, besides that Microsoft has some built-in implementations, and also there is a variety of third-party logging providers for these interfaces.
This allows better compatibility with .NET Core or even .NET 5 ecosystems and is easy as well to plug some alarmistics based on log level.
Have you ever considered these changes?

Thank you.

@Michael-Kempe
Copy link

Hello!
I would just like to briefly point out that this creates a dependency on an external library. Maybe there is another solution - without adding an external references?

@emanuel-v-r
Copy link
Author

Hello!
I would just like to briefly point out that this creates a dependency on an external library. Maybe there is another solution - without adding an external references?

Hi,

I see your point, and usually, I agree that is good to avoid those, but in this scenario, it is a Microsoft package, which is quite a small one because it contains only the "contracts" and also it is also commonly used in the .NET ecosystem. You can check the package here https://www.nuget.org/packages/Microsoft.Extensions.Logging.Abstractions/, you have the statistics available there.

@gbirchmeier
Copy link
Member

I wouldn't even call our logging "proprietary", as that implies that it's something someone would want to claim ownership of. I'd actually call it "janky" and "hacky" and "not very good".

The reason it's stayed janky for this long is because we actually have multiple loggers going on; one main one and one for each socket thread. These should really be consolidated, but doing so going to be annoying and interface-breaking so I just haven't prioritized it.

It is a mess that I'm very much looking forward to cleaning up, and I agree that ILogging is likely the best way to go. I'm hoping to attack it sometime this year.

@emanuel-v-r
Copy link
Author

I wouldn't even call our logging "proprietary", as that implies that it's something someone would want to claim ownership of. I'd actually call it "janky" and "hacky" and "not very good".

The reason it's stayed janky for this long is because we actually have multiple loggers going on; one main one and one for each socket thread. These should really be consolidated, but doing so going to be annoying and interface-breaking so I just haven't prioritized it.

It is a mess that I'm very much looking forward to cleaning up, and I agree that ILogging is likely the best way to go. I'm hoping to attack it sometime this year.

Great! Thanks for the feedback!

@abbeycode
Copy link

abbeycode commented May 27, 2022

Hi! My company's been using QuickFIX/n for a couple of years now, and we'd like to dedicate some time (essentially a Summer project) to improving the logging situation, and we agree that moving to ILogger would be the best way to go.

Our key complaint is the lack of rolling, though it would also be nice if the QuickFIX logs could be co-mingled with our own and filtered by severity.

If we were to start working on adopting Microsoft.Extensions.Logging.ILogger, would that PR be welcome? We have a junior developer who we'd be putting on this with my guidance and could use any pointers as far as where to start (e.g. the classes we would we be looking to eliminate in switching to ILogger).

@kirsan31
Copy link

For now we can somehow integrate popular logging framework (like NLog) but we unable to do proper message filtering and message severity.
It wood be nice to have more control of logging. For example I want not to log HeartBeat messages at all. And i don't want to do it by parsing the final message string :(

@VAllens
Copy link
Contributor

VAllens commented Dec 4, 2024

While I personally would love to do this,
it would be too destructive and invasive and cause QuickFIX/n to create external dependencies.

I prefer to use an extension library implementation,
e.g. QuickFIXn.Extensions.Logging.

@emanuel-v-r
Copy link
Author

While I personally would love to do this, it would be too destructive and invasive and cause QuickFIX/n to create external dependencies.

I prefer to use an extension library implementation, e.g. QuickFIXn.Extensions.Logging.

This is not just a regular "external dependency", it's a dependency from the maintainers of dotnet.
Popular logging libraries such NLog and Serilog support ILogger

@VAllens
Copy link
Contributor

VAllens commented Dec 4, 2024

While I personally would love to do this, it would be too destructive and invasive and cause QuickFIX/n to create external dependencies.
I prefer to use an extension library implementation, e.g. QuickFIXn.Extensions.Logging.

This is not just a regular "external dependency", it's a dependency from the maintainers of dotnet. Popular logging libraries such NLog and Serilog support ILogger

ILogger and ILogger<TCategoryName>, which is not part of the .NET runtime,
is provided by the Microsoft.Extensions.Logging.Abstractions package.

@emanuel-v-r
Copy link
Author

While I personally would love to do this, it would be too destructive and invasive and cause QuickFIX/n to create external dependencies.
I prefer to use an extension library implementation, e.g. QuickFIXn.Extensions.Logging.

This is not just a regular "external dependency", it's a dependency from the maintainers of dotnet. Popular logging libraries such NLog and Serilog support ILogger

ILogger and ILogger, which is not part of the .NET runtime, is provided by the Microsoft.Extensions.Logging.Abstractions package.

I didn't say it was part of dotnet runtime, just said that it belongs to the maintainers of dotnet (Microsoft).

@gbirchmeier gbirchmeier closed this as not planned Won't fix, can't repro, duplicate, stale Dec 4, 2024
@gbirchmeier gbirchmeier reopened this Dec 4, 2024
@gbirchmeier
Copy link
Member

While I agree with @VAllens that external dependencies should be minimized, I am not opposed to this dependency from Microsoft.

I'll leave further comments on PR #899

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

6 participants