1、环境准备。查看是否已经安装gcc和gcc-c 。
which gcc;如果没有安装运行:yum -y install gcc
which g ;如果没有安装运行:yum -y install gcc-c
2、安装pcre。下载地址:
http://download.chinaunix.net/download/0008000/7913.shtml(这个主要用来处理http-rewrite。如果要支持php等脚本请求转发就必须安装该模块)
①下载:pcre-8.30.tar.bz2
②解压并安装:
tar -jxvf pcre-8.30.tar.bz2 pcre-8.30(其中j-bz2处理指令;x-解压;v-回显zip中的内容;f-解包)
./configure -prefix=/usr/local/nginx(预编译生成MakeFile,-prefix--指定安装目录)
make(编译)
make install (安装指令)
3、安装zlib.下载地址:
http://download.chinaunix.net/download/0013000/12241.shtml ①下载:zlib-1.2.7.tar.gz压缩包。上传到服务器。
②解压并安装:
tar -zxvf zlib-1.2.7.tar.gz zlib-1.2.7(其中z-zip处理指令;x-解压;v-回显zip中的内容;f-解包)
./configure -prefix=/usr/local(预编译生成MakeFile,-prefix--指定安装目录)
make(编译)
make install (安装指令)
4、安装openssl.下载地址:
http://download.chinaunix.net/download/0001000/11.shtml(这是用来支持https连接的模块)
①下载:openssl-1.0.1c.tar.gz
②解压并安装:
tar -zxvf openssl-1.0.1c.tar.gz openssl-1.0.1c
./config -prefix=/usr/local
make(编译)
make install (安装指令)
①下载nginx安装包,地址为:
http://wiki.nginx.org/Install。然后上传到centos服务器进行解压:
tar -zxvf nginx-1.2.2.tar.gz nginx-1.2.2。
②进入nginx文件夹下,找到configure文件。然后运行:
./configure --prefix=/usr/local/nginx --with-pcre=/root/tool/pcre-(version) --with-http_ssl_module --with-openssl=/root/tool/openssl-(version) --with-zlib=/root/tool/zilb-(version)
注意:--with-XXX=压缩包解压以后的目(不是安装后的目录)
预编译源文件并生成出Makefile文件。(有可能centos尚未安装gcc编译工具:yum -y install gcc)
③编译文件,执行:
make
④安装nginx:
make install(默认安装在/usr/local/nginx文件下)。
安装完成后,运行:ps aux|grep nginx会看到nginx的后台守护进程。这个时候可以运行一些nginx设置指令,但是
nginx尚未提供服务。例如重起nginx:
/usr/local/nginx/sbin/nginx -s reload(stop--停止)
当nginx配置文件发生变化时就需要重启,例如增加php 提供的pastcgi服务。
⑤启动nginx的web服务:
/usr/local/nginx/sbin/nginx。
注意:在启动nginx的时候,可能有些依赖文件找不到,可以试试下面的指令。
例如我遇到问题是libpcre.so.1找不到:
①测试nginx运行: /usr/local/nginx/sbin/nginx -t;爆出如下异常:
/usr/local/nginx/sbin/nginx: error while loading shared libraries: libpcre.so.1: cannot open shared object file: No such file or directory
②发现问题后,上网查找到查看nginx对依赖包路径查看:ldd $(which /usr/local/nginx/sbin/nginx);显示如下
linux-gate.so.1 => (0x00c89000)
libcrypt.so.1 => /lib/libcrypt.so.1 (0x00b98000)
libpcre.so.1 => /lib/libpcre.so.1 (0x00351000)
libz.so.1 => /lib/libz.so.1 (0x00426000)
libc.so.6 => /lib/libc.so.6 (0x00935000)
libfreebl3.so => /lib/libfreebl3.so (0x007e9000)
/lib/ld-linux.so.2 (0x003d5000)
libdl.so.2 => /lib/libdl.so.2 (0x00569000)
可以看到libpcre.so.1 => /lib/libpcre.so.1 (0x00351000)依赖的是/lib/libpcre.so.1。但是我的安装路径为:/usr/local/lib/libpcre.so.1
因此需要在/lib中建立libpcre.so.1的连接。
③进入/lib中建立连接:ln -s /usr/local/lib/libpcre.so.1 /lib/libpcre.so.1;建立完连接后,在此启动服务,一切OK。
④启动:/usr/local/nginx/sbin/nginx
5、添加开机启动脚本
vi /etc/init.d/nginx
#!/bin/sh
#
# nginx - this script starts and stops the nginx daemon
#
# chkconfig: - 85 15
# description: Nginx is an HTTP(S) server, HTTP(S) reverse \
# proxy and IMAP/POP3 proxy server
# processname: nginx
# config: /usr/local/nginx/conf/nginx.conf
# config: /etc/sysconfig/nginx
# pidfile: /usr/local/nginx/logs/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="/usr/local/nginx/sbin/nginx"(修改为你的安装路径)
prog=$(basename $nginx)
NGINX_CONF_FILE="/usr/local/nginx/conf/nginx.conf"(修改为你的安装路径)
[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx
lockfile=/var/lock/subsys/nginx
make_dirs() {
# make required directories
user=`$nginx -V 2>&1 | grep "configure arguments:" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -`
if [ -z "`grep $user /etc/passwd`" ]; then
useradd -M -s /bin/nologin $user
fi
options=`$nginx -V 2>&1 | grep 'configure arguments:'`
for opt in $options; do
if [ `echo $opt | grep '.*-temp-path'` ]; then
value=`echo $opt | cut -d "=" -f 2`
if [ ! -d "$value" ]; then
# echo "creating" $value
mkdir -p $value && chown -R $user $value
fi
fi
done
}
start() {
[ -x $nginx ] || exit 5
[ -f $NGINX_CONF_FILE ] || exit 6
make_dirs
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
sleep 1
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 775 /etc/init.d/nginx
chkconfig --add nginx
chkconfig --level 35 nginx on
service nginx restart