TL;DR: run
rm /var/spool/exim4/db/*
The long version:
A script of mine has been working diligently for months, sending me email when things break, or more often when I purposefully reboot a monitored computer.
This morning it was sending out the same email every few minutes, well after the issue was resolved. While I'm still not sure, I suspect an email was caught in my 'outbox', being sent over and over. In a fit of holiday cheer, I remembered XKCD 838 and looked in /var/spool/ to find a folder called exim4 that was empty except for four files in its db folder. I moved these binary files and the emails stopped. I then sent a test email, and the files immediately reappeared, with the same file sizes the had before. The test email was successfully received, and it's been quiet for hours now.
I don't know what those files do, but I do know that moving/deleting them fixed my problem when a reboot didn't. I didn't find any useful information on Google or in /etc/exim4/conf.d/ so I figured I'd post my findings here.
My problem was with an Ubuntu 16.04.1 server running Exim version 4.86_2 and GNU Mailutils 2.99.99 sending mail via Gmail's SMTP server.
As always: Your Mileage May Vary.
Tuesday, November 22, 2016
Thursday, April 21, 2016
Hyper-V: The operation failed because the file was not found.
TL;DR: Give permission for the local user named SERVICE to access the files in question.
The long version:
Hyper-V is a powerful hypervisor. It's a shame it has to run on such a stupid OS with so loosely defined user accounts. The Hyper-V service (as it exists by default on Windows Server Core 2012r2, and probably everywhere else) runs as the user "Local System". As is the case on all OSs, a user must be given permission to access and manipulate a file (in this case, VHD files). You'd think that giving access to "Everyone" or "LOCAL SERVICE" would do the trick, but you'd be wrong. Apparently, the real name of "Local System" is "SERVICE", and I don't know why services.msc doesn't just say that.
Since I first set up Hyper-V, I've been getting an error message that looks like this:
This worked for me, and I didn't see it posted anywhere else, so I figured I'd share it. As with anything, Your Mileage May Vary.
The long version:
Hyper-V is a powerful hypervisor. It's a shame it has to run on such a stupid OS with so loosely defined user accounts. The Hyper-V service (as it exists by default on Windows Server Core 2012r2, and probably everywhere else) runs as the user "Local System". As is the case on all OSs, a user must be given permission to access and manipulate a file (in this case, VHD files). You'd think that giving access to "Everyone" or "LOCAL SERVICE" would do the trick, but you'd be wrong. Apparently, the real name of "Local System" is "SERVICE", and I don't know why services.msc doesn't just say that.
Since I first set up Hyper-V, I've been getting an error message that looks like this:
Window Title: Virtual Machine ConnectionSearching the great and powerful Google lead me nowhere. Thankfully, I was able to solve it pretty easily. In my case, I'm using a Core install so I don't waste any more resources on the big stupid Windows than I have to. This means I have to do everything remotely. Obviously you'll need a machine with the permission and ability to manipulate the permissions of these files. I did it from an SMB/CIFS share of the VHD repo, but you can remote in and do it locally, or temporarily enable Admin Shares, or better yet: SSH in and run chmod or chown--just kidding, that would be too easy.
Main Instruction: The application encountered an error while attempting to change the state of 'VM name'.
Content: 'VM Name' failed to change state.
The operation failed because the file was not found.
- From any machine with a full Windows installation (I haven't tried doing this from any other OS) navigate to the folder holding the "file not found" files. I used Windows 7 to fix my 2012r2 Core, but you can use whatever is handy.
- Right-click on their parent folder (or several grand-parents down, whatever) and go to Properties.
- Click the "Security" tab.
- Click "Edit..."
- Click "Add..."
- Click "Advanced"
- Click "Locations..."
- Select the actual host of this folder, not your local computer, not a Domain Controller. It should be the top-most item on the Location tree.
- Click "OK"
- Click "Find Now"
- This should show every single user, group, and security principal local to that machine. Press the S key to be brought to the 'S' section of this alphabetically sorted list.
- Look for a group called "SERVICE".
- Double-Click the "SERVICE" group to choose it.
- Click "OK"
- Now back at the "Permissions for [folder]" window, give the "SERVICE" group full control.
- Click "OK" a bunch, and you're done.
This worked for me, and I didn't see it posted anywhere else, so I figured I'd share it. As with anything, Your Mileage May Vary.
Subscribe to:
Posts (Atom)