构建基于Nginx的web服务器

简介:
系统平台:RHEL 5
Nginx版本:nginx-0.8.54
一.安装及配置Nginx
1.安装pcre软件包,pcre的作用为nginx提供兼容perl的正则表达式库。以下采用RHEL5光盘自带的rpm包进行安装,另外也可下载最新的源码包进行编译安装。
[root@localhost~]# rpm -ivh pcre-6.6-2.el5_1.7
[root@localhost~]# rpm -ivh pcre-devel-6.6-2.el5_1.7
 
2.安装nginx
[root@localhost~]# tar zxf nginx-0.8.54.tar.gz
[root@localhost~]# cd nginx-0.8.54
[root@localhost nginx-0.8.54]# ./configure \     
> --user=nginx \           定义nginx运行的用户
> --group=nginx \        定义nginx运行的组
> --with-http_stub_status_module     \\启用站点状态统计模块
\\其他更多配置选项可以使用./configure --help命令进行查看
[root@localhost nginx-0.8.54]# make && make install
 
二.Nginx服务的运行控制
1.添加nginx运行的用户组:
[root@localhost nginx-0.8.54]# useradd -s /sbin/nologin nginx
 
2.Nginx默认安装在/usr/local/nginx目录下,为了方便应用,可以添加一个nginx主程序的符号链接:
[root@localhost nginx-0.8.54]# ln -sf /usr/local/nginx/sbin/nginx  /usr/sbin
 
3.使用nginx -t命令检查nginx配置文件是否有语法错误:
执行nginx -t后出现上述提示表示配置文件语法正确。
 
4.使用nginx启动服务,然后使用netstat命令进行查看:
[root@localhost nginx-0.8.54]# nginx
 
 
5.nginx启动成功后,可以在浏览器中查看初始的web页面:
在客户端浏览器中执行: http://172.16.10.118 服务器IP地址)进行查看:
 
另外在服务器命令行下使用文本浏览器工具elink进行查看:
[root@localhost nginx-0.8.54]# elinks  http://172.16.10.118
 
 
6.使用系统信号控制nginx进程:
[root@localhost~]# kill -s HUP nginx   //重新加载配置文件,等同于“killall -1 nginx”
[root@localhost~]# kill -s QUIT nginx  //安全退出,等同于“kill -3 nginx”
[root@localhost~]# kill -s TERM nginx //快速退出,不等待处理完当前连接
 
另外,为了方便管理,可以添加一个nginx服务脚本,使用chkconfig和service命令管理nginx服务:
[root@localhost~]# vi /etc/init.d./nginx
#!/bin/bash 
#chkconfig: - 99 20 
#description: Nginx Service Control Script 
case "$1" in 
  start) 
         /usr/sbin/nginx    
         ;; 
  stop) 
         /usr/bin/killall -s QUIT nginx 
            ;; 
  restart) 
         $0 stop 
         $0 start 
         ;; 
  reload) 
         /usr/bin/killall -s HUP nginx 
         ;; 
  *) 
    echo "Usage:$0 {start|stop|restart|reload}" 
    exit 1 
esac 
exit 0 

 
[root@localhost~]# chmod a+x /etc/init.d/nginx    为nginx脚本赋予可执行权限
[root@localhost~]# chkconfig --add nginx
[root@localhost~]# chkconfig --level 2345 nginx on
接下来就可以使用service nginx stop|start|restart|reload对nginx服务进行控制:
 
三.构建基于域名的虚拟主机
1.修改nginx主配置文件:
[root@localhost~]# vi /usr/local/nginx/conf/nginx.conf
 
user  nginx nginx;                 \\运行nginx的用户
worker_processes  8;           \\工作进程数
error_log  logs/error.log;       \\错误日志的位置
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;
pid        logs/nginx.pid;            \\进程文件默认位于/usr/local/nginx/logs/nginx.pid

events {
    use epoll;                               \\参考事件模型,用于2.6以上的内核
    worker_connections  65535;    \\每个工作进程可接受的连接数
}

