lamp环境搭建mysql5.5+httd2.4+php5.6

一.LAMP简介

LAMP 是Linux Apache MySQL PHP的简写,其实就是把Apache, MySQL以及PHP安装在Linux系统上,组成一个环境来运行php的脚本语言。LAMP是世界排名第一的Web服务器,非常流行。

二.系统环境和软件版本

1.系统:虚拟机下的 CentOS-6.5 32位 minimal

[root@localhost ~]# cat /etc/issue

CentOS release 6.5 (Final)

Kernel \r on an \m

[root@localhost ~]# uname -a

Linux localhost.localdomain 2.6.32-431.el6.i686 #1 SMP Fri Nov 22 00:26:36 UTC 2013 i686 i686 i386 GNU/Linux

2.iptables关闭、selinux关闭(下面为临时关闭,也可以永久关闭);

[root@localhost ~]# iptables -F

[root@localhost ~]# setenforce 0

三、安装过程

(一).安装mysql

1.准备数据存放的磁盘空间,如果要存放的数据很多的话,可以单独准备一个大的硬盘挂载到某个目录下面,这里我们添加一个5G的硬盘,挂载到根目录下的/mysqldata

[root@localhost /]# df

Filesystem     1K-blocks    Used Available Use% Mounted on

/dev/sda3       18423556 1016440  16471232   6% /

tmpfs             515264       0    515264   0% /dev/shm

/dev/sda1         198337   24976    163121  14% /boot

/dev/sdb1        5154852  141304   4751692   3% /mysqldata

2.创建mysql使用的系统用户mysql

[root@localhost /]# useradd -r -s /sbin/nologin -M -d /mysqldata/mydata/ mysql

[root@localhost /]# chown -R mysql:mysql /mysqldata

3.安装并初始化mysql

[root@localhost ~]# yum install -y wget   #安装wget

[root@localhost ~]# cd /usr/local/src/

[root@localhost ~]# yum install -y libaio libaio-devel

[root@localhost src]# wget http://mirrors.sohu.com/mysql/MySQL-5.5/mysql-5.5.42-linux2.6-i686.tar.gz

[root@localhost src]# tar -zxvf mysql-5.5.43-linux2.6-i686.tar.gz

[root@localhost src]# mv mysql-5.5.43-linux2.6-i686 ../mysql 

[root@localhost src]# cd ../mysql/

[root@localhost mysql]# chown -R mysql:mysql .

[root@localhost mysql]# ./scripts/mysql_install_db --user=mysql --datadir=/mysqldata/mydata/

Installing MySQL system tables...

OK

Filling help tables...

OK

......      #看到两个OK即成功初始化

[root@localhost mysql]# chown -R root .

4.拷贝配置文件

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

cp:是否覆盖"/etc/my.cnf"? y

[root@localhost mysql]# yum install -y vim-enhanced    #安装vim文本编辑器

vim /etc/my.cnf 并修改此文件中thread_concurrency的值为你的CPU个数乘以2,比如这里使用如下行:

thread_concurrency = 2

另外还需要添加如下行指定mysql数据文件的存放位置:

datadir = /mysqldata/mydata

5.为mysql提供sysv服务脚本

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

[root@localhost mysql]# chmod 755 /etc/init.d/mysqld

[root@localhost mysql]# vim /etc/init.d/mysqld

需要修改 “datadir=/mysqldata/mydata” 

[root@localhost mysql]# chkconfig --add mysqld

[root@localhost mysql]# chkconfig mysqld on

[root@localhost mysql]# service mysqld start

[root@localhost mysql]# ps aux |grep mysqld      #查看是否启动

root      1321  0.0  0.1   3044  1312 pts/0    S    22:02   0:00 /bin/sh ./bin/mysqld_safe --datadir=/mysqldata/mydata --pid-file=/mysqldata/mydata/localhost.localdomain.pid

mysql     1433  1.1  4.2 381608 43512 pts/0    Sl   22:02   0:00 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/mysqldata/mydata --user=mysql --log-error=/mysqldata/mydata/localhost.localdomain.err --pid-file=/mysqldata/mydata/localhost.localdomain.pid --socket=/tmp/mysql.sock --port=3306

