Linux安装nginx

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
    开机启动脚本内容(http://wiki.nginx.org/RedHatNginxInitScript)
#!/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

相关推荐