LNMP是:Linux+Nginx+MySQL+PHP
由于Nginx拥有超越Apache的卓越性,LNMP正逐渐替代LAMP
Nginx:是一个高性能的HTTP和反向代理服务器软件,也是一个IMAP/POP3/SMPT代理服务器。
MySQL :是一个开放源码的小型关系型数据库管理系统,开发者为瑞典MySQL AB公司。目前MySQL被广泛地应用在Internet上的中小型网站中。由于体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库。
PHP: 是英文超级文本预处理语言Hypertext Preprocessor的缩写。PHP 是一种 HTML 内嵌式的语言,是一种在服务器端执行的嵌入HTML文档的脚本语言,语言的风格有类似于C语言,又因为是一种易于学习和使用的服务器端脚本语言,所以被广泛的运用。
一、安装Nginx
1、编译安装nginx需要事先需要安装开发包组“Development tools”和“development libraries”
# yum  groupinstall “Development tools” “Development libraries”  -y
 安装好开发包组后,要确认gcc、zlib-devel、openssl-devel、pcre-devel包已经安装上来,因为nginx依赖于这几个包,若没有安装则用下面方法安装:
 # yum   install   gcc openssl-devel pcre-devel zlib-devel  -y
2、为nginx添加系统用户和组
# groupadd -r nginx
# useradd -r -g nginx -s /sbin/nologin -M nginx
3、下载nginx并安装nginx
# tar xf nginx-1.0.13.tar.gz
# cd nginx-1.0.13
# ./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
4、编译完成之后先不要启动nginx,为nginx提供SysV init脚本
# 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/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
 
5、给脚本执行权限
 # chmod +x /etc/rc.d/init.d/nginx
8、添加到服务列表:
 # chkconfig  --add  nginx
 # chkconfig  nginx on
9、启动测试
 # service  nginx  start
 

二、接下来就要安装mysql-5.5.20
1、首先下载对应的mysql源码包至本地,根据自己的平台而定,这里是32位
因此,选择的为mysql-5.5.20-linux2.6-i686.tar.gz,
2、为安装mysql准备数据存储的文件系统,即新建一个逻辑卷,并将其挂载至特定目录即可
 在sda上划分一个逻辑分区如sda5
       # partprobe /dev/sda
       # pvcreate  /dev/sda5 创建物理卷
       # vgcreate  myvg  /dev/sda5  创建卷组
       # lvcreate -L 2G -n  mysql myvg  创建逻辑卷 -L 指定卷大小 -n 指定卷名 myvg指定属于哪个卷组
       # mke2fs  -j  /dev/myvg/mysql 格式化逻辑卷
       # mkdir -pv /mydata/data  创建两个目录mydata和data
       # vim /etc/fstab 打开配置文件在下面添加一行实现开机自动挂载
         /dev/myvg/mysql    /mydata      ext3    defaults  0 0
       # mount -a   将/dev/myvg/mysql挂载至/mydata
3、要想mysql安全运行还需要添加一个系统用户和组
    # groupadd -r mysql  创建系统组
    # useradd -g mysql -r -s /sbin/nologin -M  mysql  将用户加入组mysql 且用户没有家目录
    # chown -R mysql:mysql /mydata/data  将目录的属主属组都改为mysql
4、安装mysql
   # tar xf mysql-5.5.19-linux2.6-i686.tar.gz -C /usr/local  解压到/usr/local
   # cd  /usr/local
   # ln -sv mysql-5.5.19-linux2.6-i686  mysql  你会觉得mysql-5.5.19-linux2.6-i686这个目录很长所以有必要给它创建一个连接
   # cd mysql
   # chown -R mysql:mysql .  将当前所有目录及文件的属主属组都改为mysql
   # chown -R root . 
   # scripts/mysql_install_db --user=mysql --datadir=/mydata/data 初始化--user=mysql指定用户 --datadir=/mydata/data指定数据的存放的目录
   # cp support-files/my-large.cnf  /etc/my.cnf 为mysql 提供配置文件
   # vim /etc/my.cnf
      thread_concurrency = 2  找到这一行并将值改为你cpu数乘以2的值
      datadir = /mydata/data 添加这一行
   # cp support-files/mysql.server  /etc/rc.d/init.d/mysqld 为mysql提供sysv服务脚本
   # chkconfig --add mysqld  将mysqld添加到服务列表
   # chkconfig mysqld on  开机启动
5、输出mysql的man手册至man命令的查找路径:
   # vim /etc/man.config  编辑/etc/man.config,找到MANPATH在其下添加如下行即可:
   MANPATH  /usr/local/mysql/man
6、输出mysql的头文件至系统头文件路径/usr/include:
   # ln -sv /usr/local/mysql/include  /usr/include/mysql 用连接实现
7、输出mysql的库文件给系统库查找路径:
   # echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf
8、让系统重新载入系统库:
   # ldconfig
9、修改PATH环境变量,让系统可以直接使用mysql的相关命令。
   # vim /etc/profile 找到export PATH USER LOGNAME MAIL HOSTNAME HISTSIZE INPUTRC这一行
   在其上添加一行
     PATH=$PATH:/usr/local/mysql/bin:/usr/local/apache/bin
三、编译安装php-5.3.10
1、安装php之前要先安装好php所依赖的软件包
如果想让编译的php支持mcrypt、mcrypt、mhash扩展和libevent
如下面7个rpm包就是php所依赖和支持mcrypt、mhash、libevent包。
  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 -ivh *.rpm  --nodeps  忽略依赖关系升级安装以上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-mcrypt
 # make
 # make test
 # make intall
3、为php提供配置文件:
# cp php.ini-production /etc/php/php.ini
4、为php-fpm提供Sysv init脚本,并将其添加至服务列表:
# cp sapi/fpm/init.d.php-fpm  /etc/rc.d/init.d/php-fpm
# chkconfig --add php-fpm
# chkconfig php-fpm on
5、为php-fpm提供配置文件:
# cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf
6、编辑php-fpm的配置文件:
 # vim /usr/local/php/etc/php-fpm.conf
配置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
8、接下来就可以启动php-fpm了:
# service php-fpm start
四、 nginx和php5结合
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;

3、并在所支持的主页面格式中添加php格式的主页,如下:
location / {
            root   html;
            index  index.php index.html index.htm;
        }
       
4、重新载入nginx的配置文件:
# service nginx reload
5、在/usr/html新建index.php的测试页面,测试php是否能正常工作:
# vim /usr/html/index.php
<?php
phpinfo();
?>
6、可以通过浏览器测试了