Window下(win10)下的Nginx安装

      由于需要构建一个nginx负载均衡服务器和一个图片服务器,这里介绍一下Nginx安装,具体流程棵草靠下面的流程:

     由于使用的是win10系统,并且想能够在开发的时候进行测试,故本次通过在win10系统中安装一个VMware虚拟机运行Linux操作系统,具体的VMware安装步骤请参考此网址。本次使用的是VMware workstation pro 14 和 Centos-7版本进行测试的。同时关于构造双系统环境,可以参考一下博客:

1http://blog.csdn.net/gatherfly/article/details/51864247    2. http://os.51cto.com/art/201610/519291.htm

     准备工作准备好以后,需要安装Nginx了,不过要注意的是Nginx需要一定的安装环境,Nginx下载的代码需要经过编译之后才可以应用,所以,我们需要安装一些环境:

一、Niginx安装环境搭建

1. gcc-c++:

      首先,在虚拟机中的linux操作窗口输入命令:yum gcc-c++;(注:是在联网状态下进行的)。执行后看到提示Completed !表示安装完成。


    2.PCRE

      PCRE(Perl Compatible Regular Expressions)是一个Perl库,包括 perl 兼容的正则表达式库。nginx的http模块使用pcre来解析正则表达式,所以需要在linux上安装pcre库。使用命令:yum install -y pcrepcre-devel

pcre-devel是使用pcre开发的一个二次开发库。nginx也需要此库。按照命令输入,之后会提示安装成功:


  

     3.zlib

zlib库提供了很多种压缩和解压缩的方式,nginx使用zlib对http包的内容进行gzip,所以需要在linux上安装zlib库。因此,Nginx的编译也会需要这个库中的文件,所以,在窗口中输入以下命令,会获取清华大学的镜像文件:yum install -y zlibzlib-devel;之后同样会提示安装成功。



4.openssl

     OpenSSL是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。nginx不仅支持http协议,还支持https(即在ssl协议上传输http),所以需要在linux安装openssl库。

输入命令:yuminstall -y openssl openssl-devel;自动安装后提示安装成功.



到这里,Nginx的安装环境搭建好了,接下来需要安装Nginx了。


二、Nginx编译安装

1.连接nginx服务器

在这里使用的是SecureCRT来连接服务器,实现将内容上传到Linux服务器,这时候我们需要将下载好的Nginx压缩包,上传到Linux服务器中:
注:可以直接拖入,前提是将字符集改为UTF-8。


2.上传nginx-1.8.0.tar.gz压缩文件 

 转到ftp标签页,实现文件的上传,上传成功:

首先需要链接到Linux服务器,如出现连接不上的问题可以参考我的博客(Windows下 利用SecureCRT连接Linux服务器)关于此内容的处理。

3.解压、编译、安装

解压,上传的安装包,tar -zxvf nginx-1.8.0.tar.gz;解压完成之后,需要走出这个文件,所以需要使用命令,cd nginx-1.8.0

之后需要配置makefile:需要执行命令:
./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
     之后,我们需要进行编译安装,启用命令进行安装:
make                    //编译
make install
安装结果查看,注意:上边将临时文件目录指定为/var/temp/nginx,需要在/var下创建temp及nginx目录:

得到了nginx的可执行文件。

4.如何启动Nginx?

进入sbin目录执行./nginx就可以启动nginx。
如果遇到这个问题nginx: [emerg] mkdir() "/var/temp/nginx/client" failed (2: No such file or directory)
则需要手动创建这个目录:sudo mkdir -p /var/temp/nginx/client
重新执行./nginx即可。

r如何验证我们的nginx已经启动了呢,只需要在地址栏中填写,前面连接的ip地址加上默认端口号:80即可。

     看到这个界面,说明nginx能够正常的启动了。

5.如何停止nginx?

     方式1,快速停止:
cd /usr/local/nginx/sbin
./nginx -s stop
此方式相当于先查出nginx进程id再使用kill命令强制杀掉进程。


方式2,完整停止(建议使用):
cd /usr/local/nginx/sbin
./nginx -s quit
此方式停止步骤是待nginx进程处理任务完毕进行停止。


6.重启nginx

方式1,先停止再启动(建议使用):
对nginx进行重启相当于先停止nginx再启动nginx,即先执行停止命令再执行启动命令。
如下:
./nginx -s quit
./nginx

方式2,重新加载配置文件:
当nginx的配置文件nginx.conf修改后,要想让配置生效需要重启nginx,使用-s reload不用先停止nginx再启动nginx即可将配置信息在nginx中生效,如下:
./nginx -s reload

7.开机启动Nginx(可选):

这里使用的是编写shell脚本的方式来处理,vi /etc/init.d/nginx  (输入下面的代码)
#!/bin/bash
# nginx Startup script for the Nginx HTTP Server
# it is v.0.0.2 version.
# chkconfig: - 85 15
# description: Nginx is a high-performance web and proxy server.
#              It has a lot of features, but it's not for everyone.
# processname: nginx
# pidfile: /var/run/nginx.pid
# config: /usr/local/nginx/conf/nginx.conf
nginxd=/usr/local/nginx/sbin/nginx
nginx_config=/usr/local/nginx/conf/nginx.conf
nginx_pid=/var/run/nginx.pid
RETVAL=0
prog="nginx"
# Source function library.
. /etc/rc.d/init.d/functions
# Source networking configuration.
. /etc/sysconfig/network
# Check that networking is up.
[ ${NETWORKING} = "no" ] && exit 0
[ -x $nginxd ] || exit 0
# Start nginx daemons functions.
start() {
if [ -e $nginx_pid ];then
   echo "nginx already running...."
   exit 1
fi
   echo -n $"Starting $prog: "
   daemon $nginxd -c ${nginx_config}
   RETVAL=$?
   echo
   [ $RETVAL = 0 ] && touch /var/lock/subsys/nginx
   return $RETVAL
}
# Stop nginx daemons functions.
stop() {
        echo -n $"Stopping $prog: "
        killproc $nginxd
        RETVAL=$?
        echo
        [ $RETVAL = 0 ] && rm -f /var/lock/subsys/nginx /var/run/nginx.pid
}
# reload nginx service functions.
reload() {
    echo -n $"Reloading $prog: "
    #kill -HUP `cat ${nginx_pid}`
    killproc $nginxd -HUP
    RETVAL=$?
    echo
}
# See how we were called.
case "$1" in
start)
        start
        ;;
stop)
        stop
        ;;
reload)
        reload
        ;;
restart)
        stop
        start
        ;;
status)
        status $prog
        RETVAL=$?
        ;;
*)
        echo $"Usage: $prog {start|stop|restart|reload|status|help}"
        exit 1
esac
exit $RETVAL
  wq 保存并退出。

8. 设置文件访问权限:

chmod a+x /etc/init.d/nginx   (a+x ==> all user can execute  所有用户可执行),这样在控制台就很容易的操作nginx了:查看Nginx当前状态、启动Nginx、停止Nginx、重启Nginx…
如果修改了nginx的配置文件nginx.conf,也可以使用上面的命令重新加载新的配置文件并运行,可以将此命令加入到rc.local文件中,这样开机的时候nginx就默认启动了,vi /etc/rc.local   中 加入一行  /etc/init.d/nginx start    保存并退出,下次重启会生效。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值