root      1446  0.0  0.0   5980   748 pts/0    S+   22:02   0:00 grep mysqld

6.创建用户并授权

[root@localhost ~]# cd /etc/profile.d/

[root@localhost profile.d]# vim mysql.sh

export echo PATH=$PATH:/usr/local/mysql/bin    #增加一行并保存,然后推出终端重新登录即可使用mysql命令

[root@localhost ~]# mysql

mysql> set password for 'root'@'localhost' = password('123456');   #为root用户设置密码

mysql> use mysql

Database changed

mysql> delete from user where user='';    #删除匿名用户

mysql> select host,user from user;

+-----------------------+------+

| host                  | user |

+-----------------------+------+

| 127.0.0.1             | root |

| localhost             | root |

| localhost.localdomain | root |

+-----------------------+------+

3 rows in set (0.00 sec)

mysql> create database lamp;

mysql> grant all privileges on lamp.* to 'lamp'@'%' identified by '123456';    #创建lamp数据库并授权给用户lamp

mysql> flush privileges;

mysql> \q

[root@localhost ~]# mysql -ulamp -p123456   #测试刚刚创建的用户

mysql>

mysql安装完毕


(二).安装httpd

centos6 yum安装的apr版本已经不适用httpd-2.4版本了。所以,需要源码编译apr以及apr-util

[root@localhost ~]# yum install -y gcc   #安装编译器

[root@localhost src]# wget http://mirrors.cnnic.cn/apache/apr/apr-1.5.1.tar.bz2

[root@localhost src]# wget http://mirrors.cnnic.cn/apache/apr/apr-util-1.5.4.tar.gz

[root@localhost src]# tar jxvf apr-1.5.1.tar.bz2   #编译安装apr

[root@localhost src]# cd apr-1.5.1

[root@localhost apr-1.5.1]# ./configure --prefix=/usr/local/apr

[root@localhost apr-1.5.1]# make && make install

[root@localhost src]# tar zxvf apr-util-1.5.4.tar.gz     #编译安装apr-util

[root@localhost apr-util-1.5.4]# cd apr-util-1.5.4

[root@localhost apr-util-1.5.4]# ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr/

[root@localhost apr-util-1.5.4]# make && make install

下载安装httpd-2.4.12

[root@localhost ~]# yum install pcre-devel -y

[root@localhost ~]# yum install openssl-devel -y

[root@localhost src]# wget http://mirrors.cnnic.cn/apache//httpd/httpd-2.4.12.tar.bz2

[root@localhost src]# cd httpd-2.4.12

[root@localhost httpd-2.4.12]# ./configure --prefix=/usr/local/apache --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

[root@localhost httpd-2.4.12]#make && make install

启动httpd

[root@localhost httpd-2.4.12]# vim /usr/local/apache/conf/httpd.conf 

修改ServerName为:ServerName localhost:80

[root@localhost httpd-2.4.12]# /usr/local/apache/bin/apachectl start  #启动httpd

[root@localhost httpd-2.4.12]# curl localhost   #测试

<html><body><h1>It works!</h1></body></html> 

到局域网的其他电脑上,打开浏览器,输入主机的IP,显示It Works !即成功安装了httpd !

apache加入chkconfig

cp /usr/local/apache2/bin/apachectl /etc/init.d/httpd

vim /etc/init.d/httpd

在第一行#!/bin/sh下增加两行文字

# chkconfig: 35 70 30

# description: Apache

保存退出

chkconfig --level 35 httpd on


(三).安装PHP


[root@localhost src]# wget http://us1.php.net/distributions/php-5.6.7.tar.bz2

[root@localhost src]# tar -jxvf php-5.6.7.tar.bz2

[root@localhost src]# cd php-5.6.7

[root@localhost php-5.6.7]# yum install -y libxml2-devel

[root@localhost php-5.6.7]# yum install -y bzip2 bzip2-devel

[root@localhost php-5.6.7]# rpm -ivh 'http://download.Fedoraproject.org/pub/epel/6/i386/epel-release-6-8.noarch.rpm'           #这里需要安装第三方的yum源,默认的yum源里面没有libmcrypt-devel,下载安装

[root@localhost php-5.6.7]# yum install -y  libmcrypt-devel

