实验前准备

   1service iptables stop   #关闭防火墙

      service iptables status   #查看防火墙是否已经关闭

      iptables: Firewall is not running. 这说明防火墙     已经关闭

   2 setenforce 0  关闭selinux

        通过sestatus查看selinux是否关闭

  

                     

   3)确认没有使用RPM方式源代码安装php及相关依赖包

[root@crushlinux ~]# rpm -e httpd httpd-manual webalizer subversion mod_python mod_ssl mod_perl system-config-httpd php php-cli php-ldap php-common php-mysql  mysql-server mysql dovecot –nodeps

 

实验部分

 

一、安装httpd

 

1、下载apache

wget http://archive.apache.org/dist/httpd/httpd-2.2.17.tar.gz

2、解压压缩包

tar xf httpd-2.2.17.tar.gz

3、编译源码包,并且安装

   (1)cd httpd-2.2.17

   (2)./configure --prefix=/usr/local/httpd --enable-so --enable-rewrite --enable-charset-lite --enable-cgi

1

编译完成后,如上图,说明已经编译成功

如果出现以下错误

则在编译时入加 --with-included-apr 即可解决。

 

4、安装

make && make install

2

编译完成后,如上图,说明已经编译成功

  (1)ln -s /usr/local/httpd/bin/* /usr/local/bin/

      

  (2)cp /usr/local/httpd/bin/apachectl /etc/init.d/httpd

      #复制启动脚本

3vi /etc/init.d/httpd  #编辑启动脚本,增加红色部分内容

   #!/bin/sh

   #chkconfig:345 66 88

   #description:http apache

解释:

   345 66 88表示345运行级别是开启的,66为服务启动顺序,88服务为停止顺序。

   4chmod +x /etc/init.d/httpd

        chkconfig --add httpd

        chkconfig --list httpd

5、启动服务

   service httpd start

   报错1httpd: Could not reliably determine the server's fully qualified domain name, using ::1 for ServerName

   解决:vim /usr/local/httpd/conf/httpd.conf

      97 #ServerName www.example.com:80

      98 ServerName localhost:80

   在配置文件中加入97行下加入98行显示内容

 

   报错2

/usr/local/apache/bin/httpd: error while loading shared libraries: libiconv.so.2: cannot open shared object file: No such file or directory

有很多so模块在/usr/local/lib目录下,所以在/etc/ld.so.conf中加入/usr/local/lib这一行

[root@crushlinux conf]# vi /etc/ld.so.conf

/usr/local/lib

[root@crushlinux conf]# /sbin/ldconfig -v

现在您已经将 Apach源代码安装在 /usr/local/apache。本源代码安装支持可装载模块

和标准的 MPM prefork。之后,可以使用如下命令启动 Apache 服务器:

/usr/local/httpd/bin/apachectl start

 

二、安装mysql

准备工作:

[root@Centos2 mysql]# rpm -q mysql-server mysql

package mysql-server is not installed

package mysql is not installed

如果已经安装,先卸载,以免发生端口或是程序冲突

mysql5.5以上的版本都需要cmake编译。而不是./configure

所以需要安装cmake

tar xf  cmake-2.8.6.tar.gz

cd cmake-2.8.6

./configure

gmake && gmake install

或这是

yum -y install cmake

 

 

   1、创建mysql用户

      groupadd mysql

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

   2、解压,编译、安装

      tar xf mysql-5.5.22.tar.gz

      cd mysql-5.5.22

 

   [root@Centos2 mysql-5.5.22]#

    cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DSYSCONFDIR=/etc -DDEFAULT_CHARSET=utf8  -DDEFAULT_COLLATION=utf8_general_ci -DEXTRA_CHARSETS=all

 

-DCMAKE_INSTALL_PREFIX: 指定数据库安装目录

-DSYSCONFDIR=/etc :指定配置文件目录

-DDEFAULT_CHARSET:指定默认使用的字符集编码。如utf8

-DDEFAULT_COLLATION=utf8_general_ci:设定默认排序规则(utf8_general_ci快速/utf8_unicode_ci准确)

-DEXTRA_CHARSETS=all:启用额外的字符集类型(默认为all)

如下图表示编译完成

                    1

配置

make && make install

3、权限调整

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

4、建立配置文件

rm -rf /etc/my.cnf

cd mysql-5.5.22

cp support-files/my-medium.cnf /etc/my.cnf

5、初始化数据库

cd /usr/local/mysql

scripts/mysql_install_db

--user=mysql

 --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data/

初始化数据库成功

6.设置软连接

为了在任何目录下都能使用mysql命令。可以创建软连接

ln -s /usr/local/mysql/bin/* /usr/local/bin/

7、将mysql添加为系统服务

cd mysql-5.5.22/support-files

cp mysql.server /etc/init.d/mysqld

chmod +x /etc/init.d/mysqld

chkconfig --add mysqld

8、启动mysql服务

service mysqld start

Starting  MySQL..          [  OK  ]

 

[root@Centos2 ~]# netstat -antp |grep mysqld

tcp 0   0 0.0.0.0:3306  . 0.0.0:*     LISTEN    13611/mysqld 

 

9、登陆验证

 

mysql搭建完成

三、安装php

1.源代码安装libmcrypt

[root@crushlinux ~]# tar zxf libmcrypt-2.5.8.tar.gz [root@crushlinux ~]# cd libmcrypt-2.5.8/

[root@crushlinux libmcrypt-2.5.8]# ./configure

[root@crushlinux libmcrypt-2.5.8]# make && make install

[root@crushlinux libmcrypt-2.5.8]# ln -s /usr/local/lib/libmcrypt.* /usr/lib/

2.源代码安装mhash

[root@crushlinux ~]# tar zxf mhash-0.9.9.9.tar.gz

[root@crushlinux ~]# cd mhash-0.9.9.9/

[root@crushlinux mhash-0.9.9.9]# ./configure

[root@crushlinux mhash-0.9.9.9]# make && make install

[root@crushlinux mhash-0.9.9.9]# ln -s /usr/local/lib/libmhash* /usr/lib/

3、源代码安装mcrypt

[root@crushlinux ~]# tar zxf mcrypt-2.6.8.tar.gz

[root@crushlinux ~]# cd mcrypt-2.6.8/

[root@crushlinux mcrypt-2.6.8]# ./configure

[root@crushlinux mcrypt-2.6.8]# make && make install

编译时候报错:

configure: error: *** libmcrypt was not found

解决办法:

第一步ln -s   

/usr/local/bin/libmcrypt_config   /usr/bin/libmcrypt_config

第二步:

export LD_LIBRARY_PATH=/usr/local/lib: LD_LIBRARY_PATH

 

4、编译php

root@crushlinux ~]# tar zxf php-5.3.6.tar.gz

[root@crushlinux ~]# cd /php-5.3.6

[root@crushlinux php-5.3.6]# ./configure --prefix=/usr/local/php5 --with-mcrypt --with-apxs2=/usr/local/httpd/bin/apxs --with-mysql=/usr/local/mysql --with-config-file-path=/usr/local/php5 --enable-mbstring

 

编译参数解释:

--prefix=/usr/local/php5                  //指定安装目录

--with-mcrypt                             //加载扩展工具支持

--with-apxs2=/usr/local/httpd/bin/apxs //设置Apache提供的apxs模块                                               程序文件位置

--with-mysql=/usr/local/mysql              //指定mysql服务的安装路径

--with-config-file-path=/usr/local/php5 //指定php配置文件“php.ini”                                              的存放路径

--enable-mbstring                      //启用多字节字符串功能

 

如下图表示编译成功

                      1

Make && make install

如下图表示安装成功:

 

   到此apachemysqlphp源码包安装完成。

 

四、整合LANMP环境

   [root@crushlinux php-5.3.6]# cd php-5.3.6

    [root@crushlinux php-5.3.6]# ls php.ini-*

/usr/src/php-5.3.6/php.ini-development //开发版样例文件,用户学习,测试

/usr/src/php-5.3.6/php.ini-production //生产版样例文件,用户实际运用

 

1复制样例文件

[root@crushlinux php-5.3.6]#

cp php.ini-development /usr/local/php5/php.ini

 

2)php.ini配置调整

 

[root@crushlinux php-5.3.6]# vi /usr/local/php5/php.ini

773 default_charset = "utf-8"       //设置默认字符集为utf-8

871 file_uploads = On              //允许通过PHP网页上传文件

880 upload_max_filesize = 2M       //允许上传的文件大小限制

883 max_file_uploads = 20          //每个HTTP请求最多允许上传的文件数

728 post_max_size = 8M             //每次通过表单POST提交的数据量限制

226 short_open_tag = On             //允许识别PHP短语法标记,即<? … ?>

 

3)调整Apache配置

[root@crushlinux ~]# vim /usr/local/httpd/conf/httpd.conf

53 LoadModule php5_module        modules/libphp5.so  

     配置加载PHP程序的模块文件

54 AddType application/x-httpd-php .php .phtml             

     添加对“.php”类型网页支持

169  DirectoryIndex index.php index.html       

     识别常见的php首页文件

[root@crushlinux ~]# /usr/local/httpd/bin/apachectl restart

 

 

五、测试

1)测试PHP能否正常提供服务

[root@crushlinux ~]# vim /usr/local/httpd/htdocs/test1.php

<?php

phpinfo();    内建函数用于显示PHP环境信息

?>

[root@crushlinux ~]# /usr/local/httpd/bin/apachectl restart

浏览器输入:http://10.3.0.209/test1.php

 

有如上信息为正确

 

2)测试PHP能否正常访问mysql数据库

[root@crushlinux ~]# vi /usr/local/httpd/htdocs/test2.php

 

<?php

$link=mysql_connect('localhost','root','');

if($link) echo "OK!!";

else echo "FAILD!!";

?>

   

centos6.5搭建LAMP的更多相关文章

  1. 基于centOS6.7搭建LAMP(httpd-2.4.18+mysql-5.5.47+php-5.6.16)环境

    首先确保系统可以联网.设置IP地址以及虚拟机安装linux在此略过.本文采用centos6.7 64位minimal版.php5.6.16.httpd-2.4.18.mysql-5.5.47版搭建la ...

  2. Centos6.5 搭建LAMP环境

    1.Centos6.5 处于对安全的考虑,严格控制网络的进去.所以安装  Apache 或 MySQL 的时候,需要开放 80 或 3306 端口 首先,执行如下命令查看当前防火墙开放了哪些端口: [ ...

  3. centos6.4yum搭建lamp环境

    1.配置防火墙,开启80端口.3306端口vi /etc/sysconfig/iptables-A INPUT -m state --state NEW -m tcp -p tcp --dport 8 ...

  4. 在centos6中编译安装httpd-2.4/搭建LAMP

    首先确保centos6安装平台安装一下环境: #yum groupinstall "Development  Tools" "Server Platform Develo ...

  5. Centos6.4版本下搭建LAMP环境

    Centos6.4版本下搭建LAMP环境 配置yum mkdir/mnt/cdrom mount/dev/cdrom  /mnt/cdrom 装载光盘 vi /etc/yum.repos.d/Cent ...

  6. CentOS6.5下搭建LAMP+FreeRadius+Daloradius Web管理和TP-LINK路由器、H3C交换机连接,实现,上网认证和记账功能

    什么是RADIUS服务: RADIUS:(Remote Authentication Dial In User Service)中文名为远程用户拨号认证服务,简称RADIUS,是目前应用最广泛的AAA ...

  7. CentOS6.5下搭建LAMP环境(源码编译方式)

    CentOS 6.5安装配置LAMP服务器(Apache+PHP5+MySQL) 学习PHP脚本编程语言之前,必须先搭建并熟悉开发环境,开发环境有很多种,例如LAMP ,WAMP,MAMP等.这里我介 ...

  8. linux搭建LAMP

    先简要概述下本文要点:(操作系统采用CentOS6.5 x64) 1.分别安装搭建lamp服务环境: 2.采用lamp一键安装包搭建环境: 3.在lamp环境中初步搭建起一个网站: 一. 分别安装搭建 ...

  9. 64位CentOS 6.0下搭建LAMP环境

    系统环境:Centos6.0 x64 1.确认搭建LAMP所需要的环境是否已经安装 [root@centos6 ~]# rpm -q make gcc gcc-c++ zlib-devel libai ...

随机推荐

  1. Linux基础命令---lftp登录ftp服务器

    lftp lftp指令可以用来登录远程ftp服务器,这是一个字符界面的文件传输工具. 此命令的适用范围:RedHat.RHEL.Ubuntu.CentOS.SUSE.openSUSE.Fedora. ...

  2. LR中的快捷建

    Ctrl+F  弹出搜索对话框 CTRL+F8  弹出view tree 界面 (寻找关联) 觉得不错的可关注微信公众号在手机上观看,让你用手机边玩边看

  3. 【编程思想】【设计模式】【行为模式Behavioral】观察者模式Observer

    Python转载版 https://github.com/faif/python-patterns/blob/master/behavioral/observer.py #!/usr/bin/env ...

  4. css clip样式 属性功能及作用

    clip clip 在学前端的小伙伴前,估计是很少用到的,代码中也是很少看见的,但是,样式中有这样的代码,下面让我们来讲讲他吧! 这个我也做了很久的开发没碰到过这个属性,知道我在一个项目中,有一个功能 ...

  5. Hibernate的基本功能:对数据库的增删改查(创建对象实例)

    一.通过实例化的对象向数据库添加新记录 package com.yh.test; import org.hibernate.Session; import org.hibernate.SessionF ...

  6. 热部署详细步骤---·> 小热身!

    IDEA 2018.1.5 4版本 热部署 网址:https://www.jb51.net/softjc/629271.html

  7. MySQL数据库字段加密

    一.导入表结构 USE `qskj_03`; /*Table structure for table `test` */ DROP TABLE IF EXISTS `test`; CREATE TAB ...

  8. heap exploit about ptmalloc in glibc version 2.31

    学习的一下高版本的libc的利用方式. 项目地址:https://github.com/StarCross-Tech/heap_exploit_2.31 tcache_dup 源代码: 1 #incl ...

  9. Oracle 函数高级查询

    目录 oracle高级查询 Oracle SQL获取每个分组中日期最新的一条数据 求平均值(为0的参数不均摊) 字符串清除前面的0 判断字符串串是否包含某个字符串 switch 判断 oracle不足 ...

  10. 突出显示(Project)

    <Project2016 企业项目管理实践>张会斌 董方好 编著 当一个大的项目文件做好以后,查看全部内容,肉眼多少会有点吃不消,这时就需要"划重点".在Porect里 ...