注:通过yum安装时如果总是404,需要先清下缓存在update一下
yum clean all
yum update
1、需要安装gcc的环境。
yum install gcc-c++
2、第三方的开发包。
PCRE
PCRE(Perl Compatible Regular Expressions)是一个Perl库,包括 perl 兼容的正则表达式库。nginx的http模块使用pcre来解析正则表达式,所以需要在linux上安装pcre库。
yum install -y pcre pcre-devel
注:pcre-devel是使用pcre开发的一个二次开发库。nginx也需要此库。
zlib
zlib库提供了很多种压缩和解压缩的方式,nginx使用zlib对http包的内容进行gzip,所以需要在linux上安装zlib库。
yum install -y zlib zlib-devel
openssl
OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。
nginx不仅支持http协议,还支持https(即在ssl协议上传输http),所以需要在linux安装openssl库。
yum install -y openssl openssl-devel
1.上传nginx1.8到linux
2.解压到/usr/local
tar -xvf nginx-1.8.0.tar.gz -C /usr/local
3.进入/usr/local/nginx-1.8.0/目录使用configure生成Makefile文件
cd /usr/local/nginx-1.8.0/
./configure \
--prefix=/usr/local/nginx \
--pid-path=/var/run/nginx/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/temp/nginx/client \
--http-proxy-temp-path=/var/temp/nginx/proxy \
--http-fastcgi-temp-path=/var/temp/nginx/fastcgi \
--http-uwsgi-temp-path=/var/temp/nginx/uwsgi \
--http-scgi-temp-path=/var/temp/nginx/scgi
4.由于上面将临时文件目录指向了 /var/temp/nginx ,所以这里要创建一个这样的文件夹
mkdir /var/temp/nginx -p
5.执行make编译和make install安装
make
make install
6.进入/usr/local/nginx/sbin目录,启动nginx
./nginx
7.查看启动状态
ps aux|grep nginx
8.关闭nginx
./nginx -s quit
9.重启nginx 先关闭后启动,刷新配置文件
./nginx -s reload
1.在/etc/init.d/目录下创建nginx文件
vim /etc/init.d/nginx
2.编写以下脚本文件,注意修改一下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: /etc/nginx/nginx.conf
# config: /etc/sysconfig/nginx
# 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执行文件路径
nginx="/usr/local/nginx/sbin/nginx"
prog=$(basename $nginx)
#指定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
3.wq保存脚本文件后设置文件的执行权限
chmod a+x /etc/init.d/nginx
4.可以通过该脚本文件对nginx服务进行管理了
/etc/init.d/nginx start
/etc/init.d/nginx stop
5.将nginx服务加入chkconfig管理列表
chkconfig --add /etc/init.d/nginx
6.加入后,就可以使用以下命令管理nginx了
service nginx start
service nginx stop
7.设置终端模式开机启动
chkconfig nginx on
8.重启linux后测试nginx是否开机启动
ps aux|grep nginx
测试:先修改本机host C:\Windows\System32\Drivers\etc\hosts
1.通过端口区分不同的虚拟主机
2.通过域名区分不同的虚拟主机
3.实现反向代理(通过nginx代理访问不同服务器)
4.实现负载均衡