Windows service concept?

  • Thread starter Thread starter Guest
  • Start date Start date
G

Guest

Hi, friends,

Here is a question about Windows service concept in C#.net 2005.

Suppose my service is doing a transaction, say modifying records/data of a
database. At this point, a user issues a command to stop this service? How
this service will behave? It will stop right away without rollback, or it
will finish this transaction then stop?

Any ideas, reference papers? Thanks.
 
Hello,

when a service is gracefully stopped (not killed), the OnShutdown method is
called inside your service. You can then hold the stop-process until the
transaction is complete or do a rollback.

The services MMC will wait up to 30 seconds before displaying a warning
message to the user who stopped the service. But even in this case, the
process will not be terminated.

Best regards,
Henning
 
Thanks, Henning. I have another question:

Is that possible for a Windows service to have public properties/methods so
that other assembly may access it?

If yes, how? Any reference paper or samples? Thanks again.
 
In this case, you want remote api on your service. Something like WCF would
be good.

--
William Stacey [C# MVP]


| Thanks, Henning. I have another question:
|
| Is that possible for a Windows service to have public properties/methods
so
| that other assembly may access it?
|
| If yes, how? Any reference paper or samples? Thanks again.
|
| "Henning Krause [MVP - Exchange]" wrote:
|
| > Hello,
| >
| > when a service is gracefully stopped (not killed), the OnShutdown method
is
| > called inside your service. You can then hold the stop-process until the
| > transaction is complete or do a rollback.
| >
| > The services MMC will wait up to 30 seconds before displaying a warning
| > message to the user who stopped the service. But even in this case, the
| > process will not be terminated.
| >
| > Best regards,
| > Henning
| >
| > | > > Hi, friends,
| > >
| > > Here is a question about Windows service concept in C#.net 2005.
| > >
| > > Suppose my service is doing a transaction, say modifying records/data
of a
| > > database. At this point, a user issues a command to stop this service?
How
| > > this service will behave? It will stop right away without rollback, or
it
| > > will finish this transaction then stop?
| > >
| > > Any ideas, reference papers? Thanks.
| >
| >
 
Hello,

WCF will be an excellent choice unless your service must run on Windows
2000. WCF is not supported there. In that case you'll have to use another
technique. Possible choices include WSE 3.0 (to host in-process
webservices), Message Queues and .NET Remoting .

Best regards,
Henning Krause
 
Hello,

WCF will be an excellent choice unless your service must run on Windows
2000. WCF is not supported there. In that case you'll have to use another
technique. Possible choices include WSE 3.0 (to host in-process
webservices), Message Queues and .NET Remoting .

Best regards,
Henning Krause

William Stacey said:
In this case, you want remote api on your service. Something like WCF
would
be good.
| Thanks, Henning. I have another question:
|
| Is that possible for a Windows service to have public properties/methods
so
| that other assembly may access it?
|
| If yes, how? Any reference paper or samples? Thanks again.
|
| "Henning Krause [MVP - Exchange]" wrote:
|
| > Hello,
| >
| > when a service is gracefully stopped (not killed), the OnShutdown
method
is
| > called inside your service. You can then hold the stop-process until
the
| > transaction is complete or do a rollback.
| >
| > The services MMC will wait up to 30 seconds before displaying a
warning
| > message to the user who stopped the service. But even in this case,
the
| > process will not be terminated.
| >
| > Best regards,
| > Henning
| >
| >| > > Hi, friends,
| > >
| > > Here is a question about Windows service concept in C#.net 2005.
| > >
| > > Suppose my service is doing a transaction, say modifying
records/data
of a
| > > database. At this point, a user issues a command to stop this
service?
How
| > > this service will behave? It will stop right away without rollback,
or
it
| > > will finish this transaction then stop?
| > >
| > > Any ideas, reference papers? Thanks.
| >
| >

Hi,

Besides WCF mentioned (That is supported in Windows XP SP2 and up),
you can choose any IPC (Inter Process Communication) techniques such
as mentioned by Henning.

Take a look at this article just to get the feeling of IPC.

Moty
http://www.codeproject.com/threads/ipcworkshop.asp?df=100&forumid=14121&exp=0&select=407325
 
Thank you all, guys!

One more question about implementation. I listed all services running on a
selected machine by looping each element in the array returned below.

ServiceController[] controllers =
ServiceController.GetServices(selectedMachineName);

When a user selects a service from the list and wants to stop/start it, I
use the above code, loop the array again, and find the controller this user
selects by comparing controller.ServiceName with the service name of
selected service. Through this controller, the service is stopped/started.

My question is: Is there a way that I don't have to "loop the array again",
rather, I may save "something" when looping the first time? (I guess not, but
not sure).

Also, controller does not contain Startup Type, Log On As info. Any other
..net module may provide those info?

Thanks a lot !
 
Hello Andrew,

if you have the name of the service, you can construct a service controller
with the ServiceController constructor:

ServiceController sc = new ServiceController(name);

sc.Start();

best regards,
Henning Krause
 
Great, thanks!

And what about this one:

controller does not contain Startup Type, Log On As info. Any other .net
module may provide those info?
 
Thank you, Henning, really appreciate.

I received one suggestion for my previous question: Is that possible for a
Windows service to have public properties/methods so that other assembly may
access it?

In the assembly, say a .exe app, that needs to access this Windows service's
properties/methods/events, just reference this service either at design time
or at run time, and treat this service as any other module assembly.

What is your comment on this approach?

Thanks.


Henning Krause said:
Hello,
Also, controller does not contain Startup Type, Log On As info. Any
other
.net module may provide those info?


for this info, you must use the Win32 function QueryServiceConfig (See
http://www.pinvoke.net/default.aspx/advapi32/QueryServiceConfig.html for an
example.

Best regards,
Henning Krause
 
Hello,

that's not possible due to process isolation. You'll have to stick to some
sort of interprocess communication.

Best regards,
Henning Krause

Andrew said:
Thank you, Henning, really appreciate.

I received one suggestion for my previous question: Is that possible for a
Windows service to have public properties/methods so that other assembly
may
access it?

In the assembly, say a .exe app, that needs to access this Windows
service's
properties/methods/events, just reference this service either at design
time
or at run time, and treat this service as any other module assembly.

What is your comment on this approach?

Thanks.


Henning Krause said:
Hello,
Also, controller does not contain Startup Type, Log On As info. Any
other
.net module may provide those info?


for this info, you must use the Win32 function QueryServiceConfig (See
http://www.pinvoke.net/default.aspx/advapi32/QueryServiceConfig.html for
an
example.

Best regards,
Henning Krause
 
But, since a windows service is a singleton, when one instance this windows
service, one will get a reference to this singleton. At this point, one may
access properties/methods, right?

Henning Krause said:
Hello,

that's not possible due to process isolation. You'll have to stick to some
sort of interprocess communication.

Best regards,
Henning Krause

Andrew said:
Thank you, Henning, really appreciate.

I received one suggestion for my previous question: Is that possible for a
Windows service to have public properties/methods so that other assembly
may
access it?

In the assembly, say a .exe app, that needs to access this Windows
service's
properties/methods/events, just reference this service either at design
time
or at run time, and treat this service as any other module assembly.

What is your comment on this approach?

Thanks.


Henning Krause said:
Hello,

Also, controller does not contain Startup Type, Log On As info. Any
other
.net module may provide those info?

for this info, you must use the Win32 function QueryServiceConfig (See
http://www.pinvoke.net/default.aspx/advapi32/QueryServiceConfig.html for
an
example.

Best regards,
Henning Krause

 
Hello Andrew,

you can't get a direct reference to the service instance. Processes are
isolated from another in Windows. That's why there is inter-process
communcation.

Best regards,
Henning Krause


Andrew said:
But, since a windows service is a singleton, when one instance this
windows
service, one will get a reference to this singleton. At this point, one
may
access properties/methods, right?

Henning Krause said:
Hello,

that's not possible due to process isolation. You'll have to stick to
some
sort of interprocess communication.

Best regards,
Henning Krause

Andrew said:
Thank you, Henning, really appreciate.

I received one suggestion for my previous question: Is that possible
for a
Windows service to have public properties/methods so that other
assembly
may
access it?

In the assembly, say a .exe app, that needs to access this Windows
service's
properties/methods/events, just reference this service either at design
time
or at run time, and treat this service as any other module assembly.

What is your comment on this approach?

Thanks.


:

Hello,

Also, controller does not contain Startup Type, Log On As info.
Any
other
.net module may provide those info?

for this info, you must use the Win32 function QueryServiceConfig (See
http://www.pinvoke.net/default.aspx/advapi32/QueryServiceConfig.html
for
an
example.

Best regards,
Henning Krause

 
Back
Top