Ok, I have solved the problem.
You have to set to something different than "Local System account" under
properties of the service.
bye
Robert
Robert Dollinger schrieb:
> Hi to everyone,
>
> I have a Service, that runs on a WinXP machine. The service read a file
> on a Win98 machine and write the content in a file on the WinXP machine.
> After tree times I get the error message exceptions.IOError: (13,
> 'Permission denied').
>
> The following things I have already tested:
>
> - The file on Win98 machine could be deleted, so the file is closed
> correctly.
> - Stop an restart the service on WinXP, will have no effect
> - Reboot the Win98 machine solve the problem for three times. So I have
> the same issue explained above.
> - I have changed the intervall from 5 sec to 1 minute. After ther first
> time I get the error message.
> - Using a Win2000 or WINXP machine instead of the Win98 machine. That
> works. But unfortunatly the PC to access is a Win98 and I have no
> influence to decide for upgrade.
>
> I can't figure out, what's the problem.
>
> This is the code to simulate my actual problem:
>
> # -*- coding: iso-8859-1 -*-
>
> import win32serviceutil
> import win32service
> import win32event
> import pywintypes
> import win32file
> import win32pipe
> import win32api
> import win32con
> import thread
> import ntsecuritycon
> import os
> import sys
>
> class MyService(win32serviceutil.ServiceFramework):
> """NT Service."""
>
> _svc_name_ = "TCTest"
> _svc_display_name_ = "TCTest"
>
> def __init__(self, args):
> win32serviceutil.ServiceFramework.__init__(self, args)
> self.stop_event = win32event.CreateEvent(None, 0, 0, None)
> self.overlapped = pywintypes.OVERLAPPED()
> self.overlapped.hEvent = win32event.CreateEvent(None,0,0,None)
> self.thread_handles = []
>
> def SvcDoRun(self):
> import servicemanager
>
> servicemanager.LogMsg(
> servicemanager.EVENTLOG_INFORMATION_TYPE,
> servicemanager.PYS_SERVICE_STARTED,
> (self._svc_name_, '')
> )
>
> while 1:
> datei = open(r'\\ipcwin98\test\test.txt', 'r')
> log = open(r'c:\log.txt', 'a')
> log.write(datei.read())
> datei.close()
> log.close()
>
> if win32event.WaitForSingleObject(self.stop_event, 5000) ==
> win32event.WAIT_OBJECT_0:
> break
>
> servicemanager.LogMsg(
> servicemanager.EVENTLOG_INFORMATION_TYPE,
> servicemanager.PYS_SERVICE_STOPPED,
> (self._svc_name_, '')
> )
>
> def SvcStop(self):
> self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)
> win32event.SetEvent(self.stop_event)
>
> if __name__ == '__main__':
> win32serviceutil.HandleCommandLine(MyService)
>
>
> Thanks in advanced for your help.
> bye
> Robert
>
--
http://mail.python.org/mailman/listinfo/python-list