win32_create_service Crea una nueva entrada para servicio en la base de datos SCM &reftitle.description; voidwin32_create_service arraydetails stringmachine&null; Intenta añadir un servicio en la base de datos SCM. Se necesitan privilegios de administrador para que esto tenga éxito. &reftitle.parameters; details Un array de detalles del servicio: service El nombre corto del servicio. Este es el nombre que se utilizará para controlar el servicio utilizando el comando net. El servicio debe ser único (dos servicios no pueden compartir el mismo nombre), e idealmente, debería evitar tener espacios en su nombre. display El nombre de visualización del servicio. Este es el nombre que se verá en la Applet Servicios. description La descripción larga del servicio. Esta es la descripción que se verá en la Applet de Servicios. user El nombre de usuario bajo el cual se desea que el servicio se ejecute. Si se omite, el servicio funcionará como LocalSystem. Si se especifica el nombre de usuario, también se debe proporcionar una contraseña. password La contraseña que corresponde a user. path La ruta completa al módulo ejecutable que se iniciará cuando el servicio se inicie. Si se omite, se utilizará la ruta del proceso actual de PHP. params Argumentos de comando a pasar al servicio cuando se inicie. Si se desea ejecutar un script PHP como servicio, entonces el primer argumento debería ser la ruta completa al script PHP que se planea ejecutar. Si el nombre del script o la ruta contienen espacios, entonces, rodee la ruta completa del script PHP con " load_order Controla el load_order. Esto aún no está completamente soportado. svc_type Establece el tipo de servicio. Si se omite, el valor por omisión es WIN32_SERVICE_WIN32_OWN_PROCESS. No se debe cambiar esto a menos que se sepa realmente lo que se está haciendo. start_type Especifica cómo debe iniciarse el servicio. El valor por omisión es WIN32_SERVIDE_AUTO_START lo que significa que el servicio se iniciará cuando la máquina se inicie. error_control Informa al SCM sobre qué hacer cuando detecte un problema con el servicio. El valor por omisión es WIN32_SERVER_ERROR_IGNORE. Cambiar este valor aún no está completamente soportado. delayed_start Si delayed_start está establecido a &true;, entonces informará al SCM que este servicio debe iniciarse después de los servicios iniciados automáticamente y un cierto retraso. Cualquier servicio puede ser marcado como un servicio retrasado después del inicio automático; sin embargo, esta configuración no tiene ningún efecto mientras el parámetro start_type del servicio valga WIN32_SERVICE_AUTO_START. Esta configuración solo se aplica en Windows Vista y servidores Windows 2008 y posteriores. base_priority Para reducir el impacto en el uso del procesador, puede ser necesario establecer una prioridad más baja que la normal. El parámetro base_priority puede ser establecido a una de las constantes definidas en las clases de baja prioridad Win32. dependencies Para definir las dependencias del servicio, es necesario establecer este parámetro con la lista de nombres de servicios en un array. recovery_delay Este parámetro define el retraso entre el fallo y la ejecución de la acción de recuperación. El valor es en milisegundos. El valor por omisión es 60000. recovery_action_1 La acción que se ejecutará en caso de la primera falla. La acción por omisión es WIN32_SC_ACTION_NONE. El parámetro recovery_action_1 puede ser establecido con una de las constantes definidas en las Acciones de recuperación Win32. recovery_action_2 La acción que se ejecutará en caso de la segunda falla. La acción por omisión es WIN32_SC_ACTION_NONE. El parámetro recovery_action_2 puede ser establecido con una de las constantes definidas en las Acciones de recuperación Win32. recovery_action_3 La acción que se ejecutará en caso de fallas subsiguientes. La acción por omisión es WIN32_SC_ACTION_NONE. El parámetro recovery_action_3 puede ser establecido con una de las constantes definidas en las Acciones de recuperación Win32. recovery_reset_period El contador de fallas se reiniciará después del retraso definido en este parámetro. El retraso se expresa en segundos. El valor por omisión es 86400. recovery_enabled Establecer este parámetro a &true; para habilitar las opciones de recuperación, y &false; para deshabilitarlas. El valor por omisión es &false; recovery_reboot_msg Añadir este parámetro para definir el mensaje registrado en el registro de eventos de Windows antes del reinicio. Solo se utiliza si una de las acciones está definida a WIN32_SC_ACTION_REBOOT. recovery_command Añadir este parámetro para definir el comando a ejecutar cuando una acción está definida a WIN32_SC_ACTION_RUN_COMMAND. machine El nombre opcional de la máquina en la que se desea crear el servicio. Si se omite, se utilizará la máquina local. &reftitle.returnvalues; &return.void; Antes de la versión 1.0.0, &win32service.noerror.false.error; &reftitle.errors; Se lanzará una ValueError si el valor del parámetro service está vacío. Se lanzará una ValueError si el valor del parámetro path está omitido o vacío. Se lanzará una ValueError si el valor del parámetro svc_type es incorrecto. Se lanzará una ValueError si el valor del parámetro start_type es incorrecto. Se lanzará una ValueError si el valor del parámetro error_control es incorrecto. Se lanzará una ValueError si el valor del parámetro base_priority es incorrecto. Se lanzará una ValueError si el valor del parámetro recovery_delay no está entre 0 y PHP_INT_MAX. Se lanzará una ValueError si el valor del parámetro recovery_action_1 es incorrecto. Se lanzará una ValueError si el valor del parámetro recovery_action_2 es incorrecto. Se lanzará una ValueError si el valor del parámetro recovery_action_3 es incorrecto. Se lanzará una ValueError si el valor del parámetro recovery_reset_period no está entre 0 y PHP_INT_MAX. Se lanzará una Win32ServiceException en caso de error. &reftitle.changelog; &Version; &Description; PECL win32service 1.0.0 Se lanzará una ValueError si un parámetro es inválido, antes &false; era devuelto. PECL win32service 1.0.0 Se lanzará una Win32ServiceException en caso de error, antes un Código de error Win32 era devuelto. PECL win32service 1.0.0 El tipo de retorno ahora es void, antes era mixed. PECL win32service 0.4.0 Los parámetros dependencies, recovery_delay, recovery_action_1, recovery_action_2, recovery_action_3, recovery_reset_period, recovery_enabled, recovery_reboot_msg y recovery_command han sido añadidos. &reftitle.examples; Ejemplo con <function>win32_create_service</function> Crea un servicio cuyo nombre corto es 'dummyphp'. 'dummyphp', // el nombre del servicio 'display' => 'ejemplo de servicio PHP ficticio', // la descripción corta 'description' => 'Este es un servicio Windows creado utilizando PHP', // la descripción larga 'params' => '"' . __FILE__ . '" run', // ruta al script así como los argumentos )); debug_zval_dump(\$x); ?> ]]> Un ejemplo <function>win32_create_service</function> con dependencias Crea un servicio cuyo nombre corto es 'dummyphp' con dependencias. 'dummyphp', // El nombre del servicio 'display' => 'ejemplo de servicio PHP ficticio', // Una descripción corta 'description' => 'Este es un servicio Windows creado utilizando PHP.', // Una descripción larga 'params' => '"' . __FILE__ . '" run', // ruta al script así como los argumentos 'dependencies' => array("Netman"), // La lista de dependencias )); debug_zval_dump(\$x); ?> ]]> Ejemplo de <function>win32_create_service</function> con opciones de recuperación Crea un servicio cuyo nombre corto es 'dummyphp' con opciones de recuperación. 'dummyphp', // El nombre del servicio 'display' => 'ejemplo de servicio PHP ficticio', // Una descripción corta 'description' => 'Este es un servicio Windows creado utilizando PHP.', // Una descripción larga 'params' => '"' . __FILE__ . '" run', // ruta al script así como los argumentos 'recovery_delay' => 120000, // Las acciones de recuperación se ejecutarán después de 2 minutos 'recovery_action_1' => WIN32_SC_ACTION_RESTART, // Primera falla, reiniciar el servicio 'recovery_action_2' => WIN32_SC_ACTION_RUN_COMMAND, // Segunda falla, ejecutar un comando 'recovery_action_3' => WIN32_SC_ACTION_NONE, // Fallas subsiguientes, no hacer nada 'recovery_reset_period' => 86400, // Reiniciar el contador de fallas después de 1 día (86400 minutos) 'recovery_enabled' => true, // Habilitar las opciones de recuperación 'recovery_reboot_msg' => null, // No definir un mensaje de reinicio, no es útil. 'recovery_command' => "c:\clean-service.bat", // Cuando la acción es WIN32_SC_ACTION_RUN_COMMAND, ejecutar este comando. )); debug_zval_dump(\$x); ?> ]]> &reftitle.seealso; win32_delete_service Las clases de baja prioridad Win32 Las acciones de recuperación Win32 Los códigos de error Win32