>

编译安装LAMP情形,情况搭建

- 编辑:正版管家婆马报彩图 -

编译安装LAMP情形,情况搭建

一、Linux

LAMP环境配置:httpd-2.4.23 + mysql-5.5.51 +php-5.5.38编译安装过程
编译前先准备系统的开发环境:

操作系统:CentOS 6.4

# yum groupinstall "Development tools" "Server Platform Development"

1.配置好可用的yum源

一、编译安装apache

2.开发环境支持:

1、解决依赖关系
httpd-2.4.23需要较新版本的apr和apr-util,因此需要事先对其进行升级。升级方式有两种,一种是通过源代码编译安装,一种是直接升级rpm包。这里采用源码编译方式;
(1) 编译安装apr

# yum groupinstall -y "Development tools"

# tar zxf apr-1.5.2.tar.gz
# cd apr-1.5.2
# ./configure --prefix=/usr/local/apr
# make && make install

# yum groupinstall -y "Server Platform Development"

(2) 编译安装apr-util

Ubuntu 13.04 安装 LAMPVsftpdWebminphpMyAdmin 服务及设置 http://www.linuxidc.com/Linux/2013-06/86250.htm

# tar xf apr-util-1.5.4.tar.gz
# cd apr-util-1.5.4
# ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr
# make && make install

CentOS 5.9下编译安装LAMP(Apache 2.2.44+MySQL 5.6.10+PHP 5.4.12) http://www.linuxidc.com/Linux/2013-03/80333p3.htm

(3)httpd-2.4.23编译过程也要依赖于pcre-devel软件包,需要事先安装。此软件包系统光盘自带,因此,找到并安装即可。

RedHat 5.4下Web服务器架构之源码构建LAMP环境及应用PHPWind http://www.linuxidc.com/Linux/2012-10/72484p2.htm

# yum install -y pcre-devel

LAMP源码环境搭建WEB服务器Linux+Apache+MySQL+PHP http://www.linuxidc.com/Linux/2013-05/84882.htm

(4)创建用户,组

二、Apache

# groupadd -r apache
# useradd -r -g apache apache

 编译安装httpd-2.4.9

2.编译安装httpd-2.4.23

1.安装pcre-devel(依赖包)

首先下载httpd-2.4.23到本地:httpd-2.4.23.tar.gz

#yum install pcre-devel -y

# tar xf httpd-2.4.23.tar.gz
# cd httpd-2.4.23
# ./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd24 --enable-so --enable-ssl --enable-cgi --enable-rewrite --with-zlib --with-pcre --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util --enable-modules=most --enable-mpms-shared=all --with-mpm=event
# make -j 4 && make install

