Introducción a las aplicaciones de servicios de WindowsIntroduction to Windows Service Applications

Servicios de Microsoft Windows, antes conocidos como servicios NT, permiten crear aplicaciones ejecutables de larga duración que se ejecutan en sus propias sesiones de Windows.Microsoft Windows services, formerly known as NT services, enable you to create long-running executable applications that run in their own Windows sessions. Estos servicios pueden iniciarse automáticamente cuando el equipo arranca, se pueden pausar y reiniciar y no muestran ninguna interfaz de usuario.These services can be automatically started when the computer boots, can be paused and restarted, and do not show any user interface. Estas características dificultan servicios ideal para su uso en un servidor o siempre que tenga funcionalidad de ejecución prolongada que no interfiere con otros usuarios que trabajan en el mismo equipo.These features make services ideal for use on a server or whenever you need long-running functionality that does not interfere with other users who are working on the same computer. También puede ejecutar servicios en el contexto de seguridad de una cuenta de usuario que sea diferente del usuario que ha iniciado sesión o la cuenta de equipo predeterminada.You can also run services in the security context of a specific user account that is different from the logged-on user or the default computer account. Para obtener más información sobre los servicios y sesiones de Windows, consulte la documentación del SDK de Windows.For more information about services and Windows sessions, see the Windows SDK documentation.

Puede crear fácilmente servicios mediante la creación de una aplicación que se instala como un servicio.You can easily create services by creating an application that is installed as a service. Por ejemplo, imagine que desea supervisar los datos de contador de rendimiento y reaccionar a valores de umbral.For example, suppose you want to monitor performance counter data and react to threshold values. Puede escribir una aplicación de servicio de Windows que realiza escuchas para los datos del contador de rendimiento, implementar la aplicación y empezar a recopilar y analizar los datos.You could write a Windows Service application that listens to the performance counter data, deploy the application, and begin collecting and analyzing data.

Crear el servicio como un proyecto de Microsoft Visual Studio, defina el código que controla qué comandos puede enviarse al servicio y qué acciones deben ejecutarse cuando se reciben esos comandos.You create your service as a Microsoft Visual Studio project, defining code within it that controls what commands can be sent to the service and what actions should be taken when those commands are received. Los comandos que se pueden enviar a un servicio incluyen iniciar, pausar, reanudar y detener el servicio; También puede ejecutar comandos personalizados.Commands that can be sent to a service include starting, pausing, resuming, and stopping the service; you can also execute custom commands.

Después de crear y compilar la aplicación, puede instalarlo mediante la ejecución de la utilidad de línea de comandos InstallUtil.exe y pase la ruta de acceso al archivo ejecutable del servicio.After you create and build the application, you can install it by running the command-line utility InstallUtil.exe and passing the path to the service's executable file. A continuación, puede usar el Administrador de Control de servicios para iniciar, detener, pausar, reanudar y configurar el servicio.You can then use the Services Control Manager to start, stop, pause, resume, and configure your service. También puede realizar muchas de estas mismas tareas en el servicios nodo Explorador de servidores o mediante la ServiceController clase.You can also accomplish many of these same tasks in the Services node in Server Explorer or by using the ServiceController class.

Frente a las aplicaciones de servicio. Otras aplicaciones de Visual StudioService Applications vs. Other Visual Studio Applications

