首页 > 系统管理 > LNMP环境搭建
2015
05-10

LNMP环境搭建

经历了6个多小时的艰难磨练,lnmp终于搭建成功,虽然安装时间大大的超出了预估,但是对于一个新手来说,大家就多多体谅了。废话少说,接下来就是安装lnmp的全过程:

首先,准备好安装lnmp的组件包“cmake-3.2.2.tar.gz  mysql-5.6.4-m7.tar.gz  nginx-1.8.0.tar.gz  php-5.6.8.tar.gz”版本是5月9号在http://nginx.org/en/download.html下载新版nginx ,http://php.net/get/php-5.6.8.tar.gz/from/a/mirror 下载新版php,其他的组件包是百度搜索到的。

我们把安装组件放置到linux/usr/local下如图所示:

blob.png

我们先安装NGINX

第一步,安装相关的组件,这里yum安装就可以了,接着新建nginx账户,

# yum -y install  rpcbind subversion libpng gd gcc gcc-c++ pcre-devel   pcre-devel  nmap rsync iptraf sysstat wget dmidecode openssh-clientszlib-devel openssl* ncurses-devel  libmcrypt-devel  expect
#groupadd –r nginx
#useradd –r –g nginx nginx

如图所示:

blob.png

第二步,解压nginx安装包,紧跟着进入nginx-1.8.0目录进行编译安装,如图所示:

blob.png

 blob.png

编译编码如下所示:

./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

第三步,为nginx提供SysV init脚本,新建文件/etc/rc.d/init.d/nginx,把以下内容复制到前面提到的目录下:

blob.png

#!/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

如图所示:

blob.png

关闭iptables

#chkconfig  iptables  off

查看是否已经关闭:

chkconfig –list | grep iptables

blob.png

到此nginx安装完毕

blob.png

接下来我们安装PHP

第一步安装相关组件,然后进行编译安装:

#  yum install libxml2-devel   openssl-devel  bzip2-devel libmcrypt-devel   -y
#tar xf php-5.5.5.tar.gz
#cd  php-5.5.5
# ./configure --prefix=/usr/local/httpd/php --with-mysql=mysqlnd --with-openssl --with-mysqli=mysqlnd --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml  --enable-sockets --enable-fpm --with-mcrypt  --with-config-file-path=/etc --with-config-file-scan-dir=/etc/php.d --with-bz2
#make && make install

备注:如果在cheking 时发生错误:

blob.png

第二步,为php提供配置文件

# cp php.ini-production /etc/php.ini

为php-fpm提供Sysv init脚本,并将其添加至服务列表

# cp sapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm
# chmod +x /etc/rc.d/init.d/php-fpm
# chkconfig --add php-fpm
# chkconfig php-fpm on

blob.png

第三步,修改配置文件信息

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

内容为监听端口,配置信息按需求修改。

blob.png

#service php-fpm start
#netstat –antp

  显示出 nginx、php 端口 

blob.png

第四步,编辑/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;

第五步,接着在/usr/html新建index.php的测试页面,测试php是否能正常工作:

#vim /usr/html/index.php
<?php
phpinfo();
?>

测试页面成功!

blob.png

接下来我们安装MYSQL

接下来安装mysql

第一步,配置mysql账户信息

#mkdir -p /mydata/data
#groupadd -r mysql 
#useradd -g mysql -r -s /sbin/nologin -M -d /mydata/data mysql  #chown -R mysql:mysql /mydata/data

blob.png

第二步,yum安装相关包组件“(可选)

# yum -y install gcc gcc-c++ autoconf automake zlib* libxml2* ncurses ncurses-devel libtool-ltdl-devel*

下面是cmake编译安装mysql的准备工作:解压并进入cmake目录用。

#./bootstrap
#gmake && gmake install

blob.png

第三步,编译安装mysql

#cmake . \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql-5.6.4-m7 \
    -DWITH_INNOBASE_STORAGE_ENGINE=1 \
    -DWITH_ARCHIVE_STORAGE_ENGINE=1 \
    -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
    -DWITH_FEDERATED_STORAGE_ENGINE=1 \
    -DWITH_PARTITION_STORAGE_ENGINE=1 \
    -DWITH_READLINE=1 \
    -DENABLED_LOCAL_INFILE=1 \
    -DEXTRA_CHARSETS=all \
    -DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci
#make && make install

如图所示:

blob.png

blob.png

第四步,初始化数据库

# cd /usr/local/mysql-5.6.4-m7/
# chown  -R mysql.mysql .
# ./scripts/mysql_install_db --user=mysql --datadir=/mydata/data

如图所示:

blob.png

第五步,配置mysql

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

datadir = /mydata/data

启动数据库

# cp support-files/mysql.server  /etc/init.d/mysqld
# chmod +x /etc/init.d/mysqld 
# /etc/init.d/mysqld start

如图所示:

blob.png

第六步,进入mysql

#ln -s /usr/local/mysql-5.6.4-m7 /usr/local/mysql
# echo "PATH=/usr/local/mysql/bin:$PATH" >> /etc/profile
# echo "export PATH" >> /etc/profile
# source  /etc/profile
# mysql

如图所示:

blob.png

第七部,给mysql用户授权:

GRANT ALL PRIVILEGES ON *.* TO 'root'@'ip address' IDENTIFIED BY 'password' WITH GRANT OPTION;

刷新权限:

FLUSH PRIVILEGES;

如图所示:

blob.png

至此lnmp环境搭建完毕,优化配置根据自己的需要来定。

如有问题请加入QQ群:347163978  找大圣询问,好了,写这么多 好好休息一下!!!




最后编辑:
作者:tshare365
这个作者貌似有点懒,什么都没有留下。
捐 赠您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请狠狠点击

留下一个回复