(关于pcre: http://www.linuxidc.com/Linux/2014-04/99536.htm)

提供SysV服务脚本/etc/rc.d/init.d/httpd

2.安装apr,apr-util

# cp /etc/rc.d/init.d/httpd /etc/rc.d/init.d/httpd24 #这个httpd服务脚本拷贝系统预装httpd2.2的服务脚本修改下面几行:
    vim /etc/rc.d/init.d/httpd24
            apachectl=/usr/local/apache/bin/apachectl
            httpd=${HTTPD-/usr/local/apache/bin/httpd}
            prog=httpd
            pidfile=${PIDFILE-/usr/local/apache/logs/httpd.pid}#注意:httpd.pid默认位置
            lockfile=${LOCKFILE-/var/lock/subsys/httpd24}

#tar -xf apr-1.5.0.tar.bz2 -C /usr/src/

加入服务列表:
# chkconfig --add httpd
# chkconfig --list httpd24

#cd /usr/src/apr-1.5.0

测试启动:

#./configure  --prefix=/usr/local/apr  //指定其安装位置

service httpd24 restart
使用浏览器访问当前主机显示It Works 表示成功。

# make && make install

注意:如果用httpd -t 报错找不到指定文件,可以通过软链接的方式将httpd指向指定目录:
# ln -sv /usr/local/apache/bin/httpd /usr/local/sbin/httpd

        (关于apr: )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       

二、安装mysql-5.5.51

#tar -xf apr-util-1.5.3.tar.bz2 -C /usr/src/

(1)准备数据存放的文件系统

# cd /usr/src/apr-util-1.5.3

##创建一个mydata单独的LVM2文件系统
        #fdisk /dev/sda3
        #pvcreate /dev/sda3
        #vgcreate myvg /dev/sda3
        #lvcreate -L 10G -n mydata myvg
        #mke2fs -t ext4 /dev/myvg/mydata
        #mkdir /mydata
        #vim /etc/fstab 添加:/dev/myvg/mydata /mydata ext4 defaults 0 0
        #mount -a
        #cd /mydata;mkdir data
        #chown mysql:mysql data

# ./configure  --prefix=/usr/local/apr-util  --with-apr=/usr/local/apr

       
(2)创建用户,组           

# make && make install

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

3.安装httpd

(3)安装mysql-5.5.51

#tar -xf httpd-2.4.9.tar.bz2 -C /usr/src

# tar zxf mysql-5.5.51-linux2.6-i686.tar.gz -C /usr/local/
# cd /usr/local/
# ln -sv mysql-5.5.51-linux2.6-i686/ mysql
# cd mysql

# cd /usr/src/httpd-2.4.9

(4)安装并初始化mysql-5.5.51

# ./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd --enable-so --enable-ssl --enable-cgi --enable-rewrite --with-zlib --with-pcre --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util --enable-modules=most --enable-mpms-shared=most --with-mpm=event

# chown -R mysql:mysql .
# scripts/mysql_install_db --user=mysql --datadir=/mydata/data
# chown -R root .

================================================================

(5)为mysql提供主配置文件:

释义:

# cd /usr/local/mysql
# cp support-files/my-large.cnf  /etc/my.cnf
#并修改此文件中thread_concurrency的值为你的CPU个数乘以2,比如这里使用如下行:
thread_concurrency = 2
另外还需要添加如下行指定mysql数据文件的存放位置:
datadir = /mydata/data

--prefix=/usr/local/apache  #→指定其安装位置

(6)拷贝服务脚本

--sysconfdir=/etc/httpd  #→指定配置文件安装位置

# cd /usr/local/mysql
# cp support-files/mysql.server /etc/rc.d/init.d/mysqld
# chmod +x /etc/rc.d/init.d/mysqld

--enable-so  #→启用基于DSO的方式动态加载模块

(7)添加服务列表

--enable-ssl  #→启用基于https协议的功能

# chkconfig --add mysqld
# chkconfig mysqld on
# chkconfig --list mysqld

--enable-cgi  #→启用基于cgi协议的功能

(8)添加系统环境变量

--enable-rewrite  #→启用支持URL重写的功能

 # vim /etc/profile.d/mysql.sh
    #!/bin/bash
    #
    export PATH=/usr/local/mysql/bin:$PATH
# source /etc/profile.d/mysql.sh
测试启动:service mysqld restart

--with-zlib  #→指定支持在互联网上发送数据报文时,通用的压缩库的API

使用mysql命令登陆本地数据库,并给数据库创建密码
    mysql> use mysql
    mysql> update user set password=password('root') where user='root';
    mysql> select user,host,password from user;
    mysql> drop user ''@'localhost';#删除匿名用户
    mysql> drop user ''@'liu';
    mysql> flush privileges;

--with-pcre  #→指定支持poll的cgi

注意:额外配置:

--with-apr=/usr/local/apr    #→指定par的安装路径

1、输出mysql的man手册至man命令的查找路径:
编辑/etc/man.config,添加如下行即可:
MANPATH  /usr/local/mysql/man
2、输出mysql的头文件至系统头文件路径/usr/include:
这可以通过简单的创建链接实现:
# ln -sv /usr/local/mysql/include  /usr/include/mysql
3、输出mysql的库文件给系统库查找路径:
# echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf
而后让系统重新载入系统库:
# ldconfig

--with-apr-util=/usr/local/apr-util/  #→指定par-util的安装路径

三、编译安装php-5.5.38
1、解决依赖关系:

--enable-modules=most  #→启用大多数常用的模块

请配置好yum源(系统安装源及epel源)后执行如下命令:
# yum -y groupinstall "Desktop Platform Development"
# yum -y install bzip2-devel libmcrypt-devel libxml2-devel
libmcrypt-devel 需要epel yum源进行安装。

--enable-mpms-shared=all  #→启用加载所有的mpm模块

2.安装php-5.5.38

--with-mpm=event    #→指定接下来httpd的工作模式是event

# tar zxf php-5.5.38.tar.gz
# cd php-5.5.38
# ./configure --prefix=/usr/local/php --with-mysql=/usr/local/mysql --with-openssl --with-mysqli=/usr/local/mysql/bin/mysql_config --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml  --enable-sockets --with-apxs2=/usr/local/apache/bin/apxs --with-mcrypt  --with-config-file-path=/etc --with-config-file-scan-dir=/etc/php.d --with-bz2  --enable-maintainer-zts

======================================================================

说明:
1、这里为了支持apache的worker或event这两个MPM,编译时使用了--enable-maintainer-zts选项。
2、如果使用PHP5.3以上版本,为了链接MySQL数据库,可以指定mysqlnd,这样在本机就不需要先安装MySQL或MySQL开发包了。mysqlnd从php 5.3开始可用,可以编译时绑定到它(而不用和具体的MySQL客户端库绑定形成依赖),但从PHP 5.4开始它就是默认设置了。
# ./configure --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd

# make && make install

1 # make -j 4 && make install

模块加载的方式:

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

    a).静态:使用--with-mpm=指定模块名称;一旦编译安装完成,无法卸载,只能从新编译安装。

