]>
Commit | Line | Data |
---|---|---|
b53d342f | 1 | # |
2 | # Conditional build: | |
3 | %bcond_without tests # do not perform "make test" | |
4 | # | |
5 | %define pdir Server | |
6 | %define pnam Starter | |
7 | %include /usr/lib/rpm/macros.perl | |
8 | Summary: Server::Starter - a superdaemon for hot-deploying server programs | |
9 | #Summary(pl.UTF-8): | |
10 | Name: perl-Server-Starter | |
11 | Version: 0.11 | |
12 | Release: 1 | |
13 | # same as perl | |
14 | License: GPL v1+ or Artistic | |
15 | Group: Development/Languages/Perl | |
16 | Source0: http://www.cpan.org/modules/by-module/Server/%{pdir}-%{pnam}-%{version}.tar.gz | |
17 | # Source0-md5: 037d75831a23ca76cd306d678b20332e | |
18 | #URL: http://search.cpan.org/dist/Server-Starter/ | |
19 | BuildRequires: perl-devel >= 1:5.8.0 | |
20 | BuildRequires: rpm-perlprov >= 4.1-13 | |
21 | # generic URL, check or change before uncommenting | |
22 | %if %{with tests} | |
23 | BuildRequires: perl-List-MoreUtils | |
24 | BuildRequires: perl-Proc-Wait3 | |
25 | BuildRequires: perl-Scope-Guard | |
26 | %endif | |
27 | BuildArch: noarch | |
28 | BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n) | |
29 | ||
30 | %description | |
31 | It is often a pain to write a server program that supports graceful | |
32 | restarts, with no resource leaks. Server::Starter, solves the problem | |
33 | by splitting the task into two. One is start_server, a script provided | |
34 | as a part of the module, which works as a superdaemon that binds to | |
35 | zero or more TCP ports or unix sockets, and repeatedly spawns the | |
36 | server program that actually handles the necessary tasks (for example, | |
37 | responding to incoming commenctions). The spawned server programs | |
38 | under Server::Starter call accept(2) and handle the requests. | |
39 | ||
40 | To gracefully restart the server program, send SIGHUP to the | |
41 | superdaemon. The superdaemon spawns a new server program, and if (and | |
42 | only if) it starts up successfully, sends SIGTERM to the old server | |
43 | program. | |
44 | ||
45 | By using Server::Starter it is much easier to write a hot-deployable | |
46 | server. Following are the only requirements a server program to be run | |
47 | under Server::Starter should conform to: | |
48 | ||
49 | - receive file descriptors to listen to through an environment | |
50 | variable | |
51 | - perform a graceful shutdown when receiving SIGTERM | |
52 | ||
53 | A Net::Server personality that can be run under Server::Starter exists | |
54 | under the name Net::Server::SS::PreFork. | |
55 | ||
56 | ||
57 | ||
58 | # %description -l pl.UTF-8 # TODO | |
59 | ||
60 | %prep | |
61 | %setup -q -n %{pdir}-%{pnam}-%{version} | |
62 | ||
63 | %build | |
64 | %{__perl} Makefile.PL \ | |
65 | INSTALLDIRS=vendor | |
66 | %{__make} | |
67 | ||
68 | %{?with_tests:%{__make} test} | |
69 | ||
70 | %install | |
71 | rm -rf $RPM_BUILD_ROOT | |
72 | ||
73 | %{__make} pure_install \ | |
74 | DESTDIR=$RPM_BUILD_ROOT | |
75 | ||
76 | %clean | |
77 | rm -rf $RPM_BUILD_ROOT | |
78 | ||
79 | %files | |
80 | %defattr(644,root,root,755) | |
81 | %doc Changes README | |
82 | %attr(755,root,root) %{_bindir}/start_server | |
83 | %{_mandir}/man1/start_server.1p* | |
84 | %{perl_vendorlib}/Server/*.pm | |
85 | %{_mandir}/man3/* |