Nginx的编译安装

2022-07-03 16:56:32 浏览数 (1)

Nginx 是一个高性能的 Web 和反向代理服务器, 它具有有很多非常优越的特性:

作为 Web 服务器:相比 Apache,Nginx 使用更少的资源,支持更多的并发连接,体现更高的效率,这点使 Nginx 尤其受到虚拟主机提供商的欢迎。能够支持高达 50,000 个并发连接数的响应,感谢 Nginx 为我们选择了 epoll and kqueue 作为开发模型.

作为负载均衡服务器:Nginx 既可以在内部直接支持 Rails 和 PHP,也可以支持作为 HTTP代理服务器 对外进行服务。Nginx 用 C 编写, 不论是系统资源开销还是 CPU 使用效率都比 Perlbal 要好的多。

作为邮件代理服务器: Nginx 同时也是一个非常优秀的邮件代理服务器(最早开发这个产品的目的之一也是作为邮件代理服务器),Last.fm 描述了成功并且美妙的使用经验。

Nginx 安装非常的简单,配置文件 非常简洁(还能够支持perl语法),Bugs非常少的服务器: Nginx 启动特别容易,并且几乎可以做到7*24不间断运行,即使运行数个月也不需要重新启动。你还能够在 不间断服务的情况下进行软件版本的升级。 编译环境: [root@www ~]# yum groupinstall Development Tools [root@www ~]# yum install pcre-devel openssl-devel

获取nginx程序源码包:

[root@www ~]# ll total 888 drwxr-xr-x  9 1001 1001  4096 Dec 27 02:19 nginx-1.6.2 -rw-r--r--  1 root root 804164 Sep 16 22:45 nginx-1.6.2.tar.gz -rw-r--r--  1 root root  29542 Apr 23  2014 nginx.vim

解压源码包:

[root@www ~]# tar xf nginx-1.6.2.tar.gz [root@www ~]# cd nginx-1.6.2

创建nginx管理用户:

[root@www nginx-1.6.2]# useradd -M -s /sbin/nologin nginx [root@www nginx-1.6.2]# id nginx uid=500(nginx) gid=500(nginx) groups=500(nginx)

源码编译安装nginx:

我们编译安装时需要定义各种配置需要的目录进行,所以需要新建一些目录:

日志存储目录:

[root@www ~]# mkdir /var/log/nginx

各种缓存目录,客户端,代理,fastcgi目录:

[root@www ~]# mkdir -pv /var/tmp/nginx/{client,proxy,fastcgi} mkdir: created directory `/var/tmp/nginx' mkdir: created directory `/var/tmp/nginx/client' mkdir: created directory `/var/tmp/nginx/proxy' mkdir: created directory `/var/tmp/nginx/fastcgi' [root@www ~]#

可以使用如下命令查看帮助文件:

[root@www nginx-1.6.2]# ./configure --help |less

开始编译nginx:

[root@www nginx-1.6.2]# ./configure --prefix=/usr/local/nginx --conf-path=/etc/nginx/nginx.conf --user=nginx --group=nginx --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --pid-path=/var/run/nginx/nginx.pid --lock-path=/var/lock/nginx.lock --with-http_ssl_module --with-http_stub_status_module --with-http_gzip_static_module --with-http_flv_module --with-http_mp4_module --http-client-body-temp-path=/var/tmp/nginx/client --http-proxy-temp-path=/var/tmp/nginx/proxy --http-fastcgi-temp-path=/var/tmp/nginx/fastcgi

安装nginx:

[root@www nginx-1.6.2]# make && make install

 检查安装:

查看安装目录

[root@www ~]# ls /usr/local/nginx/ html  sbin [root@www ~]# ls /usr/local/nginx/sbin/ nginx

查看配置文件目录:

[root@www ~]# ls /etc/nginx/ fastcgi.conf            fastcgi_params.default  mime.types              nginx.conf.default      uwsgi_params            fastcgi.conf.default    koi-utf                mime.types.default      scgi_params            uwsgi_params.default    fastcgi_params          koi-win                nginx.conf              scgi_params.default    win-utf

环境变量设置:

[root@www ~]# echo "export PATH=/usr/local/nginx/sbin:$PATH" > /etc/profile.d/nginx.sh [root@www ~]# source /etc/profile.d/nginx.sh

查看nginx的版本:

[root@www ~]# nginx -v nginx version: nginx/1.6.2

 测试nginx的配置文件:

[root@www ~]# nginx -t nginx: the configuration file /etc/nginx/nginx.conf syntax is ok nginx: configuration file /etc/nginx/nginx.conf test is successful

提供nginx服务脚本:

[root@www ~]# vim /etc/rc.d/init.d/nginx #!/bin/bash # # 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="/usr/local/nginx/sbin/nginx" prog=$(basename $nginx) NGINX_CONF_FILE="/etc/nginx/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' -`   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

将服务脚本加入系统启动并设置开机自动启动:

[root@www ~]# chkconfig --list nginx service nginx supports chkconfig, but is not referenced in any runlevel (run 'chkconfig --add nginx') [root@www ~]# chkconfig --add nginx [root@www ~]# chkconfig nginx on

设置服务脚本开启执行权限:

[root@www ~]# chmod x /etc/rc.d/init.d/nginx

启动nginx服务器: [root@www ~]# vim /etc/rc.d/init.d/nginx [root@www ~]# service nginx start            Starting nginx:                                            [  OK  ] [root@www ~]# ss -tunl |grep 80 tcp    LISTEN    0      128                  :::38804                :::*    tcp    LISTEN    0      128                    *:80                    *:*

简单的nginx基础介绍完毕!

0 人点赞