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 ~]# lltotal 888drwxr-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 nginxuid=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 -vnginx version: nginx/1.6.2
测试nginx的配置文件:
[root@www ~]# nginx -tnginx: the configuration file /etc/nginx/nginx.conf syntax is oknginx: 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 2esac
将服务脚本加入系统启动并设置开机自动启动:
[root@www ~]# chkconfig --list nginxservice 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 80tcp LISTEN 0 128 :::38804 :::* tcp LISTEN 0 128 *:80 *:*
简单的nginx基础介绍完毕!