macOS Mojave - locate not working
I got a MacBook from my work and wanted to use the locate
command, but I get the message:
WARNING: The locate database (/var/db/locate.database) does not exist.
To create the database, run the following command:
sudo launchctl load -w /System/Library/LaunchDaemons/com.apple.locate.plist
Please be aware that the database can take some time to generate; once
the database has been created, this message will no longer appear.
I ran sudo launchctl
and waited some time... It's been two days and I still see that same message. If I ran sudo launchctl
again I get:
/System/Library/LaunchDaemons/com.apple.locate.plist: service already loaded
Searched for the database and:
$ ls -l /var/db/locate.database
ls: /var/db/locate.database: No such file or directory
The com.apple.locate.plist file is set with the predefined schedule to update on every Saturday at 3:15
<key>StartCalendarInterval</key>
<dict>
<key>Hour</key>
<integer>3</integer>
<key>Minute</key>
<integer>15</integer>
<key>Weekday</key>
<integer>6</integer>
</dict>
So, it shall update once it was executed for the first time. I'm under Mojave (v10.14.2), new MacBook with SSD and Core i7. locate
should take few minutes to work on new machines, but it's not the case here.
Any ideas on why it isn't working and/or how to make it work?
Solution 1:
Amigo, I might start with launchctl:
sudo launchctl unload -w /System/Library/LaunchDaemons/com.apple.locate.plist
Then check for any impediments to obtaining exclusive lock privilege on the nonexistent database:
sudo fuser -fu /private/var/db/locate.database
sudo lsof /private/var/db/locate.database
Then kill any process reported by either command. Next, run the db generator by hand, preceded by an opensnoop for debugging if something goes wrong. You will need to open a new terminal window ( command key - N shortcut, I believe ) and run opensnoop there, exiting it with a Control Key - c combo.
sudo opensnoop -cegx -f /private/var/db/locate.database
Then over to your original window type:
sudo /usr/libexec/locate.updatedb
Remember to quit opensnoop with a cntrl-c in its window.
F.
Solution 2:
I was using the MacBook for about three weeks and just put it to sleep everyday. For some unknown reason locate
was not working. To solve the issue, it helped the classical "have you tried to turn it on and off?" After restart, it worked.
As already mentioned, locate
is configured to update its database every Saturday, so it doesn't find any new file created before it updates. A workaround is to set the .plist file for everyday updates.
And as @mateusz-szlosek suggested, the command mdfind
is more efficient and can find recently created files using the option -name
.