after some hiccups with windows I am trying to get the event daemon to work again. It’s the same machine that had been running it just fine for quite some time, but I had to remove the service and add it again for certain reasons.
When I test the daemon framework in an eleveated powershell it works just fine.
However, when I try to start the service via the Windows Services UI I get an error saying this:
Try deleting the event daemon data folder, which is configured in the daemon. Specifically shotgunEventDaemon.py.
There are also logs in the same directory, which you could check for more information.
Dude, Python 2.7 has been deprecated for about 10 years, it’s time to switch
I think there are fixes in the event daemon github to make it work.
I did all that, even started entirely new folders (with respectively updated configs).
Dude, Python 2.7 has been deprecated for about 10 years
Yeah, I know that but due to the VFX industry being behind by about 10 years this is still fairly recent switch in our world. The event daemon framework itself wasn’t updated to Python 3 for quite some time and since everything was working just fine until about a week ago and went by the old “never change a running system” philosophy (especially seeing I have to look after IT as well as production).
I will try running everything via Pythyon 3 though, maybe a recent windows update decided to no longer accept Python 2.7 as a service command.
You should really debug the service startup, and get more logs from there. Not sure how. Does the command line start of the service spit out just this single error message?
Did you try Start-Service shotgunEventDaemon
from powershell?
But really if the program gets to the point of writing logs, you should look in those. The directory is configured in the event daemon configuration.
No idea, I guess whatever is set up by shotgunEventDaemon.py install
I can’t find any info in the service properties or the logs.
My wild guess is that it is referring to PythonService.exe and possibly the last windows update decided that Python 2.7 is no longer acceptable to run as a service. This is the only thing I can think of but I have not yet had the time to try Python 3 to verify this.
In the windows service you can see “path to executable”. I don’t know if this also includes any arguments.
I have not tested shotgunEventDaemon.py install (we have our own system). Have you updated the event daemon recently?
I did after the trouble started, so I am using the latest version.
I am about to free up from a marathon show, so will probably raze the lot and get Python 3 on the job. Then report back
So I installed Python 3.7 with pywin32 then tried to install the service with that as per the GitHub docs. Now I get this:
PS C:\WINDOWS\system32> D:\Python37_7\python.exe \\10.11.11.101\ohufx\pipeline\tools\python\shotgun_events\src\shotgunEventDaemon.py install
Installing service ShotgunEventDaemon
**** WARNING ****
The executable at "D:\Python37_7\lib\site-packages\win32\PythonService.exe" is being used as a service.
This executable doesn't have pythonXX.dll and/or pywintypesXX.dll in the same
directory, and they can't be found in the System directory. This is likely to
fail when used in the context of a service.
The exact environment needed will depend on which user runs the service and
where Python is installed. If the service fails to run, this will be why.
NOTE: You should consider copying this executable to the directory where these
DLLs live - "D:\Python37_7\lib\site-packages\win32" might be a good place.
****
I tried copying the dlls into the same directory as the exe but got the same error.
The location where PythonService.exe is run from is controlled by this command ai assume: shotgunEventDaemon.py install
Where to from here (I’m no windows expert)?
EDIT:
I just copied the dlls as per the above message and the service installed successfully using Python 3. However, when I try to start it I am still getting an error:
The Shotgun Event Handler service failed to start due to the following error:
The service did not respond to the start or control request in a timely fashion.
All utterly unhelpful.
So frustrating after having this working for years…
Yeah, I never do this either but wanted to test to see what the actual problem is.
By now I am getting teh same error as with Python 2 (“incorrectr function”).
I logged an issue in the github repo but no traction.
There must be a way to debug this in a constructive manner…
FWIW, I’m tried to do the same using a 2.7 install and got something similar - I’m not sure how much free air I’ve got, but I guess sometime this weekend I might have to learn about windows services. How hard could it be?
Haha, exactly. The annoying thing is that I set this up two years ago withut trouble and it had been running ever since.
I set it up for other companies in the past as well without trouble.
But now I am stuck