http {
    include       mime.types;        \\文件扩展名与文件类型映射表
    default_type  application/octet-stream;   \\默认文件类型
    charset utf-8;                            \\站点页面文件使用的默认字符编码
    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';
    #access_log  logs/access.log  main;
    sendfile        on;           \\开启高效文件传输模式
    tcp_nopush      on;      \\防止网络阻塞
    tcp_nodelay     on;       \\防止延迟
    #keepalive_timeout  0;
    keepalive_timeout  65;   \\超时时间
    #gzip  on;
 #第一虚拟主机配置
  server {
        listen       80;                 \\监听端口
        server_name   www.sjzz.com;             \\站点的FQDN名称
        #charset koi8-r;
        #access_log  logs/host.access.log  main;
        location / {
            root   /var/www/sjzz;         \\网站的根目录
            index  index.html index.htm;        \\目录索引文件名
        }
        #error_page  404              /404.html;
        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
 location /Status {                 //站点状态统计
     stub_status on;
     access_log off;
 }
        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass    http://127.0.0.1;
        #}
        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}
        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }
#第二个虚拟主机配置
    # another virtual host using mix of IP-, name-, and port-based configuration
    #
    server {
         listen       80;         \\监听端口
    #    listen       somename:8080;
         server_name   www.linux5234.com;      \\站点的FQDN名称
         location / {
             root   /var/www/linux5234;          \\网站的根目录
             index  index.html index.htm;
         }
  
  location /Status {        //站点状态统计
      stub_status on;
      access_log off;
 }
    }

    # HTTPS server
    #
    #server {
    #    listen       443;
    #    server_name  localhost;
    #    ssl                  on;
    #    ssl_certificate      cert.pem;
    #    ssl_certificate_key  cert.key;
    #    ssl_session_timeout  5m;
    #    ssl_protocols  SSLv2 SSLv3 TLSv1;
    #    ssl_ciphers  ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;
    #    ssl_prefer_server_ciphers   on;
    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}
}
 
2.重启nginx服务:
[root@localhost~]# service nginx restart
 
3.建立虚拟主机对应网页目录及测试页面:
[root@localhost~]#  mkdir -p /var/www/sjzz   /var/www/linux5234
[root@localhost~]#  echo "This is www.sjzz.com" > /var/www/sjzz/index.html
[root@localhost~]#  echo "This is www.linxu5234.com" > /var/www/linux5234/index.html
 
4.在客户浏览器中访问不同的虚拟主机:
 
 
四.配置站点状态统计
1.修改nginx.conf文件,在server{........}配置部分分别添加如下配置项:
location /Status {
     stub_status on;            \\启用状态统计模块
     access_log off;             \\关闭日志记录
 }
2.重启nginx服务
[root@localhost~]# service nginx restart
 
3.在客户端浏览器中访问“http://www.sjzz.com/Status”和“http://www.sjzz.com/Status”,
即可看到站点的状态统计信息:
 
 
五.配置FastCGI方式支持的PHP页面
使用RHEL5系统自带的php软件包时,php-cgi工具由php-cli-5.1.6-23.2.el5_3
提供,位于/usr/bin/php-cgi。若使用源码包编译安装php环境,需要在“./configure”时添加“--enable-cgi”选项,同进去掉“--with-apxs2”选项,否则可能无法编译出php-cgi程序。本文采用系统默认安装php环境。
可以使用rpm -qa |grep php查看php-cli-5.1.6-23.2.el5_3是否安装,如果没有安装,就立即挂载光盘进行安装。
1.获取spawn-fcgi工具
spawn-fcgi从Lighttpd源码包中获得:
[root@localhost~]# tar zxf lighttpd-1.4.20.tar.gz
[root@localhost~]# cd lighttpd-1.4.20
[root@localhost~]# ./configure && make
[root@localhost~]# cp src/spawn-fcgi  /usr/sbin/
 
2.启动php-cgi
[root@localhost~]# spawn-fcgi -a 127.0.0.1 -p 9000 -f /usr/bin/php-cgi  -C 16    \\启动16个php-cgi子进程,在127.0.0.1的9000端口监听服务
3.查看spawn-fcgi运行状态:
使用ps aux |grep php-cgi查看进程:
 
4.如果需要在每次开机后都运行spawn-fcgi命令,可以将它添加到/etc/init.d/nginx或者/etc/rc.local脚本中:
[root@localhost~]# vi /etc/rc.local
/usr/sbin/spawn-fcgi -a 127.0.0.1 -p 9000 -f /usr/bin/php-cgi  -C 16   
 
