LNMP指的是在Linux系统下Nginx+MySQL+PHP这种网站服务器的架构.此时我们需用到nginx. Nginx 是一个高性能的 HTTP 和 反向代理服务器.作为 Web 服务器,和Apache相比,Nginx 使用更少的资源,支持更多的并发连接,体现更高的效率.当然Apache也有它自己的优点,比如功能丰富,稳定等等.今天主要介绍一下LNMP的实现.安装LNMP的过程和LAMP的类似,因此如果你会配置LAMP,相信这个就对你来说就不在话下了.

此处用到的软件版本为nginx-1.0.13.tar.gz  mysql-5.5.20 php-5.3.10 以下为安装过程:

首先安装Nginx

1、准备工作

# yum -y install pcre-devel  (需事先配置好yum)

#yum –y Development Libraries Development Tools  开发组件 如果安装了,可略过此步骤

下载nginx-1.0.13.tar.gz到本地(Nginx的官网www.nginx.org)

2、安装nginx

# groupadd -r nginx

# useradd -r -g nginx -s /sbin/nologin -M nginx

#tar xf nginx-1.0.13.tar.gz

# ./configure \

  --prefix=/usr \

  --sbin-path=/usr/sbin/nginx \

  --conf-path=/etc/nginx/nginx.conf \

  --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 \

  --user=nginx \

  --group=nginx \

  --with-http_ssl_module \

  --with-http_flv_module \

  --with-http_stub_status_module \

  --with-http_gzip_static_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/fcgi/ \

  --http-uwsgi-temp-path=/var/tmp/nginx/uwsgi \

  --http-scgi-temp-path=/var/tmp/nginx/scgi \

  --with-pcre

# make

# make install

3、为了使用起来更方便,我们为nginx提供SysV init脚本:

  #vim / etc/rc.d/init.d/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="/usr/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

# chmod +x /etc/rc.d/init.d/nginx  为此脚本赋予执行权限

# chkconfig --add nginx 添加至服务列表

# chkconfig nginx on   让其开机启动

# service nginx start  启动nginx 可以进行测试了

此时Nginx已安装配置完毕。

接下来开始安装mysql-5.5.20

1、  准备数据存放的文件系统 (一般我们将数据目录放在逻辑卷上,以方便快照来备份数据)

#fdisk /dev/sda  新建一个逻辑分区 将其id改为8e 这里创建了一个分区/dev/sda5

#partprobe /dev/sda

#vgcreate myvg /dev/sda5

#lvcreate –L 2G –n mysql myvg    

#mke2fs –j /dev/myvg/mysql

#mkdir –pv /mydata/mysql   此处是为了将mysql的数据库文件存放/mydata/mysql目录中(当然你可自己定义它的存放位置)

#vim /etc/fstab 添加如下行

     /dev/myvg/mysql     /mydata       ext3      defaults  0  0

    #mount –a

2、新建用户以安全方式运行进程:

# groupadd -r mysql

# useradd -g mysql -r -s /sbin/nologin -M -d /mydata/data mysql

# chown -R mysql:mysql /mydata/data

3、安装并初始化mysql-5.5.20

下载平台对应的mysql版本至本地 然后执行如下命令

# tar xf mysql-5.5.20-linux2.6-i686.tar.gz -C /usr/local

# cd /usr/local/

# ln -sv mysql-5.5.20-linux2.6-i686  mysql

# cd mysql

# chown -R mysql:mysql  .

# scripts/mysql_install_db --user=mysql --datadir=/mydata/mysql

# chown -R root .

4、为mysql提供主配置文件:

# cd /usr/local/mysql

# cp support-files/my-large.cnf  /etc/my.cnf

#vim /etc/my.cnf  修改如下

thread_concurrency = 2    此处修改thread_concurrency的值为本机CPU个数乘以2

datadir = /mydata/data  添加此行指定mysql数据文件的存放位置

5、也是为方便使用此服务,在此为mysql提供sysv服务脚本:

# cd /usr/local/mysql

# cp support-files/mysql.server  /etc/rc.d/init.d/mysqld

# chkconfig --add mysqld  添加至服务列表

# chkconfig mysqld on  开机启动

以下为使用mysql符合相应的系统规范,我们将其导出

输出mysqlman手册至man命令的查找路径:

    #vim /etc/man.config 添加如下行

MANPATH  /usr/local/mysql/man

输出mysql的头文件至系统头文件路径/usr/include

# ln -sv /usr/local/mysql/include  /usr/include/mysql

输出mysql的库文件给系统库查找路径:

# echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf

# ldconfig  重新载入库文件

修改PATH环境变量,让系统可以直接使用mysql的相关命令。