[root@localhost php-5.6.7]# ./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

[root@localhost httpd-2.4.12]#make && make install

[root@localhost php-5.6.7]# cp php.ini-production /etc/php.ini

(四).apache结合PHP

[root@localhost php-5.6.7]# vim /usr/local/apache/conf/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是否已经可以正常使用。

[root@localhost php-5.6.7]# /usr/local/apache/bin/apachectl restart

[root@localhost php-5.6.7]# netstat -lnpt |grep httpd

tcp        0      0 :::80                       :::*                        LISTEN      18316/httpd 

[root@localhost ~]# vim /usr/local/apache/htdocs/1.php

#添加如下内容,保存

<?php

phpinfo();

?>

#到其他电脑上打开,输入IP/1.php,可以看到php的相关信息的页面。

[root@localhost htdocs]# vim 2.php   #自定义一个关于php连接mysql是否成功的测试页面;

        <?php

        $link = mysql_connect('127.0.0.1','lamp','password');

        if ($link)

                echo"Success!!!";

        else

                echo"Failure....";

        mysql_close();

        ?>

 #到其他电脑上打开,输入IP/2.php,注意先启用mysqld服务。

(五).安装phpMysqlAdmin

phpMysqlAdmin官网地址:http://www.phpmyadmin.net/home_page/downloads.php

[root@localhost src]# wget http://ncu.dl.sourceforge.net/project/phpmyadmin/phpMyAdmin/4.4.4/phpMyAdmin-4.4.4-all-languages.tar.gz 

 [root@localhost src]# unzip phpMyAdmin-4.4.1.1-all-languages.zip

 [root@localhost src]# mv phpMyAdmin-4.4.1.1-all-languages /usr/local/apache/htdocs/pma

 #浏览器输入IP/pma 即可进入管理页面

(六).安装xchche,为php加速

[root@localhost xcache-3.2.0]# yum -y install m4 autoconf  #安装编译环境

[root@localhost src]# wget http://xcache.lighttpd.net/pub/Releases/3.2.0/xcache-3.2.0.tar.gz

 [root@localhost src]# tar -zxvf xcache-3.2.0.tar.gz 

 [root@localhost src]# cd xcache-3.2.0

 [root@localhost xcache-3.2.0]# /usr/local/php/bin/phpize   #执行后会生成configure文件

 [root@localhost xcache-3.2.0]# ./configure --enable-xcache --with-php-config=/usr/local/php/bin/php-config

  [root@localhost xcache-3.2.0]# make && make install

#编辑php.ini,整合php和xcache:

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

[root@localhost xcache-3.2.0]# cd /etc/

[root@localhost etc]# mkdir php.d

[root@localhost etc]# cp /usr/local/src/xcache-3.2.0/xcache.ini /etc/php.d     #说明:xcache.ini文件在xcache的源码目录中。

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

extension = /usr/local/php/lib/php/extensions/no-debug-zts-20131226/xcache.so

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

#到其他电脑上打开,输入IP/1.php,可以看到php的相关信息的页面。页面中有xcache相关的信息即安装成功。

(七).启用服务器状态

mod_status模块可以让管理员查看服务器的执行状态,它通过一个HTML页面展示了当前服务器的统计数据。这些数据通常包括但不限于:

(1) 处于工作状态的worker进程数;

(2) 空闲状态的worker进程数;

(3) 每个worker的状态,包括此worker已经响应的请求数,及由此worker发送的内容的字节数;

(4) 当前服务器总共发送的字节数;

(5) 服务器自上次启动或重启以来至当前的时长;

(6) 平均每秒钟响应的请求数、平均每秒钟发送的字节数、平均每个请求所请求内容的字节数;

启用状态页面的方法很简单,只需要在主配置文件中添加如下内容即可:

<Location /server-status>

    SetHandler server-status

    Require all granted

</Location>

需要提醒的是,这里的状态信息不应该被所有人随意访问,因此,应该限制仅允许某些特定地址的客户端查看。比如使用Require ip 192.168.16.0/24来限制仅允许指定网段的主机查看此页面。

浏览器输入:IP/server-status 可以看到信息页面。


你可能感兴趣的:(mysql,PHP,lamp,httd)