3、 编辑apache配置文件httpd.conf,以apache支持php

    b).动态:使用--enable-mpms-shared选项即可启用此特性。当给出的参数为all时,所有此平台支持的MPM模块都会被安装。可运行时加载,构建 MPM 为动态模块允许通过修改LoadModule指令内容来改变MPM,而不用重新编译安装。

  # vim /etc/httpd/httpd.conf
 1、添加如下二行
  AddType application/x-httpd-php  .php
  AddType application/x-httpd-php-source  .phps
 2、定位至DirectoryIndex index.html
  修改为:
    DirectoryIndex  index.php  index.html

    配置:

而后重新启动httpd,或让其重新载入配置文件即可测试php是否已经可以正常使用。

    a).设置pid文件的路径:

4、测试php安装是否成功:

#vim /etc/httpd/httpd.conf    //添加

测试页面index.php示例如下:
    <?php
      $link = mysql_connect('127.0.0.1','root','root');
      if ($link)
        echo "Success...";
      else
        echo "Failure...";

  PidFile "/var/run/httpd.pid"

      mysql_close();
      phpinfo();
    ?>
   
四、LAMP环境测试

b).配置httpd服务脚本

        这里使用phpMyAdmin测试
        mv phpMyAdmin-4.4.14.1-all-languages /usr/local/apache/htdocs/pma
        cd /usr/local/apache/htdocs/pma
        cp config.sample.inc.php config.inc.php
        vim config.inc.php
        ab -c 10 -n 100 #压力测试
       
五、安装xcache,为php加速:

#vim /etc/rc.d/init.d/httpd  //修改

1、安装xcache-3.2.0
# tar zxf xcache-3.2.0.tar.gz
# cd xcache-3.2.0
# /usr/local/php/bin/phpize
# ./configure --enable-xcache --with-php-config=/usr/local/php/bin/php-config
# make && make install

    apachectl=/usr/local/apache/bin/apachectl

安装结束时,会出现类似如下行:
Installing shared extensions:    /usr/local/php/lib/php/extensions/no-debug-zts-20121212/

    httpd=${HTTPD-/usr/local/apache/bin/httpd}

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

  c).权限+启动

首先将xcache提供的样例配置导入php.ini
# mkdir /etc/php.d
# cp xcache.ini /etc/php.d

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

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

# chkconfig --add httpd

接下来编辑/etc/php.d/xcache.ini,找到zend_extension开头的行,修改为如下行:
extension = /usr/local/php/lib/php/extensions/no-debug-zts-20121212/xcache.so

# chkconfig --list httpd

注意:如果php.ini文件中有多条zend_extension指令行,要确保此新增的行排在第一位。
访问测试页,即可看到已安装的xcache模块属性信息
现在即可使用ab命令进行压力测试,速度一般提升在3倍左右。

httpd          0:off  1:off  2:off  3:off  4:off  5:off  6:off

下面关于LAMP相关的内容你可能也喜欢

# chkconfig httpd on

LAMP平台安装Xcache和Memcached加速网站运行  http://www.linuxidc.com/Linux/2015-06/118835.htm

# chkconfig --list httpd

CentOS 7下搭建LAMP平台环境  http://www.linuxidc.com/Linux/2015-06/118818.htm

