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)
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
预编译源文件并生成出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
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
chkconfig --add nginx
chkconfig --level 35 nginx on
service nginx restart
相关推荐
张立军的架构之路 2020-09-28
yongzhang 2020-07-19
nginxs 2020-11-14
Guanjs0 2020-11-13
小木兮子 2020-11-11
yserver 2020-11-11
ssihc0 2020-11-11
windle 2020-11-10
HanksWang 2020-11-10
liuchen0 2020-11-10
Freshairx 2020-11-10
ccschan 2020-11-10
liwf 2020-11-10
Guanjs0 2020-11-09
AderStep 2020-11-09
zrtlin 2020-11-09