5.修改nginx.conf配置文件,配置nginx支持PHP页面:
location ~ \.php$ {
     root   /var/www/php;
     fastcgi_pass 127.0.0.1:9000;
     fastcgi_index index.php;
     fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
     include fastcgi_params;
 }
 
重启nginx服务:
[root@localhost~]# service nginx restart
 
6.建立php网页目录和测试页面:
[root@localhost~]# mkdir /var/www/php
[root@localhost~]# vi /var/www/php/index.php
<?php
echo "PHP is OK!";
phpinfo{};
?>
 
7.在客户浏览器中进行验证(成功):









本文转自 kk5234 51CTO博客,原文链接:http://blog.51cto.com/kk5234/514578,如需转载请自行联系原作者
目录
相关文章
|
18天前
|
编解码 前端开发 JavaScript
构建高效响应式Web界面:现代前端框架的比较
【4月更文挑战第9天】在移动设备和多样屏幕尺寸盛行的时代,构建能够适应不同视口的响应式Web界面变得至关重要。本文深入探讨了几种流行的前端框架——Bootstrap、Foundation和Tailwind CSS,分析它们在创建响应式设计中的优势与局限。通过对比这些框架的栅格系统、组件库和定制化能力,开发者可以更好地理解如何选择合适的工具来优化前端开发流程,并最终实现高性能、跨平台兼容的用户界面。
|
19天前
|
前端开发 JavaScript 关系型数据库
从前端到后端:构建现代化Web应用的技术探索
在当今互联网时代,Web应用的开发已成为了各行各业不可或缺的一部分。从前端到后端,这篇文章将带你深入探索如何构建现代化的Web应用。我们将介绍多种技术,包括前端开发、后端开发以及各种编程语言(如Java、Python、C、PHP、Go)和数据库,帮助你了解如何利用这些技术构建出高效、安全和可扩展的Web应用。
|
1天前
|
开发框架 缓存 前端开发
利用Visual Basic构建高效的ASP.NET Web应用
【4月更文挑战第27天】本文探讨使用Visual Basic与ASP.NET创建高效Web应用的策略,包括了解两者基础、项目规划、MVC架构、数据访问与缓存、代码优化、异步编程、安全性、测试及部署维护。通过这些步骤,开发者能构建出快速、可靠且安全的Web应用,适应不断进步的技术环境。
|
2天前
|
前端开发 JavaScript Go
构建高性能Web应用:优化前端资源加载
在构建现代Web应用时,优化前端资源加载是至关重要的一步。本文将介绍一些提升Web应用性能的关键策略,包括减少HTTP请求、压缩和合并资源、使用CDN加速、以及异步加载技术等。通过实施这些优化策略,开发人员可以显著提升网站的加载速度和用户体验。
|
3天前
|
存储 中间件 Go
探索Gin框架:快速构建高性能的Golang Web应用
探索Gin框架:快速构建高性能的Golang Web应用
|
3天前
|
前端开发 JavaScript Java
前端与后端:构建现代Web应用的双翼
前端与后端:构建现代Web应用的双翼
|
11天前
|
应用服务中间件 Linux 开发工具
如何在阿里云服务器快速搭建部署Nginx环境
以下是内容的摘要: 本文档主要介绍了在阿里云上购买和配置服务器的步骤,包括注册阿里云账号、实名认证、选择和购买云服务器、配置安全组、使用Xshell和Xftp进行远程连接和文件传输,以及安装和配置Nginx服务器的过程。在完成这些步骤后,你将能够在服务器上部署和运行自己的网站或应用。
|
13天前
|
数据库 开发者 Python
Python中使用Flask构建简单Web应用的例子
【4月更文挑战第15天】Flask是一个轻量级的Python Web框架,它允许开发者快速搭建Web应用,同时保持代码的简洁和清晰。下面,我们将通过一个简单的例子来展示如何在Python中使用Flask创建一个基本的Web应用。
|
16天前
|
弹性计算 应用服务中间件 Linux
阿里云ECS服务器上从零开始搭建nginx服务器
阿里云ECS服务器上从零开始搭建nginx服务器
|
17天前
|
JavaScript 前端开发 API
Vue.js:构建高效且灵活的Web应用的利器
Vue.js:构建高效且灵活的Web应用的利器