#vim /etc/profile 添加如下行

PATH=$PATH:/usr/local/mysql

#export PATH=$PATH:/usr/local/mysql  即可使用mysql命令

到此mysql安装完毕

 

最后编译安装php-5.3.10  (此处编译安装phpLAMP中的编译php会有所不同,此处是将其编译成一个独立的服务)

1、准备工作

# yum -y groupinstall "X Software Development"  (前提配置好yum)

如果想让编译的php支持mcryptmcryptmhash扩展和libevent,此处还需要下载如下几个rpm包并安装之:

libmcrypt-2.5.8-4.el5.centos.i386.rpm

libmcrypt-devel-2.5.8-4.el5.centos.i386.rpm

mhash-0.9.9-1.el5.centos.i386.rpm

mhash-devel-0.9.9-1.el5.centos.i386.rpm

libevent-2.0.17-2.i386.rpm

libevent-devel-2.0.17-2.i386.rpm

mcrypt-2.6.8-1.el5.i386.rpm

命令如下:

# rpm -Uvh libmcrypt-2.5.8-4.el5.centos.i386.rpm libmcrypt-devel-2.5.8-4.el5.centos.i386.rpm

#rpm –Uvh mhash-0.9.9-1.el5.centos.i386.rpm mhash-devel-0.9.9-1.el5.centos.i386.rpm

#rpm –Uvh libevent-2.0.17-2.i386.rpm libevent-devel-2.0.17-2.i386.rpm

#rpm –Uvh mcrypt-2.6.8-1.el5.i386.rpm

2、  编译安装php-5.3.10 下载此软件包到本地后执行如下命令

# tar xf php-5.3.10.tar.bz2

# cd php-5.3.10

# ./configure --prefix=/usr/local/php --with-mysql=/usr/local/mysql --with-openssl --enable-fpm --with-mysqli=/usr/local/mysql/bin/mysql_config --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib-dir --with-libxml-dir=/usr --enable-xml  --with-mhash --with-mcrypt  --with-config-file-path=/etc/php --with-config-file-scan-dir=/etc/php --with-bz2 --with-curl --with-mcryp

# make

# make test

# make intall

# cp php.ini-production /etc/php/php.ini 提供配置文件

# cp sapi/fpm/init.d.php-fpm  /etc/rc.d/init.d/php-fpm

# chkconfig --add php-fpm

# chkconfig php-fpm on

# cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf

 php-fpm提供配置文件

# vim /usr/local/php/etc/php-fpm.conf    php-fpm的配置文件

配置pm.的相关选项为你所需要的值,并启用pid文件(如下最后一行):

pm.max_children = 50

pm.start_servers = 5

pm.min_spare_servers = 2

pm.max_spare_servers = 8

pid = /var/run/php-fpm.pid

# service php-fpm start 配置完成即可启动php-fpm

# ps aux | grep php-fpm  验证服务

到此php已经准备完备,以下将nginxphp进行整合以便使用

1#vim /etc/nginx/nginx.conf     启用如下选项:

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;

        }

2#vim /etc/nginx/fastcgi_params    将其内容更改为如下内容:

fastcgi_param  GATEWAY_INTERFACE  CGI/1.1;

fastcgi_param  SERVER_SOFTWARE    nginx;

fastcgi_param  QUERY_STRING       $query_string;

fastcgi_param  REQUEST_METHOD     $request_method;

fastcgi_param  CONTENT_TYPE       $content_type;

fastcgi_param  CONTENT_LENGTH     $content_length;

fastcgi_param  SCRIPT_FILENAME    $document_root$fastcgi_script_name;

fastcgi_param  SCRIPT_NAME        $fastcgi_script_name;

fastcgi_param  REQUEST_URI        $request_uri;

fastcgi_param  DOCUMENT_URI       $document_uri;

fastcgi_param  DOCUMENT_ROOT      $document_root;

fastcgi_param  SERVER_PROTOCOL    $server_protocol;

fastcgi_param  REMOTE_ADDR        $remote_addr;

fastcgi_param  REMOTE_PORT        $remote_port;

fastcgi_param  SERVER_ADDR        $server_addr;

fastcgi_param  SERVER_PORT        $server_port;

fastcgi_param  SERVER_NAME        $server_name;

并在所支持的主页面格式中添加php格式的主页,内容如下:

location / {

            root   html;

            index  index.php index.html index.htm;

            }

# service nginx reload重新载入nginx的配置文件

到此LNMP平台已搭建成功 下面就可提供测试页面测试了

提供测试页面

# cat > /usr/html/index.php << EOF

<?php

phpinfo();

?>

用浏览器访问此页面测试LNMP是否能正常工作,到此lNMP已搭建成功