NginX 설치
의존 패키지 설치
아래의 의존 패키지를 설치합니다.
|
yum -y install gcc g++ cpp gcc-c++
yum -y install pcre-devel
yum -y install openssl openssl-devel
yum -y install gd gd-devel
|
다운로드
nginx 설치 압축파일을 다운로드 받습니다.
|
wget http://nginx.org/download/nginx-1.2.7.tar.gz
|
설치
다운로드 받은 nginx 설치 파일의 압축을 해제한 후 설치 디렉토리로 이동합니다.
|
tar xvfz nginx-1.2.7.tar.gz
cd nginx-1.2.7
|
Nginx 설치를 위하여 아래와 같은 컴파일 configure 옵션으로 실행합니다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
./configure --prefix=/opt/nginx-1.2.7 \
--conf-path=/opt/nginx-1.2.7/conf/nginx.conf \
--sbin-path=/opt/nginx-1.2.7/sbin/nginx \
--lock-path=/var/lock/nginx.lock \
--pid-path=/var/run/nginx.pid \
--http-client-body-temp-path=/var/lib/nginx/body \
--http-proxy-temp-path=/var/lib/nginx/proxy \
--http-fastcgi-temp-path=/var/lib/nginx/fastcgi \
--http-uwsgi-temp-path=/var/lib/nginx/uwsgi \
--http-scgi-temp-path=/var/lib/nginx/scgi \
--http-log-path=/opt/nginx-1.2.7/log/access.log \
--error-log-path=/opt/nginx-1.2.7/log/error.log \
--with-http_addition_module \
--with-http_degradation_module \
--with-http_flv_module \
--with-http_gzip_static_module \
--with-http_image_filter_module \
--with-http_mp4_module \
--with-http_random_index_module \
--with-http_realip_module \
--with-http_ssl_module \
--with-http_stub_status_module \
--with-http_sub_module \
--with-http_realip_module \
--user=nobody \
--group=nobody
|
컴파일 후 설치합니다.
NginX 실행시 필요한 폴더를 생성합니다.
서비스 등록
NginX 를 서비스로 실행할 수 있도록 서비스 파일을 편집합니다.
아래의 내용을 서비스 스크립트 파일에 입력한 후 저장합니다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
#!/bin/sh
#
# nginx - this script starts and stops the nginx daemin
#
# chkconfig: - 85 15
# description: Nginx is an HTTP(S) server, HTTP(S) reverse \
# proxy and IMAP/POP3 proxy server
# processname: nginx
# config: /opt/nginx-1.2.7/conf/nginx.conf
# pidfile: /var/run/nginx.pid
# Source function library.
. /etc/rc.d/init.d/functions
# Source networking configuration.
. /etc/sysconfig/network
# Check that networking is up.
[ "$NETWORKING" = "no" ] && exit 0
nginx="/opt/nginx-1.2.7/sbin/nginx"
prog=$(basename $nginx)
NGINX_CONF_FILE="/opt/nginx-1.2.7/conf/nginx.conf"
lockfile=/var/lock/subsys/nginx
start() {
[ -x $nginx ] || exit 5
[ -f $NGINX_CONF_FILE ] || exit 6
echo -n $"Starting $prog: "
daemon $nginx -c $NGINX_CONF_FILE
retval=$?
echo
[ $retval -eq 0 ] && touch $lockfile
return $retval
}
stop() {
echo -n $"Stopping $prog: "
killproc $prog -QUIT
retval=$?
echo
[ $retval -eq 0 ] && rm -f $lockfile
return $retval
}
restart() {
configtest || return $?
stop
start
}
reload() {
configtest || return $?
echo -n $"Reloading $prog: "
killproc $nginx -HUP
RETVAL=$?
echo
}
force_reload() {
restart
}
configtest() {
$nginx -t -c $NGINX_CONF_FILE
}
rh_status() {
status $prog
}
rh_status_q() {
rh_status >/dev/null 2>&1
}
case "$1" in
start)
rh_status_q && exit 0
$1
;;
stop)
rh_status_q || exit 0
$1
;;
restart|configtest)
$1
;;
reload)
rh_status_q || exit 7
$1
;;
force-reload)
force_reload
;;
status)
rh_status
;;
condrestart|try-restart)
rh_status_q || exit 0
;;
*)
echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"
exit 2
esac
|
서비스 스크립트에 실행권한을 설정합니다.
|
chmod +x /etc/init.d/nginx
|
시스템 재기동시에도 자동으로 실행될 수 있도록 설정합니다.
정상적으로 설정이 되어있는지 아래의 명령을 이용하여 확인합니다.
정상적으로 등록시 아래와 같이 표시됩니다.
|
nginx 0:off 1:off 2:on 3:on 4:on 5:on 6:off
|
방화벽 설정
방화벽 정책파일을 편집합니다.
|
vi /etc/sysconfig/iptables
|
아래와 같이 80 번 포트를 방화벽 정책에 추가시킨 후 저장합니다.
|
-A INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT
|
방화벽을 재시작하여 현재 시스템에 적용합니다.
NginX 실행
시작
종료
재시작
NginX 실행확인
브라우저의 주소창에 http:// 을 입력하여 정상적으로 NginX 가 실행되는지 확인합니다.