Función de las aplicaciones de servicio de manera diferente a muchos otros tipos de proyecto de varias maneras:Service applications function differently from many other project types in several ways:

  • El archivo ejecutable compilado que crea un proyecto de aplicación de servicio debe instalarse en el servidor antes de que el proyecto pueda funcionar de forma significativa.The compiled executable file that a service application project creates must be installed on the server before the project can function in a meaningful way. No puede depurar o ejecutar una aplicación de servicio, presione la tecla F5 o F11; no se puede ejecutar inmediatamente un servicio o un paso en su código.You cannot debug or run a service application by pressing F5 or F11; you cannot immediately run a service or step into its code. En su lugar, debe instalar e iniciar el servicio y, a continuación, adjuntar a un depurador al proceso del servicio.Instead, you must install and start your service, and then attach a debugger to the service's process. Para obtener más información, consulte Cómo: depurar aplicaciones de servicios de Windows.For more information, see How to: Debug Windows Service Applications.

  • A diferencia de algunos tipos de proyectos, debe crear componentes de instalación para las aplicaciones de servicio.Unlike some types of projects, you must create installation components for service applications. Los componentes de instalación, instalar y registrar el servicio en el servidor y crear una entrada para el servicio con las ventanas Administrador de Control de servicios.The installation components install and register the service on the server and create an entry for your service with the Windows Services Control Manager. Para obtener más información, consulte Cómo: agregar instaladores a la aplicación de servicio.For more information, see How to: Add Installers to Your Service Application.

  • El Main método para la aplicación de servicio debe emitir el comando Run para los servicios de su proyecto contiene.The Main method for your service application must issue the Run command for the services your project contains. El Run método carga los servicios en la Administrador de Control de servicios en el servidor apropiado.The Run method loads the services into the Services Control Manager on the appropriate server. Si usas el Windows Services plantilla de proyecto, este método se escribirá automáticamente.If you use the Windows Services project template, this method is written for you automatically. Tenga en cuenta que cargar un servicio no es lo mismo que iniciar el servicio.Note that loading a service is not the same thing as starting the service. Vea "Duración del servicio" a continuación para obtener más información.See "Service Lifetime" below for more information.

  • Aplicaciones de servicios de Windows se ejecutan en una estación de ventana diferente a la sesión interactiva del usuario que ha iniciado sesión.Windows Service applications run in a different window station than the interactive station of the logged-on user. Una estación de ventana es un objeto seguro que contiene un Portapapeles, un conjunto de átomos globales y un grupo de objetos de escritorio.A window station is a secure object that contains a Clipboard, a set of global atoms, and a group of desktop objects. Dado que la estación de servicio de Windows no es una sesión interactiva, cuadros de diálogo generan desde dentro de una ventana de aplicación de servicio no se verán y puede provocar que el programa deje de responder.Because the station of the Windows service is not an interactive station, dialog boxes raised from within a Windows service application will not be seen and may cause your program to stop responding. Del mismo modo, mensajes de error deben se registran en el registro de eventos de Windows en lugar de hacerlo en la interfaz de usuario.Similarly, error messages should be logged in the Windows event log rather than raised in the user interface.

    Las clases de servicio de Windows compatibles con .NET Framework no admiten la interacción con estaciones interactivas, es decir, el usuario ha iniciado sesión.The Windows service classes supported by the .NET Framework do not support interaction with interactive stations, that is, the logged-on user. .NET Framework no también incluye clases que representan las estaciones y escritorios.The .NET Framework also does not include classes that represent stations and desktops. Si el servicio de Windows debe interactuar con otras estaciones, debe tener acceso a la API no administrada de Windows.If your Windows service must interact with other stations, you will need to access the unmanaged Windows API. Para obtener más información, consulte la documentación del SDK de Windows.For more information, see the Windows SDK documentation.

    La interacción de las ventanas de servicio con el usuario u otras estaciones debe diseñarse con cuidado para que incluya casos tales como que se va a ningún usuario ha iniciado sesión o el usuario tenga un conjunto inesperado de objetos de escritorio.The interaction of the Windows service with the user or other stations must be carefully designed to include scenarios such as there being no logged on user, or the user having an unexpected set of desktop objects. En algunos casos, puede ser más adecuado escribir una aplicación de Windows que se ejecuta bajo el control del usuario.In some cases, it may be more appropriate to write a Windows application that runs under the control of the user.

  • Las aplicaciones de servicio de Windows se ejecutan en su propio contexto de seguridad y se inician antes el usuario inicia sesión en el equipo de Windows en el que se instalan.Windows service applications run in their own security context and are started before the user logs into the Windows computer on which they are installed. Debe considerar detenidamente en qué cuenta de usuario para ejecutar el servicio; un servicio que se ejecuta bajo la cuenta del sistema tiene más permisos y privilegios que una cuenta de usuario.You should plan carefully what user account to run the service within; a service running under the system account has more permissions and privileges than a user account.

Duración del servicioService Lifetime

Un servicio pasa por varios Estados internos de su duración.A service goes through several internal states in its lifetime. En primer lugar, el servicio está instalado en el sistema en el que se ejecutará.First, the service is installed onto the system on which it will run. Este proceso ejecuta los instaladores para el proyecto de servicio y carga el servicio en la Administrador de Control de servicios de ese equipo.This process executes the installers for the service project and loads the service into the Services Control Manager for that computer. El Administrador de Control de servicios es la utilidad central que proporciona Windows para administrar servicios.The Services Control Manager is the central utility provided by Windows to administer services.

Después de haberse cargado el servicio, debe estar iniciado.After the service has been loaded, it must be started. Iniciando el servicio le permite comenzar a funcionar.Starting the service allows it to begin functioning. Puede iniciar un servicio desde el Administrador de Control de servicios, de Explorador de servidores, o desde el código mediante una llamada a la Start método.You can start a service from the Services Control Manager, from Server Explorer, or from code by calling the Start method. El Start método pasa el procesamiento a la aplicación OnStart método y procesa el código que haya definido allí.The Start method passes processing to the application's OnStart method and processes any code you have defined there.