httpd          0:off  1:off  2:on    3:on    4:on    5:on    6:off

CentOS 6.5系统安装配置LAMP(Apache+PHP5+MySQL)服务器环境 http://www.linuxidc.com/Linux/2014-12/111030.htm

验证:

CentOS 7.2 yum安装LAMP环境  http://www.linuxidc.com/Linux/2016-11/136766.htm

# service httpd start

Ubuntu 14.04 配置 LAMP+phpMyAdmin PHP(5.5.9)开发环境  http://www.linuxidc.com/Linux/2014-10/107924.htm

# ps -elFH

Ubuntu 14.10 下安装 LAMP 服务图文详解  http://www.linuxidc.com/Linux/2014-12/110082.htm

三、MySQL

LAMP结合NFS构建小型博客站点  http://www.linuxidc.com/Linux/2015-08/121029.htm

1.安装

CentOS7下安装部署LAMP环境  http://www.linuxidc.com/Linux/2016-04/130653.htm

# tar xf mysql-5.5.33-linux2.6-x86_64.tar.gz -C /usr/local

Ubuntu Server 14.04 LTS下搭建LAMP环境图文详解  http://www.linuxidc.com/Linux/2016-12/138758.htm

# ln -sv /usr/local/mysql-5.5.33-linux2.6-x86_64 mysql 创建软连接,易于操作

Ubuntu Server 16.04下配置LAMP环境 http://www.linuxidc.com/Linux/2016-12/138757.htm

2.为数据库创建逻辑卷

CentOS 6.7编译安装LAMP 详解 http://www.linuxidc.com/Linux/2017-03/141244.htm

# fdisk /dev/sda                  //10G

Ubuntu 16.04搭建LAMP开发环境 http://www.linuxidc.com/Linux/2016-10/136327.htm

#pvcreate /dev/sda3              //创建物理卷

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-03/141752.htm

#vgcreate myvg /dev/sda8          //创建卷组

图片 1

#lvcreate -L 8G -n mydata myvg    //创建逻辑卷

#mke2fs -t ext4 /dev/myvg/mydata  //格式化逻辑卷

# mkdir  /mydata                  //创建逻辑卷挂载目录

#mkdri -pv /mydata/data          //创建mysql数据存放目录

# vim /etc/fstab                  //添加开机自动挂载

/dev/myvg/mydata      /mydata      ext4    defaults        0 0

# mount -a                        //挂载

3.新建用户以安全方式运行进程

#groupadd -r mysql      //创建系统组mysql

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

                        //创建系统用户mysql

#chown -R mysql:mysql /mydata/data

                        //设置目录属主属组

4.初始化mysql

# cd /usr/local/mysql

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

                            //初始化数据库

# chown -R root .

                            //设置当前目录所有文件属主为root

5.提供脚本

#cd /usr/local/mysql

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

                //设置脚本mysqld

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

                //给脚本执行权限

# chkconfig --add mysqld

                //添加开机启动

# chkconfig  mysqld on

6.提供配文件

#cd /usr/local/mysql

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

#vim /etc/my.cnf

    thread_concurrency = 2

        //修改,并发线程数,bithread_concurrency的值为CPU个数乘以2

    datadir = /mydata/data

        #添加,mysql数据文件的存放路径:

7.其他配置

# vim /etc/profile.d/mysqld.sh

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

# source /etc/profile.d/mysqld.sh

#vim /etc/man.config

MANPATH  /usr/local/mysql/man  //添加此行

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

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

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

            //输出mysql的库文件给系统库

#ldconfig  //重载系统库:

8.启动服务

# service mysqld start

# ss  -rnl | grep 3306

9.用户初始化

#mysql

mysql> use mysql

mysql> select host,user,password from user;

mysql> DELETE FROM user WHERE user = '';    //删除空用户

mysql> DELETE FROM user WHERE user = '::1'; //删除ipv6用户

mysql> UPDATE user SET password = PASSWORD('Hoolee') WHERE password = '';

                //为root用户设置密码

mysql> FLUSH PRIVILEGES;

 更多详情见请继续阅读下一页的精彩内容: http://www.linuxidc.com/Linux/2014-05/101087p2.htm

图片 2

本文由网络计算发布,转载请注明来源:编译安装LAMP情形,情况搭建