<
title>�ϵ����� �ü���� ���ؼ�</
title>
<
p>������ ���ɿ� ���� ū ������ �ִ� ���� ��. ������
��û�� �����ð��� ����ڰ� "����� ��ٰ�" ������ ���ϰ�
�ø������ �������� ������ �ϸ� �ȵȴ�. �������� ����ڴ�
�����ϰ� �ٽ� �����Ͽ� ���ϰ� ��� �����Ѵ�. <
directive module="mpm_common">MaxClients</
directive> ���þ �����Ͽ�
�������� ������ �� ������ ���� �ڽ��� �������ʵ��� �ؾ�
�Ѵ�. ����� �����ϴ�: <
code>top</
code>�� ���� ��������
���μ��� ����� ���� ����ġ ���μ����� ��� �� ��뷮��
�˾Ƴ���, ��ü ��밡���� ���� �ٸ� ���μ������� �����
���� �� ������ ������.</
p>
<
p>�������� ����ϴ�: ����� �� CPU, ����� �� ��Ʈ��ī��,
����� �� ��ũ, ���⼭ "����� ��"�� ������ �ؼ� �����ؾ�
<
p>�ü���� ���� ���� �˾Ƽ� ������ ���̴�. ���� �Ϲ�������
�����ϴٰ� �Ǹ�� ��� ��ħ�� �ִ�:</
p>
<
p>������ �ü���� �ֽ� ���� ����� ��ġ�� �����Ѵ�.
���� �ü�� ���ۻ�� �ֱ� TCP ���ð� ������ ���̺귯����
<
p>�ü���� <
code>sendfile(2)</
code> �ý���ȣ����
�����Ѵٸ�, �̸� ����ϱ����� �����̳� ��ġ�� ��ġ�Ͽ�����
Ȯ���Ѵ�. (���� ���, ��������� 2.4 �̻� ������ ���Ѵ�.
Solaris 8 �ʱ� ������ ��ġ�� �ʿ��ϴ�.) �����ϴ� �ý����̶��
����ġ 2�� <
code>sendfile</
code>�� ����Ͽ� CPU�� ��
����ϸ� ���� ������ �� ���� ����� �� �մ�.</
p>
<
title>����� ������ ���ؼ�</
title>
<
module>mpm_common</
module>
<
module>mod_status</
module>
<
directive module="core">AllowOverride</
directive>
<
directive module="mod_dir">DirectoryIndex</
directive>
<
directive module="core">HostnameLookups</
directive>
<
directive module="core">EnableMMAP</
directive>
<
directive module="core">EnableSendfile</
directive>
<
directive module="core">KeepAliveTimeout</
directive>
<
directive module="prefork">MaxSpareServers</
directive>
<
directive module="prefork">MinSpareServers</
directive>
<
directive module="core">Options</
directive>
<
directive module="mpm_common">StartServers</
directive>
<
title>HostnameLookups�� DNS�� ���� ����� ����</
title>
<
p>����ġ 1.3 ���� <
directive module="core">HostnameLookups</
directive>�� �⺻����
<
code>On</
code>�̿���. ��û�� ��ġ���� DNS �˻��� ������
�ϹǷ� ��û���� ������ ����. ����ġ 1.3���� �� ������
�⺻���� <
code>Off</
code>�� ����Ǿ��. �α������� �ּҸ�
ȣ��Ʈ������ ��ȯ�Ϸ��� ���� �α�ó�� ���α��� �ϳ���,
<
p>�α�ó�� �۾��� ���� ���ɿ� �ǿ����� ��ġ�Ƿ� ����
����ϴ� �������� �ƴ� �ٸ� ��ǻ�Ϳ��� �α������� ��ó���ϱ�
<
p><
code><
directive module="mod_access">Allow</
directive>
from domain</
code>�̳� <
code><
directive module="mod_access">Deny</
directive> from domain</
code>
���þ ����Ѵٸ� (��, IP �ּҰ� �ƴ� ȣ��Ʈ���̳� �����θ���
����Ѵٸ�) �ε��� �ߺ�-�� DNS �˻��� (���˻��� ���� ���Ƿ�
����Ǿ���� Ȯ���ϱ����� �ٽ� �˻�) �ؾ� �Ѵ�. ���Ƿ�
������ ���̱����� �̷� ���þ�� �����ϸ� �̸���� IP
<
p><
code><Location /server-status></
code> ���� ������
���þ��� �������� ������ �� ������ ����϶�. �� ���
���ǿ� �´� ��û���� DNS ��ȸ�� �Ѵ�. ������
<
code>.html</
code>�� <
code>.cgi</
code> ���ϸ� DNS �˻���
HostnameLookups off<
br />
<Files ~ "\.(html|cgi)$"><
br />
<
p>���� CGI���� DNS���� �ʿ��� ���̶��, �ʿ��� Ư��
CGI������ <
code>gethostbyname</
code> ȣ���� �ϵ��� ����غ�
<
title>FollowSymLinks�� SymLinksIfOwnerMatch</
title>
<
p>URL ���� <
code>Options FollowSymLinks</
code>��
��������ʰ� <
code>Options SymLinksIfOwnerMatch</
code>��
����ϸ� ����ġ�� �ɺ���ũ�� �˻��ϱ����� �ý���ȣ����
�ѹ� �� �ؾ� �Ѵ�. ���ϸ��� �� �κи��� �ѹ� �� ȣ����
�Ѵ�. ���� ���, ������ ������ ����:</
p>
<Directory /><
br />
Options SymLinksIfOwnerMatch<
br />
<
p><
code>/
index.html</
code> URI�� ���� ��û�� �ִٰ� ��������.
���� ����ġ�� <
code>/www</
code>, <
code>/
www/
htdocs</
code>,
<
code>lstat(2)</
code>�� ȣ���Ѵ�. <
code>lstats</
code>
��� ij������ �ʱ���� ��û�� ���� ������ �Ź� ����
�۾��� �Ѵ�. ��¥ �ɺ���ũ ���� �˻縦 ���Ѵٸ� ������
<Directory /><
br />
Options FollowSymLinks<
br />
Options -FollowSymLinks +SymLinksIfOwnerMatch<
br />
<
p>�� ��� �ּ��� <
directive module="core">DocumentRoot</
directive> ��δ� �˻�����
�ʴ´�. DocumentRoot �ۿ� �ִ� ��η� <
directive module="mod_alias">Alias</
directive>�� <
directive module="mod_rewrite">RewriteRule</
directive>�� �����
��쿡�� ���� ����� ������ �ʿ��ϴ�. �ɺ���ũ ������
������� �ʰ� �ְ��� ������ ��������,
<
code>FollowSymLinks</
code>�� �����ϰ�,
<
code>SymLinksIfOwnerMatch</
code>�� ���� �ȵȴ�.</
p>
<
title>AllowOverride</
title>
<
p>URL ���� overrides�� ����Ѵٸ� (����
<
code>.htaccess</
code> ����) ����ġ�� ���ϸ��� �� �κи���
<
code>.htaccess</
code>�� ���� �õ��Ѵ�. ���� ���,</
p>
<Directory /><
br />
<
p><
code>/
index.html</
code> URI�� ���� ��û�� �ִٰ� ��������.
����ġ�� <
code>/.htaccess</
code>, <
code>/
www/
.htaccess</
code>,
�ذ�å�� ���� <
code>Options FollowSymLinks</
code> ����
����ϴ�. �ְ��� ������ �������� ���Ͻý��ۿ� ���ؼ� ��
<
code>AllowOverride None</
code>�� ����Ѵ�.</
p>
<
section id="negotiation">
<
p>�����ϰ� ��¥ ������ ������� ����� �ִٸ� ���������
���´�. ������ ����� �̵��� �������Ϻ��� �۴�. ������
��� �� �� �ִ�. ������ ���� ���ϵ�ī�带 ����ϴ� ���:</
p>
<
p>������ ����� ����Ѵ�:</
p>
<
p>���� ���� ���� �տ� �д�.</
p>
<
p>��, ���丮���� ���ϵ��� ã�� <
code>MultiViews</
code>
���ٴ�, �� ���ϸ� ������ �ʿ��� ������ ���� �� �ִ�
<
code>type-map</
code> ������ ���� ����� ���� �� ����
<
p>����Ʈ�� ��������� �ʿ��ϴٸ� ����� ���� <
code>Options
MultiViews</
code> ���þ ����ϱ⺸�� <
code>type-map</
code>
������ ����϶�. ����� ���� �ڼ��� �����
<
code>type-map</
code> ������ ����� ����� <
a <
title>���� (memory-mapping)</
title>
<
p>���� ���, server-side-include�� ó���ϴ� �� ����ġ
2.0�� ����� ������ ������ �ü���� <
code>mmap(2)</
code>
���� �����Ѵٸ� ������ �����Ѵ�.</
p>
<
p>���� �÷��� ������ ������ ����Ѵ�. ����
������ ������ ������ ����Ʈ���� ������ ��������
<
p>� �ü������ <
code>mmap</
code>�� CPU ������
������ <
code>read(2)</
code> ��ŭ Ȯ�强�� ���� �ʴ�.
���� ���, �������μ��� Solaris �������� ����ġ 2.0��
���� <
code>mmap</
code>�� ������� ������ ������ ��
������ �� ���� ����Ѵ�.</
p>
<
p>NFS ����Ʈ�� ���Ͻý��ۿ� �ִ� ������ �����ϴ�
���߿� �ٸ� NFS Ŭ���̾�Ʈ�� �ִ� ���μ����� ������
����ų� ����ũ�⸦ ���̸�, ������ ���μ����� ����
�� ������ ���ϳ����� ������ bus error�� ����
<
p>���� ���ǿ� �ش��ϸ� ����ϴ� ������ ��������
�ʵ��� <
code>EnableMMAP off</
code>�� ����ؾ� �Ѵ�. (����:
�� ���þ�� ���丮���� ������ �� �ִ�.)</
p>
<
p>����ġ�� �ü���� <
code>sendfile(2)</
code>�� �����ϸ�
Ŀ�� sendfile�� ����Ͽ� -- ���� ���, ���� ������ �����Ҷ�
-- ����� ������ ���� �������� �� �ִ�.</
p>
<
p>���� �÷��� sendfile�� ����ϸ� read�� send�� ���
�� �ʿ䰡 �� �������. ���� sendfile�� ����ϸ�
�������� �������� ��ġ�ԵǴ� ��찡 �ִ�:</
p>
<
p>sendfile ������ �߸�Ǿ�� ������ �ý����� ������
�߰����� ���ϴ� �÷����� �ִ�. Ư�� �ٸ� ��ǻ�Ϳ���
���������� �������Ͽ� sendfile ������ �߸�� ��ǻ�ͷ�
<
p>Ŀ���� �ڽ��� ij���� ����Ͽ� NFS�� ����Ʈ�� ������
���������� ������ �� ��� ��찡 �ִ�.</
p>
<
p>���� ���ǿ� �ش��ϸ� ������ sendfile ������� �ʵ���
<
code>EnableSendfile off</
code>�� ����ؾ� �Ѵ�. (����:
�� ���þ�� ���丮���� ������ �� �ִ�.)</
p>
<
title>����� ��</
title>
<
p>����ġ 1.3 ����� <
directive module="prefork">MinSpareServers</
directive>, <
directive module="prefork">MaxSpareServers</
directive>, <
directive module="mpm_common">StartServers</
directive> ������ ���
��ġ��ũ ��� ū ������ ���ƴ�. Ư�� ����ġ�� �۾���
�����ϱ����� ����� �ڽļ��� �ٴٸ� ������ "����" �Ⱓ��
module="mpm_common">StartServers</
directive>�� �ڽ���
������, <
directive module="prefork">MinSpareServers</
directive>
���������� �ʴ� �ڽ��� �ϳ��� ������. ���� <
directive module="mpm_common">StartServers</
directive> �⺻����
<
code>5</
code>�� ������ Ŭ���̾�Ʈ 100���� ���ÿ� �����ϸ�
���ϸ� ó���ϱ ����� �ڽ��� �������� 95�ʰ� �ɷȴ�.
���� ��������� �ʴ� ���� ���������� �� ����������, 10�а���
�����ϴ� ��ġ��ũ ���� �ſ� ���ڰ� ���´�.</
p>
<
p>�ʴ� �Ѱ� ��Ģ�� �ڽ��� ���� �����ϸ鼭 ������ ������
���� �������� ���ߴ�. ��ǻ�Ͱ� �ڽ��� �����ϴ��� �ٻڸ�
��û�� ������ �� ���. ���� �� ��Ģ�� ����ġ�� ü��
���ɿ� �ǿ����� �־� �����Ͽ���. ����ġ 1.3���� �ʴ� �Ѱ�
��Ģ�� ��ȭ�Ǿ��. �ڵ�� �ڽ� �Ѱ��� �����, 1�� ����,
�ΰ��� �����, 1�� ����, �װ��� �����, �̷� ������ �ʴ�
�ڽ��� 32�� ���鶧���� ������ �����Ѵ�. �ڽļ��� <
directive module="prefork">MinSpareServers</
directive> ������ �ٴٸ���
<
p>�� ��� �����ӵ��� �������� <
directive module="prefork" >MinSpareServers</
directive>, <
directive module="prefork" >MaxSpareServers</
directive>, <
directive module="mpm_common" >StartServers</
directive>�� ���� ������ �ʿ䰡 ���. ���ʿ�
�ڽ��� 4�� �̻� ���ϸ� <
directive module="core">ErrorLog</
directive>�� ����Ѵ�. �̷� ������
���� ���̸� �� �������� �����ϱ� �ٶ���.
<
module>mod_status</
module> ��� ������ �� ���̴�.</
p>
<
p>���μ��� ��� ����Ͽ� <
directive module="mpm_common">MaxRequestsPerChild</
directive> ������
���μ����� �����Ѵ�. �⺻���� �ڽĴ� ó���� ��û���� ������
��ٴ� <
code>0</
code>�̴�. ���� ������ <
code>30</
code>��
���� �ſ� ���� ������ �������ִٸ�, ���� ����� ���� �ʿ䰡
�ִ�. SunOS�� ������ Solaris ������ ����Ѵٸ�, ���������
�� ���� <
code>10000</
code> ������ �����϶�.</
p>
<
p>��������(keep-alive)�� ����Ѵٸ� �ڽĵ��� �̹� ����
���ῡ�� �߰� ��û�� ��ٸ��� �ƹ��͵� �����ʱ���� ���
�ٻڴ�. <
directive module="core">KeepAliveTimeout</
directive>��
�⺻�� <
code>15</
code> �ʴ� �̷� ������ �ּ�ȭ�Ѵ�. ��Ʈ��
�뿪��� ���� �ڿ� ���� ������ �°� �����Ѵ�. <
a ���������� ���� ������ ����������</
a> � ��쿡��
�� ���� <
code>60</
code> �� �̻����� �ø��� ����.</
p>
<
section id="compiletime">
<
title>�����Ͻ� ������ ���ؼ�</
title>
(MPMs)�̶�� ��ü�� �� �ִ� ����ȭ ���� �����Ѵ�. ����ġ��
�������Ҷ� MPM�� �����ؾ� �Ѵ�. <
module>beos</
module>,
<
module>mpm_netware</
module>, <
module>mpmt_os2</
module>,
<
module>mpm_winnt</
module>�� ���� Ư�� �÷����� �����
�� �ִ� MPM�� �ִ�. �Ϲ����� ���н��� �ý����� ���� MPM
�߿� �ϳ��� ������ �� �ִ�. �������� �ӵ���
Ȯ�强(scalability)�� � MPM�� �����߳Ŀ� �ȴ�:</
p>
<
li><
module>worker</
module> MPM�� ���� �ڽ� ���μ�����
���� ���� �����带 ����Ѵ�. �� ������� �ѹ� �� ������
����Ѵ�. �Ϲ������� worker�� prefork MPM ���� ����
�� ����ϹǷ� ��ŷ��� ���� ������ �����ϴ�.</
li>
<
li><
module>prefork</
module> MPM�� �����尡 �Ѱ��� �ڽ�
���μ����� ������ ����Ѵ�. �� ���μ����� �ѹ� ��
������ ����Ѵ�. ���� �ý��ۿ��� prefork�� �ӵ��� worker��
���������, �� ���� �� ����Ѵ�. ������ ���� ��Ȳ����
�����带 ������� �ʴ� prefork ����� worker�� ����
������ �����: �����忡 �������� (thread-safe) ����
�����ڰ� ���� ����� ����� �� �ְ�, ������ ����� ������
����� �÷��� ���� ������� �� �ִ�.</
li>
<
p>�� MPM��� �ٸ� MPM�� ���� �� �ڼ��� ������ MPM <
a href="/mpm.html">����</
a>�� ����ϱ� �ٶ���.</
p>
<
p>�� ��뷮�� ���ɿ��� ���� �߿��� �����̱����
������ ������� �ʴ� ����� �����غ���. ����� <
a href="/dso.html">DSO</
a>�� �������ߴٸ� ������ ��
module="mod_so">LoadModule</
directive> ���þ �ּ�ó���ϸ�
�ȴ�. ���� ����� �����ϰ� �����Ͽ� ����Ʈ�� �����̵�
���������� �����ϴ��� ���캼 �� �ִ�.</
p>
<
p>�ݴ�� ����� ����ġ �������Ͽ� �������� ��ũ���ִٸ�
������ �ʴ� ����� �����ϱ����� ����ġ�� ���������ؾ�
<
p>���⼭ �翬�� � ����� ����ϰ� ������� ����
�ǹ��� ����. ������ ������Ʈ���� �ٸ���. ���� �Ƹ���
<
em>�ּ���</
em> <
module>mod_mime</
module>,
<
module>mod_dir</
module>, <
module>mod_log_config</
module>
����� ����� ���̴�. ���� ������Ʈ�� �α������� �ʿ��ٸ�
<
code>mod_log_config</
code>�� �� �ȴ�. ���� ��õ����
<
title>Atomic ���</
title>
<
p><
module>mod_cache</
module> ���� ���� �ֱ� ��������
worker MPM�� APR�� atomic API�� ����Ѵ�. �� API�� �淮��
������ ����ȭ�� ���� atomic ����� �����Ѵ�.</
p>
<
p>�⺻������ APR�� �� �ü��/CPU �÷��� ���� ȿ������
����� ����Ͽ� �� ����� �����Ѵ�. ���� ���, ���� �ֽ�
CPU���� �ϵ����� atomic compare-and-swap (CAS) ������
�ϴ� ��ɾ �ִ�. ���� � �÷��� APR�� �̷�
��ɾ ��� ������ CPU�� ȣȯ���� ���� �� ���� mutex���
������ �⺻������ ����Ѵ�. �̷� �÷��� ����ġ��
�������Ҷ� ����ġ�� �ֽ� CPU������ ������ ��ȹ�̶��,
����ġ�� �����Ҷ� <
code>--enable-nonportable-atomics</
code>
�ɼ��� ����Ͽ� �� �� atomic ������ ������ �� �ִ�:</
p>
/
configure --with-mpm=worker --enable-nonportable-atomics=yes
<
p><
code>--enable-nonportable-atomics</
code> �ɼ��� ������
���� �÷��� ������ �ִ�:</
p>
<
li>SPARC���� Solaris<
br />
<
code>--enable-nonportable-atomics</
code>�� ����ϸ�
APR�� �� �ϵ���� compare-and-swap�� ���� SPARC
v8plus ��ɾ ����Ѵ�. �� �ɼ��� ����ϸ� atomic
����� �� ȿ���������� (CPU�� �� ����ϰ� �� ����
����ȭ�� �����ϴ�), �������� ���������� UltraSPARC
�⺻������ APR�� ���������� mutex��� atomic��
<
code>--enable-nonportable-atomics</
code>�� ����ϸ�
APR�� �� �ϵ���� compare-and-swap�� ���� 486
��ɾ ����Ѵ�. �� ȿ������ atomic ����� ����������,
�������� ���������� 486 �̻� Ĩ������ (386�� �ȵȴ�)
<
title>mod_status�� ExtendedStatus On</
title>
<
p>����ġ�� �������Ҷ� <
module>mod_status</
module>�� �����ϰ�
�����Ҷ� <
code>ExtendedStatus On</
code>�� �����ϸ� ����ġ��
��û�� ���������� <
code>gettimeofday(2)</
code>(Ȥ�� �ü����
��� <
code>times(2)</
code>)�� �ι� ȣ���ϰ� (1.3 �����)
<
code>time(2)</
code>�� �߰��� ������ ȣ���Ѵ�. ���� ���?��
���۽ð��� �ʿ��ϱ� �����̴�. �ֻ��� ������ ��������
(�⺻����) <
code>ExtendedStatus off</
code>�� �����Ѵ�.</
p>
<
title>accept ����ȭ - ���� ����</
title>
<
note type="warning"><
title>����:</
title>
<
p> �Ʒ� ������ ����ġ ������ 2.0 ���� ����� ������
��� ���� �ʴ�. ������ ��ȿ�� ������ ������, �����ؼ�
<
p>���н� ���� API�� ������ �����Ѵ�. �������� ���� ��Ʈ
Ȥ�� ���� �ּҸ� ��ٸ������� ���� <
directive module="mpm_common">Listen</
directive>�� ����Ѵٰ� ��������.
������ �������� �� ������ �˻��ϱ����� ����ġ��
<
code>select(2)</
code>�� ����Ѵ�. <
code>select(2)</
code>��
���Ͽ� ��ٸ��� �ִ� ������ <
em>�����</
em> Ȥ�� <
em>�ּ���
�Ѱ�</
em> �ִ��� �˷��ش�. ����ġ���� ���� �ڽ��� �ְ�,
���� �ִ� ��� �ڽ��� ���ÿ� ���ο� ������ �˻��Ѵ�. ��
������ ������ ����ϴ� (�� ���� �ڵ忡�� �������� �ʾҴ�.
���� �����ϱ����� �뵵�� ������.):</
p>
FD_ZERO (&accept_fds);<
br />
for (i = first_socket; i <= last_socket; ++i) {<
br />
FD_SET (i, &accept_fds);<
br />
rc = select (last_socket+1, &accept_fds, NULL, NULL, NULL);<
br />
if (rc < 1) continue;<
br />
new_connection = -1;<
br />
for (i = first_socket; i <= last_socket; ++i) {<
br />
if (FD_ISSET (i, &accept_fds)) {<
br />
new_connection = accept (i, NULL, NULL);<
br />
if (new_connection != -1) break;<
br />
if (new_connection != -1) break;<
br />
process the new_connection;<
br />
<
p>���� ���� �ܼ��� �������� �ɰ��� �?(starvation)
������ �ִ�. ���� �ڽ��� ���ÿ� �� �ݺ����� �����ϸ�,
��û�� ��ٸ��� ��� <
code>select</
code>���� �����. �̶�
� ���Ͽ� ��û�� �ϳ��� ������ ��� �ڽ��� ����
(���� �ڽ��� ������ �ü���� Ÿ�ֿ̹� ��� �ٸ���).
�̵��� ��� ������ <
code>accept</
code>�ϱ� �õ��Ѵ�. ����
(������ �� ���Ḹ ������̶��) �� �ڽĸ� �����ϰ�, ��������
<
code>accept</
code>���� <
em>�����.</
em> ���� �� �ڽĵ���
�� ������ ��û���� �����ϵ��� ������, �� �������� ���ο�
��û�� ����� ���ͼ� ��� �ڽ��� ��ﶧ���� �������ִ�.
ó�� ����Ǿ��. �ּ��� �ΰ��� �ذ�å�� �ִ�.</
p>
<
p>�Ѱ����� ������ ������� �ʵ��� (non-blocking) �����
����̴�. �� ��� �ڽ��� <
code>accept</
code>�� �ص� ������
�ʰ�, ��� ������ �� �ִ�. ���� CPU �ð��� �����Ѵ�.
<
code>select</
code>���� ���� �ڽ��� 10�� �ְ�, ���� ������
�Ѱ� ���Դٰ� ��������. ���� �� �ڽ��� 9���� ����
������ <
code>accept</
code>�ϱ� �õ��ϰ� �����ϸ� �ƹ�
�ϵ� ���� �ʰ� �ٽ� <
code>select</
code>�� �ݺ��Ѵ�. �ٽ�
<
code>select</
code>�� ���ƿ� ������ � �ڽĵ� �ٸ� ���Ͽ�
���� ��û�� �������� �ʴ´�. (�������μ��� ��ǻ�Ϳ���)
���� �ڽ� ������ŭ CPU ������ �ִ� �幮 ��찡 �ƴ϶��
�� �ذ�å�� ���� ���ƺ����� �ʴ´�.</
p>
<
p>�ٸ� ����� ����ġ�� ����ϴ� ������� ���� �ݺ�����
�� �ڽĸ��� �鿩������. �ݺ����� ������ ���� (���̸�
<
strong>accept_mutex_on ();</
strong><
br />
FD_ZERO (&accept_fds);<
br />
for (i = first_socket; i <= last_socket; ++i) {<
br />
FD_SET (i, &accept_fds);<
br />
rc = select (last_socket+1, &accept_fds, NULL, NULL, NULL);<
br />
if (rc < 1) continue;<
br />
new_connection = -1;<
br />
for (i = first_socket; i <= last_socket; ++i) {<
br />
if (FD_ISSET (i, &accept_fds)) {<
br />
new_connection = accept (i, NULL, NULL);<
br />
if (new_connection != -1) break;<
br />
if (new_connection != -1) break;<
br />
<
strong>accept_mutex_off ();</
strong><
br />
process the new_connection;<
br />
<
p><
code>accept_mutex_on</
code>�� <
code>accept_mutex_off</
code>
<
a id="serialize" name="serialize">�Լ�</
a>�� mutex �������
�����Ѵ�. �ѹ� ���� �� �ڽĸ��� mutex�� ���� �� �ִ�.
mutex�� �����ϴ� ����� ���������̴�. ���� ����� (1.3
����) <
code>
src/
conf.h</
code>�� (1.3�� �� ����)
��Ű���Ĵ� ���(locking) ����� �������� �ʱ����, �̷�
��Ű���Ŀ��� ���� <
directive module="mpm_common">Listen</
directive> ���þ ����ϸ�
module="mpm_common">AcceptMutex</
directive> ���þ ����Ͽ�
mutex ������ ������ �� �ִ�.</
p>
<
dt><
code>AcceptMutex flock</
code></
dt>
<
p>�� ����� ��������� ��ױ����� <
code>flock(2)</
code>
�ý���ȣ���� ����Ѵ� (������� ��ġ�� <
directive module="mpm_common">LockFile</
directive> ���þ�� ����).</
p>
<
dt><
code>AcceptMutex fcntl</
code></
dt>
<
p>�� ����� ��������� ��ױ����� <
code>fcntl(2)</
code>
�ý���ȣ���� ����Ѵ� (������� ��ġ�� <
directive module="mpm_common">LockFile</
directive> ���þ�� ����).</
p>
<
dt><
code>AcceptMutex sysvsem</
code></
dt>
<
p>(1.3�� �� ����) �� ����� SysV�� ������� ����Ͽ�
mutex�� �����Ѵ�. �������� SysV�� ��������� ����
���ۿ��� �ִ�. �ϳ��� ����ġ�� ������� ��������
�ʰ� ���� �� �ִ� ���̴� (<
code>ipcs(8)</
code> manpage
���). �ٸ� �ϳ��� �������� ������ uid�� �����ϴ�
CGI�� (<
em>��,</
em> <
code>suexec</
code>��
<
code>cgiwrapper</
code>�� ��������ʴ� �� ��� CGI)
�������� API�� ����Ͽ� ���źΰ���� �� �� �ִ�
���̴�. �̷� ���������� IRIX�� ������ ��Ű���Ŀ���
�� ����� ������� �ʴ´� (��κ��� IRIX ��ǻ�Ϳ���
���� �� ����� ����ġ�� ���̴�).</
p>
<
dt><
code>AcceptMutex pthread</
code></
dt>
<
p>(1.3�� �� ����) �� ����� POSIX mutex�� ����ϱ����
POSIX ������ �Ծ��� ������ ������ ��Ű���Ķ�� ���
��밡��������, (2.5 ����) Solaris������ �װ͵� Ư��
���������� �����ϴ� ���ϴ�. �� ����� �õ��غ��ٸ�
������ ���缭 ������ ���ϴ��� ������� �Ѵ�. ����
���븸 �����ϴ� ������ �� �����ϴ� �� ����.</
p>
<
dt><
code>AcceptMutex posixsem</
code></
dt>
<
p>(2.0�� �� ����) �� ����� POSIX ������� ����Ѵ�.
mutex�� ���� ���μ����� �����尡 �״´ٸ�(segfault)
�������� �������� ȸ������ �ʾƼ� �������� �����.</
p>
<
p>�ý��ۿ� �� ��Ͽ� ��� ����ȭ(serialization) �����
�ִٸ� �� ����� ����ϴ� �ڵ带 APR�� �߰��� ��ġ�� �ִ�.</
p>
<
p>����� �غ����� ������������ �ٸ� ����� �κ�������
�ݺ����� ����ȭ�ϴ� ����̴�. ��, ���μ����� ��� �鿩������
���̴�. �� ����� ���� �ڽ��� ���ÿ� ������ �� �־
����ȭ������ ��ü �뿪���� Ȱ������ ���ϴ� �������μ���
��ǻ�Ϳ����� ����� ������ �� �ִ�. ������ ���캼 �κ�������,
�ſ� ����ȭ�� �������� ������ �ʾƼ� �켱������ ����.</
p>
<
p>�ֻ��� ������ ������ؼ��� ���� <
directive module="mpm_common">Listen</
directive> ���� ������� �ʴ�
���� �̻����̴�. ���� ��� �����Ѵ�.</
p>
<
title>accept ����ȭ - ���� �Ѱ�</
title>
<
p>���� ������ ������ �������� ������, ������ �Ѱ���
������ ���? ������ �����Ҷ����� ��� �ڽ���
<
code>accept(2)</
code>���� �����ֱ���� �̷л� ����
������ ������ �ʰ�, �? ������ ���. ���� �����δ�
�տ��� ���� ������� �ʴ� (non-blocking) ��� ���ϴ�
"��ȸ��(spinning)" ������ ���߰� �ִ�. ��κ��� TCP ������
������ �����ϸ� Ŀ���� <
code>accept</
code>���� �����ִ�
��� �ڽ��� ��쵵�� �������ִ�. ���μ����� �Ѱ��� ������
��� ����ڿ������� ���ư���, �������� Ŀ�ο��� ��ȸ���Ͽ�
������ ������ �߰��ϸ� �ٽ� ���� �ܴ�. ����ڿ��� �ڵ忡����
�̷� ��ȸ���� �� �� ������, �и��� �����Ѵ�. ���� ��������
������� �ʴ� ���� �����ϰ� ���ϸ� ���̴� ���ʿ��� �ൿ��
<
p>���� �츮�� ���� ��Ű���Ŀ��� ������ �Ѱ��� ��쿡��
����ȭ�ϸ� �� "��" �������� �߰��ߴ�. ���� ���� ��κ���
��� �⺻������ ����ȭ�� ����Ѵ�. ���������� (Ŀ�� 2.0.30,
128Mb �� ��� Pentium pro) ������ ��� ���� �Ѱ���
����ȭ�ϸ� ���� ���� ��쿡 ���� �ʴ� ��û�� 3% �̸�
�پ����. ���� ����ȭ�� ���� ���� ��� ��û�� 100ms
������ ���ߴ�. �� ������ �Ƹ��� LAN���� ���ϴ� ��
���ἱ������ ���̴�. ������ �Ѱ��� ��� ����ȭ�� �������
�������� <
code>SINGLE_LISTEN_UNSERIALIZED_ACCEPT</
code>��
<
title>Close ����(lingering)</
title>
<
strong>��������</
strong> �������� �Ƿ���, ����� �� ������
���������� ���� �� �־�� �Ѵ� (TCP ������ �ֹ����̰�,
������ ���� �������̴�). ������ �ٸ� ���������� ����
����������, ����ġ�� 1.2���� ��Ȯ�� �����ؿԴ�.</
p>
<
p>�� ����� �������ϰ� ����ġ�� �߰������� ���� ���н�
���� ���� ������ ���ߴ�. TCP �Ծ���
<
code>FIN_WAIT_2</
code>�� Ÿ�Ӿƿ��� �ִٰ� ������ �ʾ�����,
���������� �ʾҴ�. Ÿ�Ӿƿ��� ��� �ý��ۿ��� ����ġ 1.2��
���� ������ ������ <
code>FIN_WAIT_2</
code> ���·� ������.
���� ��� �� ������ ���ۻ簡 �����ϴ� �ֽ�
TCP/
IP ��ġ��
����Ͽ� �ذ��� �� �ִ�. ���� ���ۻ簡 ��ġ�� ��ǥ����
�ʴ� ��찡 (<
em>��,</
em> SunOS4 -- �ҽ� ���̼����� �ִ�
����� ���� ��ġ�� �� ������) �ֱ���� �� ����� �������
<
p>����� �ΰ�����. �ϳ��� ���� �ɼ� <
code>SO_LINGER</
code>��
����ϴ� ����̴�. ���� �������� ��κ���
TCP/
IP ������
�� �ɼ��� �ùٷ� �������� �ʾҴ�. �ùٷ� ������ ���ÿ���
������ (<
em>��,</
em> ������ 2.0.31) �� ����� ���� ����
<
code>lingering_close</
code>��� �Լ��� ����Ѵ�. �� �Լ���
void lingering_close (int s)<
br />
char junk_buffer[2048];<
br />
/* shutdown the sending side */<
br />
signal (SIGALRM, lingering_death);<
br />
select (s for reading, 2 second timeout);<
br />
if (s is ready for reading) {<
br />
if (read (s, junk_buffer, sizeof (junk_buffer)) <= 0) {<
br />
/* just toss away whatever is here */<
br />
<
p>�� �ڵ�� ������ ������ �� CPU�� ���������, ��������
������ ���� �ʿ��ϴ�.
HTTP/
1.1�� �� �θ� ������ ��� ������
�����Ѵٸ�(persistent), ������ �� ����� ���� ��û��
ó���ϸ鼭 ���� ���̴�. �����ϰԵ�
<
code>NO_LINGCLOSE</
code>�� �����Ͽ� �� ����� �������
���� �� ������, ���� ������ �ʴ´�. Ư��
HTTP/
1.1 ���������� <
transnote>�������� ���¿��� ������ ��ٸ���
�ʰ� ���� ��û�� ������ ���</
transnote> ������������
<
code>lingering_close</
code>�� �ʼ����̴� (���� <
a ���������� ������ �� ������</
a> ����ϱ� �ٶ� ���̴�).</
p>
<
title>Scoreboard ����</
title>
<
p>����ġ�� �θ�� �ڽ��� scoreboard��� ���� ���� ����
����Ѵ�. �̻������δ� scoreboard�� ������ �����ؾ�
�Ѵ�. �츮 �����ڰ� �ش� �ü���� ������ �� �ְų� ����
���� ��� ���� ��� ���� ������ ����Ͽ� �����Ѵ�.
�������� ��ũ�� �ִ� ������ ����Ͽ� �����Ѵ�. ��ũ��
�ִ� ������ ������ �ŷڵ��� ������� (��ɵ� �� ���).
ã�Ƽ� <
code>USE_MMAP_SCOREBOARD</
code> Ȥ��
<
code>USE_SHMGET_SCOREBOARD</
code>���� Ȯ���Ѵ�. ����
�ϳ��� (���� �Բ� ����� <
code>HAVE_MMAP</
code>�̳�
<
code>HAVE_SHMGET</
code>�� ����) �����ϸ� ������ �ڵ带
����Ѵ�. �ý����� �ٸ� ������ ������ ����Ѵٸ�
������ ����� �� �ֵ��� ��(hook)�� �߰��϶�. (����
��ġ�� �츮���� �����ֱ� �ٶ���.)</
p>
<
note>������ ����: ����ġ�� ������ ������ ����ġ 1.2 �������
������ ����ϱ� �����ߴ�. ���������� �ʱ� ����ġ
������ ������ �ŷڵ��� �������� �����̴�.</
note>
<
title>DYNAMIC_MODULE_LIMIT</
title>
<
p>����� �������� �о������ �ʴ´ٸ� (������ �����̶�
������ ���̱����� �� ���� �д´ٸ� �Ƹ��� ����� ��������
�о������ ���� ���̴�), ������ �������Ҷ�
<
code>-DDYNAMIC_MODULE_LIMIT=0</
code>�� �߰��Ѵ�. ����
����� �������� �о���̱����� �Ҵ��ϴ� �� ����Ѵ�.</
p>
<
title>�η�: �ý���ȣ�� ����� �ڼ��� �м��ϱ�</
title>
<
p>������ Solaris 8���� worker MPM�� ����� ����ġ 2.0.38��
�ý���ȣ�� ���(trace)�̴�. �Ʒ� ��ɾ ����Ͽ� �����
truss -l -p <
var>httpd_child_pid</
var>.
<
p><
code>-l</
code> �ɼ��� ����ϸ� truss�� �ý���ȣ����
�ϴ� LWP (lightweight process, �淮�� ���μ���--Solaris��
Ŀ�μ��� ������) ID�� ���� ����Ѵ�.</
p>
<
p>�ٸ� �ý��ۿ��� <
code>strace</
code>, <
code>ktrace</
code>,
<
code>par</
code> ���� �ý���ȣ�� ���� ������ �ִ�. ����
<
p>Ŭ���̾�Ʈ�� ���������� ũ�Ⱑ 10KB�� ���� ������ ��û�Ѵ�.
������ ������ ��û���� �ʰų� ��������ϴ� ��û�� �� ���
����� �ſ� �ٸ��� (���δ� �ſ� �˾ƺ��� ����).</
p>
<
pre>/67: accept(3, 0x00200BEC, 0x00200C0C, 1) (sleeping...)
/67: accept(3, 0x00200BEC, 0x00200C0C, 1) = 9</
pre>
<
p>������ ������(listener) �����尡 LWP #67���� �������
<
note><
code>accept(2)</
code> ����ȭ�� ������� ������ �ָ��϶�.
���� ��Ʈ�� ��ٸ����ʴ� ��� �� �÷����� worker MPM��
�⺻������ ����ȭ���� ���� accept�� ����Ѵ�.</
note>
<
pre>/65: lwp_park(0x00000000, 0) = 0
/67: lwp_unpark(65, 1) = 0</
pre>
<
p>������ �Ƶ��̰�(accept) ������ �������
worker �����带 ����� ��û�� ó���ϰ� �Ѵ�. �Ʒ� ��Ͽ���
��û�� ó���ϴ� worker �����尡 LWP #65���� �� �� �ִ�.</
p>
<
pre>/65: getsockname(9, 0x00200BA4, 0x00200BC4, 1) = 0</
pre>
<
p>����ȣ��Ʈ�� �����ϱ����� ����ġ�� ������ �Ƶ���
����(local) ���� �ּҸ� �˾ƾ� �Ѵ�. (����ȣ��Ʈ�� �������
�ʰų� <
directive module="mpm_common">Listen</
directive>
���þ ���ϵ�ī�� �ּҸ� ������� ���� ��� ��) ���� ���
�� ȣ���� ��� �� �ִ�. ���� ���� �̷� ����ȭ �۾���
<
pre>/65: brk(0x002170E8) = 0
/65: brk(0x002190E8) = 0</
pre>
<
p><
code>brk(2)</
code> ȣ���� ��(heap)���� �� �Ҵ��Ѵ�.
�������� ��κ��� ��û ó���� ��ü ��
�Ҵ���(<
code>apr_pool</
code>�� <
code>apr_bucket_alloc</
code>)��
����ϱ���� �ý���ȣ�� ��Ͽ��� �� �ý���ȣ���� ���Ⱑ
�幰��. �� ��Ͽ��� �������� �������ڸ��� ��ü �� �Ҵ��ڰ�
����� ����� ������� <
code>malloc(3)</
code>�� ȣ���Ѵ�.</
p>
<
pre>/65: fcntl(9, F_GETFL, 0x00000000) = 2
/65: fstat64(9, 0xFAF7B818) = 0
/65: getsockopt(9, 65535, 8192, 0xFAF7B918, 0xFAF7B910, 2190656) = 0
/65: fstat64(9, 0xFAF7B818) = 0
/65: getsockopt(9, 65535, 8192, 0xFAF7B918, 0xFAF7B914, 2190656) = 0
/65: setsockopt(9, 65535, 8192, 0xFAF7B918, 4, 2190656) = 0
/65: fcntl(9, F_SETFL, 0x00000082) = 0</
pre>
<
p>���� worker ������� Ŭ���̾�Ʈ�� ����(���ϱ���� 9)��
������(non-blocking) ���·� �ٲ۴�. <
code>setsockopt(2)</
code>��
<
code>getsockopt(2)</
code> ȣ���� Solaris�� libc�� ���Ͽ�
���� <
code>fcntl(2)</
code>�� ��� ó���ϴ��� �����ش�.</
p>
<
pre>/65: read(9, " G E T / 1 0 k . h t m".., 8000) = 97</
pre>
<
p>worker ������� Ŭ���̾�Ʈ�� ���� ��û�� �д´�.</
p>
<
p>������ ������ <
code>Options FollowSymLinks</
code>��
<
code>AllowOverride None</
code>�̴�. ���� ��û�� ���ϰ����
�� ���丮�� ���� <
code>lstat(2)</
code>�ϰų�
<
code>.htaccess</
code> ������ �˻��� �ʿ䰡 ���. ������
�˻��ϱ�����, 1) ������ �ִ���, 2) ���丮�� �ƴ� �Ϲ���������,
<
code>stat(2)</
code> ȣ�⸸ �ϸ� �ȴ�.</
p>
<
pre>/65: sendfilev(0, 9, 0x00200F90, 2, 0xFAF7B53C) = 10269</
pre>
<
p>�� ��� �������� �ѹ��� <
code>sendfilev(2)</
code> �ý���ȣ���
HTTP ��������� ��û�� ������ ����� �� �ִ�. Sendfile ����δ�
�ü������ �ٸ���. �ٸ� �ý����̶�� <
code>sendfile(2)</
code>��
ȣ���ϱ� �� ����� ���������� <
code>write(2)</
code>��
<
code>writev(2)</
code> ȣ���� �Ѵ�.</
p>
<
pre>/65: write(4, " 1 2 7 . 0 . 0 . 1 - ".., 78) = 78</
pre>
<
p><
code>write(2)</
code> ȣ���� ���ٷα�(access log)�� ��û��
����Ѵ�. �� ��Ͽ� <
code>time(2)</
code> ȣ���� ������ �ָ��϶�.
����ġ 1.3�� �� ����ġ 2.0�� �ð��� �˱�����
<
code>gettimeofday(3)</
code>�� ����Ѵ�.
<
code>gettimeofday</
code>�� ����ȭ�� �������� Solaris ����
��� �ü�������� �Ϲ����� �ý���ȣ�� �δ��� ���.</
p>
<
pre>/65: shutdown(9, 1, 1) = 0
/65: poll(0xFAF7B980, 1, 2000) = 1
/65: read(9, 0xFAF7BC20, 512) = 0
<
p>worker ������� ������ �����ݱ�(lingering close)�Ѵ�.</
p>
/65: lwp_park(0x00000000, 0) (sleeping...)</
pre>
<
p>���������� worker ������� ��� ����� ������ �ݰ�,
������(listener) �����尡 �ٸ� ������ �Ҵ��� ������
<
pre>/67: accept(3, 0x001FEB74, 0x001FEB94, 1) (sleeping...)</
pre>
<
p>���� ������ ������� ������ (��� worker�� �۾����̸�
������ �����带 ���ߴ� worker MPM�� �帧���� ��ɿ� ���)
worker �����忡 �Ҵ����ڸ��� �ٸ� ������ �Ƶ��� �� �ִ�.
�� ��Ͽ��� ������ ������, worker �����尡 ��� ���� ������
ó���ϴ� ���� ���� <
code>accept(2)</
code>�� (��û�� �ſ�
���� ��� ��) �Ͼ �� �ִ�.</
p>