Puede existir un servicio en ejecución en este estado indefinidamente hasta que se ha detenido o en pausa o hasta que el equipo se apaga.A running service can exist in this state indefinitely until it is either stopped or paused or until the computer shuts down. Un servicio puede residir en uno de estos tres estados básicos: Running, Paused, o Stopped.A service can exist in one of three basic states: Running, Paused, or Stopped. El servicio también puede informar del estado de un comando pendiente: ContinuePending, PausePending, StartPending, o StopPending.The service can also report the state of a pending command: ContinuePending, PausePending, StartPending, or StopPending. Estos estados indican que un comando ha sido emitido, por ejemplo, un comando para pausar un servicio en ejecución, pero no se ha efectuado aún.These statuses indicate that a command has been issued, such as a command to pause a running service, but has not been carried out yet. Puede consultar la Status para determinar lo que un servicio de estado, o usar el WaitForStatus para llevar a cabo una acción cuando cualquiera de estos estados se produce.You can query the Status to determine what state a service is in, or use the WaitForStatus to carry out an action when any of these states occurs.

Puede pausar, detener o reanudar un servicio desde el Administrador de Control de servicios, de Explorador de servidores, o puede llamar a métodos en el código.You can pause, stop, or resume a service from the Services Control Manager, from Server Explorer, or by calling methods in code. Cada una de estas acciones puede llamar a un procedimiento asociado en el servicio (OnStop, OnPause, o OnContinue), en el que puede definir un procesamiento adicional que se realizará cuando el servicio cambia el estado.Each of these actions can call an associated procedure in the service (OnStop, OnPause, or OnContinue), in which you can define additional processing to be performed when the service changes state.

Tipos de serviciosTypes of Services

Hay dos tipos de servicios que puede crear en Visual Studio con .NET Framework.There are two types of services you can create in Visual Studio using the .NET Framework. Servicios que son el único servicio en un proceso se asignan al tipo Win32OwnProcess.Services that are the only service in a process are assigned the type Win32OwnProcess. Los servicios que comparten un proceso con otro servicio se asignan al tipo Win32ShareProcess.Services that share a process with another service are assigned the type Win32ShareProcess. Puede recuperar el tipo de servicio consultando la ServiceType propiedad.You can retrieve the service type by querying the ServiceType property.

En ocasiones, podría ver otros tipos de servicios si consulta servicios existentes que no se crearon en Visual Studio.You might occasionally see other service types if you query existing services that were not created in Visual Studio. Para obtener más información al respecto, consulte el ServiceType.For more information on these, see the ServiceType.

Servicios y el componente ServiceControllerServices and the ServiceController Component

El ServiceController componente se utiliza para conectarse a un servicio instalado y manipular su estado; mediante una ServiceController , componente, puede iniciar y detener un servicio, pausar y continuar con su funcionamiento y enviar comandos personalizados a un servicio.The ServiceController component is used to connect to an installed service and manipulate its state; using a ServiceController component, you can start and stop a service, pause and continue its functioning, and send custom commands to a service. Sin embargo, no es necesario usar un ServiceController componente cuando se crea una aplicación de servicio.However, you do not need to use a ServiceController component when you create a service application. De hecho, en la mayoría de los casos la ServiceController componente debe existir en una aplicación independiente de la aplicación de servicio de Windows que define el servicio.In fact, in most cases your ServiceController component should exist in a separate application from the Windows service application that defines your service.

Para obtener más información, consulta ServiceController.For more information, see ServiceController.

RequisitosRequirements

  • Servicios deben crearse en un servicio de Windows proyecto de aplicación o en otro proyecto compatible con .NET Framework que crea un archivo .exe cuando se compila y se hereda de la ServiceBase clase.Services must be created in a Windows Service application project or another .NET Framework–enabled project that creates an .exe file when built and inherits from the ServiceBase class.

  • Proyectos que contienen servicios de Windows deben tener componentes de instalación para el proyecto y sus servicios.Projects containing Windows services must have installation components for the project and its services. Esto puede realizarse fácilmente desde la propiedades ventana.This can be easily accomplished from the Properties window. Para obtener más información, consulte Cómo: agregar instaladores a la aplicación de servicio.For more information, see How to: Add Installers to Your Service Application.

Vea tambiénSee Also

Aplicaciones de servicios de WindowsWindows Service Applications
Arquitectura de programación de aplicaciones de servicioService Application Programming Architecture
Creación de servicios de WindowsHow to: Create Windows Services
Instalación y desinstalación de serviciosHow to: Install and Uninstall Services
Inicio de serviciosHow to: Start Services
Depuración de aplicaciones de servicios de WindowsHow to: Debug Windows Service Applications
Tutorial: Creación de una aplicación de servicios de Windows en el Diseñador de componentesWalkthrough: Creating a Windows Service Application in the Component Designer
Adición de instaladores a una aplicación de servicioHow to: Add Installers to Your Service Application