You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
In our code we have some calls made to boost/filesystem/operations methods. One of these calls was repeatedly checking the existence of some files. After an update from boost 1.81 to 1.84 it was noticed that these calls have become about 3 to 4 times slower in Windows.
I checked the same on a simple test application which performs a call to boost::filesystem::exists on a network path(formatted as "\\NETWORK_DRIVE\FILEPATH") for about a 1000 times. The timing that I got when using 1.81 and 1.84 versions showed a difference of 3.4 times.
I am building the test application using Visual Studio Professional 2022(64 bit) Version 17.10.6(Visual C++ 2022)
And running it on a Windows 11 Pro OS
The test app that I was running(while using 1.81 and 1.84) separately was following:
#include <boost/filesystem/path.hpp>
#include <boost/filesystem/operations.hpp>
#include <iostream>
#include <chrono>
int main()
{
boost::system::error_code ec;
auto pathString = std::string("\\\\NETWORK_DRIVE\\FILEPATH");
std::size_t totalTime = 0;
for (int i = 0; i < 1000; ++i)
{
auto startTime = std::chrono::high_resolution_clock::now();
auto path = boost::filesystem::path(pathString);
boost::filesystem::exists(path, ec);
auto endTime = std::chrono::high_resolution_clock::now();
auto elapsedTime = std::chrono::duration_cast<std::chrono::milliseconds>(endTime - startTime).count();
totalTime += elapsedTime;
std::cout << "TimeElapsed : " << elapsedTime << "\n";
}
std::cout << "TotalTimeElapsed : " << totalTime << "\n";
return 0;
}
Is this an expected performance degradation due to some required fixes or could this be improved?
The text was updated successfully, but these errors were encountered:
I do not see changes to status (on which exists is based) between 1.81 and 1.84 except 1db4474. I don't know if adding FILE_READ_EA caused a performance regression, but if so, that change was necessary for fixing incorrect behavior on SMBv1. Can you test if removing FILE_READ_EA affects performance in your case?
As to improving performance, technically, we don't need the entire file_status just to test if the file exists. Perhaps, there is a cheaper way to do it, but I don't readily know it, and it may depend on the actual underlying filesystem.
I do not see changes to status (on which exists is based) between 1.81 and 1.84 except 1db4474. I don't know if adding FILE_READ_EA caused a performance regression, but if so, that change was necessary for fixing incorrect behavior on SMBv1. Can you test if removing FILE_READ_EA affects performance in your case?
As to improving performance, technically, we don't need the entire file_status just to test if the file exists. Perhaps, there is a cheaper way to do it, but I don't readily know it, and it may depend on the actual underlying filesystem.
Thank you. I tried your suggestion and ran the test application after removing FILE_READ_EA flags from the status_impl methods( symlink_status_impl and status_impl). That brings the speed back to how it was in 1.81.
In our code we have some calls made to boost/filesystem/operations methods. One of these calls was repeatedly checking the existence of some files. After an update from boost 1.81 to 1.84 it was noticed that these calls have become about 3 to 4 times slower in Windows.
I checked the same on a simple test application which performs a call to boost::filesystem::exists on a network path(formatted as "\\NETWORK_DRIVE\FILEPATH") for about a 1000 times. The timing that I got when using 1.81 and 1.84 versions showed a difference of 3.4 times.
I am building the test application using Visual Studio Professional 2022(64 bit) Version 17.10.6(Visual C++ 2022)
And running it on a Windows 11 Pro OS
The test app that I was running(while using 1.81 and 1.84) separately was following:
Is this an expected performance degradation due to some required fixes or could this be improved?
The text was updated successfully, but these errors were encountered: