centOS6如何编译LNMP环境

2025-10-28 04:27:02

1、                                   LNMP环境部署

 LNMP(nginx、mysql、php)

一、安装Nginx:

1、解决依赖关系

编译安装nginx需要事先需要安装开发包组"Development Tools"和 "Development Libraries"。同时,还需要专门安装pcre-devel包:

# yum -y install pcre-devel

# yum -y groupinstall 'Development Tools' 'Development Libraries'

2、安装

首先添加用户nginx,实现以之运行nginx服务进程:

# groupadd -r nginx              添加nginx用户和用户组把nginx放里面

# useradd -r -g nginx nginx

接着开始编译和安装:

# ./configure \

  --prefix=/usr/local/nginx \                   路径

  --sbin-path=/usr/local/nginx/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  \        pid文件位置

  --lock-path=/var/lock/nginx.lock \            锁文件位置

  --user=nginx \                                用户

  --group=nginx \                               用户组

  --with-http_ssl_module \                      ssl模块启动

  --with-http_flv_module \                      

  --with-http_stub_status_module \              模块启动

  --with-http_gzip_static_module \              压缩静态模块启动

  --http-client-body-temp-path=/var/tmp/nginx/client/ \ 客户端默认的boby的路径

  --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的perl模块,可以通过为configure脚本添加--with-http_perl_module选项来实现,但目前此模块仍处于实验性使用阶段,可能会在运行中出现意外,因此,其实现方式这里不再介绍。如果想使用基于nginx的cgi功能,也可以基于FCGI来实现,具体实现方法请参照网上的文档。

3、为nginx提供SysV init脚本:

新建文件/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/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 2

esac

而后为此脚本赋予执行权限:

# chmod +x /etc/rc.d/init.d/nginx

添加至服务管理列表,并让其开机自动启动:

# chkconfig --add nginx

# chkconfig nginx on

而后就可以启动服务并测试了:

# service nginx start

如果启动不起来的话:

/usr/local/nginx/sbin/nginx 

这样就可以启动开了

2、编译安装mysql

1、检查是否安装了mysql

[root@localhost Desktop]# rpm -qa|grep mysql  

如果安装了就卸载

强制删除

rpm -e mysql-libs-版本号--nodeps  

普通模式删除

rpm -e mysql   

创建用户组并且添加一个用户

groupadd mysql  

创建一个用户,不允许登陆和不创主目录  

useradd -s /sbin/nologin -g mysql -M mysql  

检查创建用户  

tail -1 /etc/passwd  

2.安装编译代码需要的包

yum -y install make gcc-c++ cmake bison-devel  ncurses-devel  

下载安装包

tar -zxvf mysql-5.6.13.tar.gz  

cd mysql  

执行以下命令:

cmake \  

-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \  

-DMYSQL_DATADIR=/usr/local/mysql/data \  

-DSYSCONFDIR=/etc \  

-DWITH_MYISAM_STORAGE_ENGINE=1 \  

-DWITH_INNOBASE_STORAGE_ENGINE=1 \  

-DWITH_MEMORY_STORAGE_ENGINE=1 \  

-DWITH_READLINE=1 \  

-DMYSQL_UNIX_ADDR=/var/lib/mysql/mysql.sock \  

-DMYSQL_TCP_PORT=3306 \  

-DENABLED_LOCAL_INFILE=1 \  

-DWITH_PARTITION_STORAGE_ENGINE=1 \  

-DEXTRA_CHARSETS=all \  

-DDEFAULT_CHARSET=utf8 \  

-DDEFAULT_COLLATION=utf8_general_ci \  

-DMYSQL_USER=mysql \  

-DWITH_DEBUG=0 \  

-DWITH_SSL=system  

make && make install  

3.修改/usr/local/mysql权限

chmod +w /usr/local/mysql  

chown -R mysql:mysql /usr/local/mysql  

[root@localhost mysql]# cp support-files/my-default.cnf /etc/my.cnf  

执行初始化配置脚本,创建系统自带的数据库和表,配置文件的路径:

/usr/local/mysql/scripts/mysql_install_db --defaults-file=/etc/my.cnf --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql  

拷贝mysql安装目录下support-files服务脚本到init.d目录

[root@localhost mysql]# cp support-files/mysql.server /etc/init.d/mysqld  

赋予权限:

chmod +x /etc/init.d/mysqld  

设置开机启动/可以不操作

chkconfig mysqld on  

启动mysql

service mysqld start  

或者  

/etc/init.d/mysql start  

MySQL5.6.x启动成功后,root默认没有密码,我们需要设置root密码。设置之前,我们需要先设置PATH,要不,不能直接调用mysql,操作如下:

修改/etc/profile文件

root@localhost mysql]# vim /etc/profile  

在文件末尾添加

PATH=/usr/local/mysql/bin:$PATH

export PATH

让配置立即生效

[root@localhost mysql]# source /etc/profile  

8.登陆测试,默认是没有密码,直接回车就可进入

9.设置mysql密码(这一步可以先不设置),命令如下:

/usr/local/mysql/bin/mysqladmin -uroot -p password '你的密码'  

10.验证mysql安装路径

[html] view plain copy

ls -ld /usr/local/mysql/  

补充如果mysql还是无法打开需要修改以下的参数:针对于必须加:-h 127.0.0.1才能进入mysql的解决办法

1、可能是第二次在机器上安装mysql,有残余数据影响了服务的启动。

解决方法:去mysql的数据目录/data看看,如果存在mysql-bin.index,就赶快把它删除掉吧,它就是罪魁祸首了。本人就是使用第三条方法解决的 !

2、mysql在启动时没有指定配置文件时会使用/etc/my.cnf配置文件,请打开这个文件查看在[mysqld]节下有没有指定数据目录(datadir)。

解决方法:请在[mysqld]下设置这一行:datadir = /usr/local/mysql/data

3、编译安装php-5.4.4

1、解决依赖关系:

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

yum install -y libmcrypt libevent-devel mhash mhash-devel mcrypt  

yum install -y libevent libevent-devel

2、编译安装php-5.4.26

首先下载源码包至本地目录

# tar xf php-5.4.26.tar.bz2

# cd php-5.4.26

#  ./configure --prefix=/usr/local/php --with-mysql=/usr/local/mysql --with-openssl --enable-fpm --enable-sockets --enable-sysvshm  --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 --with-config-file-scan-dir=/etc/php.d --with-bz2 --with-curl 

# make

# make intall

为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

为php-fpm提供配置文件:

# 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

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

pm.max_children = 150

pm.start_servers = 8

pm.min_spare_servers = 5

pm.max_spare_servers = 10

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

接下来就可以启动php-fpm了:

# service php-fpm start

使用如下命令来验正(如果此命令输出有中几个php-fpm进程就说明启动成功了):

# ps aux | grep php-fpm

四、整合nginx和php5

1、编辑/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、编辑/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;

        }

        

而后重新载入nginx的配置文件:

# service nginx reload

3、在/usr/html新建index.php的测试页面,测试php是否能正常工作:

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

<?php

phpinfo();

?>

接着就可以通过浏览器访问此测试页面了。

补充:浏览器打不开的话就需要把防火墙和selinux关掉

五、安装xcache,为php加速:

1、安装

# tar xf xcache-3.1.0.tar.gz

# cd xcache-3.1.0

# /usr/local/php/bin/phpize

# ./configure --enable-xcache --with-php-config=/usr/local/php/bin/php-config

# make && make install

安装结束时,会出现类似如下行:

Installing shared extensions:     /usr/local/php/lib/php/extensions/no-debug-zts-20100525/

2、编辑php.ini,整合php和xcache:

首先将xcache提供的样例配置导入php.ini

# mkdir /etc/php.d

# cp xcache.ini /etc/php.d

说明:xcache.ini文件在xcache的源码目录中。

接下来编辑/etc/php.d/xcache.ini,找到zend_extension开头的行,修改为如下行:

zend_extension = /usr/local/php/lib/php/extensions/no-debug-zts-20100525/xcache.so

注意:如果php.ini文件中有多条zend_extension指令行,要确保此新增的行排在第一位。

3、重新启动php-fpm

# service php-fpm restart

声明:本网站引用、摘录或转载内容仅供网站访问者交流或参考,不代表本站立场,如存在版权或非法内容,请联系站长删除,联系邮箱:site.kefu@qq.com。
相关推荐
  • 阅读量:164
  • 阅读量:71
  • 阅读量:114
  • 阅读量:178
  • 阅读量:184
  • 猜你喜欢