Nginx-ru mailing list archive (nginx-ru@sysoev.ru)
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: Chtobi eto znachilo !?
On Sat, Mar 08, 2008 at 03:17:46PM +0300, Igor Sysoev wrote:
> On Sat, Mar 08, 2008 at 12:36:42PM +0300, Igor Sysoev wrote:
>
> > On Fri, Mar 07, 2008 at 11:58:14AM +0200, Aleksej Novikov wrote:
> >
> > > Posle upgrade na linux-2.6.24-3, takaja vot lazha stala v dmesg
> > > pojavljatsa.
> > >
> > > >warning: process `nginx' used the deprecated sysctl system call with
> > > >1.33.
> > > >warning: process `nginx' used the deprecated sysctl system call with
> > > >1.33.
> > >
> > > Kernel otkompiljon s SMP , optimizacija dlja Old XEON,
> > > sam servak DualCore DualXeon esli eto vazhno.
> > >
> > > Eto chtoto serjoznoe ?
> >
> > Нет. sysctl используется для rtsig.
> >
> > Прилагаемый патч добавляет параметр
> > --without-rtsig_module
> > который имеет смысл использовать на современных 2.6 ядрах.
>
> Второй вариант, который мне больше нравится, - собирать rtsig по умолчанию
> только на ядрах >= 2.2.19 и < 2.6.18, поскольку rtsig потерял актуальность
> с появлением epoll.
Новый патч.
--
Игорь Сысоев
http://sysoev.ru
Index: src/os/unix/ngx_linux_init.c
===================================================================
--- src/os/unix/ngx_linux_init.c (revision 1239)
+++ src/os/unix/ngx_linux_init.c (working copy)
@@ -11,7 +11,7 @@
u_char ngx_linux_kern_ostype[50];
u_char ngx_linux_kern_osrelease[50];
-int ngx_linux_rtsig_max;
+int ngx_linux_rtsig_max;
static ngx_os_io_t ngx_linux_io = {
@@ -32,9 +32,6 @@
ngx_int_t
ngx_os_specific_init(ngx_log_t *log)
{
- int name[2];
- size_t len;
- ngx_err_t err;
struct utsname u;
if (uname(&u) == -1) {
@@ -48,6 +45,12 @@
(void) ngx_cpystrn(ngx_linux_kern_osrelease, (u_char *) u.release,
sizeof(ngx_linux_kern_osrelease));
+#if (NGX_HAVE_RTSIG)
+ {
+ int name[2];
+ size_t len;
+ ngx_err_t err;
+
name[0] = CTL_KERN;
name[1] = KERN_RTSIGMAX;
len = sizeof(ngx_linux_rtsig_max);
@@ -65,6 +68,8 @@
ngx_linux_rtsig_max = 0;
}
+ }
+#endif
ngx_os_io = ngx_linux_io;
@@ -78,6 +83,8 @@
ngx_log_error(NGX_LOG_NOTICE, log, 0, "OS: %s %s",
ngx_linux_kern_ostype, ngx_linux_kern_osrelease);
+#if (NGX_HAVE_RTSIG)
ngx_log_error(NGX_LOG_NOTICE, log, 0, "sysctl(KERN_RTSIGMAX): %d",
ngx_linux_rtsig_max);
+#endif
}
Index: auto/os/linux
===================================================================
--- auto/os/linux (revision 1239)
+++ auto/os/linux (working copy)
@@ -22,9 +22,10 @@
version=${version:-0}
-# enable the rt signals on Linux 2.2.19 and onward
+# enable the rt signals on Linux between 2.2.19 and 2.6.17
-if [ $version -ge 131609 -o $EVENT_RTSIG = YES ]; then
+if [ \( $version -ge 131609 -a $version -lt 132632 \) -o $EVENT_RTSIG = YES ]
+then
echo " + rt signals found"
have=NGX_HAVE_RTSIG . auto/have
have=NGX_HAVE_POLL . auto/have
|