NAME
Module::Build::Service::Fork - Role for process handling in service implementations
VERSION
version 0.90
SYNOPSIS
package Module::Build::Service::foo;
use Moo;
extends 'Module::Build::Service::Base';
with 'Module::Build::Service::Fork';
sub _build_command {
my ($self) = @_;
[$self->bin, qw{-f flag1 -g flag2 -h}];
}
sub _build_log { ',,foo.log' }
sub _build_executable { 'foo' }
DESCRIPTION
This is a role that tries to factor out a lot of boilerplate in defining services that involve forking an executable to run the service.
ATTRIBUTES
bin
The full path to the binary executable for starting the service.
If this is not specified, we search for executable in path.
command
The command-line for the executable. Each class including the role must define it, as there is no sensible default.
executable
The bare name of the executable that is run to start the service. Defaults to service_name
.
If you specify bin
directly (either in a parameter to new
, or by overriding _build_bin), you don't actually need to specify this unless you use it yourself, as it is only used when trying to generate bin automatically.
path
The list of directories in which we should search for the executable. The default is /usr/sbin
and /usr/local/sbin
.
If you specify bin
directly (either in a parameter to new
, or by overriding _build_bin), you don't actually need to specify this unless you use it yourself, as it is only used when trying to generate bin automatically.
METHODS
start_service
A default implementation of start_service
that starts the contents of command
.
stop_service
A default implementation of stop_service
that just terminates the child process. Generally adequate. It can be overridden or modified as appropriate.
AUTHOR
Michael Alan Dorman <mdorman@ironicdesign.com>
COPYRIGHT AND LICENSE
This software is copyright (c) 2012 by Ironic Design, Inc..
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.