2024年5月12日发(作者:)
CentOS 6.4安装配置LAMP服务器(Apache+PHP5+MySQL)
学习PHP脚本编程语言之前,必须先搭建并熟悉开发环境,开发环境有很多种,例如
LAMP ,WAMP,MAMP等。这里我介绍一下LAMP环境的搭建,即Linux、 Apache、 MySQL 、PHP
环境。
一、首先安装操作系统
操作系统:centos6.5
操作系统安装步骤,此处不再详述。
备注:服务器系统采用最小化安装,安装一下GCC编译工具和一个桌面即可。如下图所示:
由于安装系统的时候我是最小化安装,只安装了一个桌面,GCC编译工具也是系统装完之后安装
的,所以没有默认的LAMP环境,如下图示:
如果安装的时候有选择默认全部安装,就已经安装了LAMP环境,但是相对版本较低,而且安装
的路径等可能不是我们想要的结果。所以这里顺便介绍一下,如果存在默认的LAMP环境,进行卸载
的方法,以apache为例:
#rpm -qa | grep -i httd // 查询系统中已安装的Apache相关软件包
#service httpd stop //如果 apache已开启,停止运行apache服务器
#rpm -e httpd-xxx --nodeps //卸载 apache服务器
php、 mysql卸载方法同上。
【搭建LAMP环境须知】
搭建LAMP环境时,需要安装的所有软件都要按照一定的顺序安装,我们按照
Apache->MySQL->PHP的顺序安装。但是在安装PHP之前,应先安装PHP5需要的最新版本库文
件,例如libxml2、libmcrypt,以及GD2库等文件。安装GD2库是为了让PHP5支持 GIF、PNG
和JPEG图片格式,所以在安装GD2库之前还要先安装最新的zlib、libpng、freetype和jpegsrc等
库文件。而且中间还会穿插安装一些软件。
二、LAMP安装前的准备
1、获取软件包
/
/downloads/
/
/home_page/
ftp:///libxml2/
ftp:///pub/crypto/mcrypt/libmcrypt/
/libgd/gd-libgd/downloads
/gnu/autoconf/
/releases/freetype/
ftp:///pub/libpng/png/src/
/files/
ZendGuard-5_5_
/en/products/guard/thank-you-zend-guard?package=415
/
/
/projects/pcre
把上面下载的16个源代码包放到linux系统下的/usr/local/src/LAMP目录中
2、编译工具安装
如果安装系统的时候已经安装了GCC编译工具,则显示上图中的信息,如果没有安装,可以使用
下面的方法进行安装:
检查是否安装:
[root@centos6 ~]# rpm -q make gcc gcc-c++ zlib-devel libaio
备注:安装libpng时候需要zlib-devel 安装mysql时候需要libaio
如果没安装则yum安装:
[root@centos6 ~]# yum -y install make gcc gcc-c++ zlib-devel libaio
3、配置防火墙,开启80端口、3306端口
编辑/etc/sysconfig/iptables文件,配置防火墙
[root@centos6 ~]# vi /etc/sysconfig/iptables
添加下面两句,开启相应端口:
-A INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT #允许80端口通过防火
墙
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT #允许3306端口通过
防火墙
备注:很多网友把这两条规则添加到防火墙配置的最后一行,导致防火墙启动失败,正确的应该是
添加到默认的22端口这条规则的下面如下所示:
########################
########################
添加好之后防火墙规则如下所示
# Firewall configuration written by system-config-firewall
# Manual customization of this file is not recommended.
*filter
:INPUT ACCEPT [0:0]
:FORWARD ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]
-A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
-A INPUT -p icmp -j ACCEPT
-A INPUT -i lo -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT
-A INPUT -j REJECT --reject-with icmp-host-prohibited
-A FORWARD -j REJECT --reject-with icmp-host-prohibited
COMMIT
########################
########################
添加好之后防火墙规则如上所示
最后重启防火墙使配置生效
[root@centos6 ~]# /etc/init.d/iptables restart
4、关闭SELINUX
编辑/etc/selinux/config文件
[root@centos6 ~]# vi /etc/selinux/config
详细修改如下所示:
#SELINUX=enforcing #注释掉
#SELINUXTYPE=targeted #注释掉
SELINUX=disabled #增加
:wq #保存,关闭
[root@centos6 ~]#shutdown -r now #重启系统
三、开始搭建LAMP环境
安装时的主要步骤:
(1)解压为后缀的压缩包软件
LAMP环境搭建所需要的每个软件的源代码文件,都是以.提供给我们的打包压缩文件,所
以我们必须将其解压再解包。可通过命令#tar zxvf 达到目的。
(2)在linux系统中源代码包安装过程
进行解压后的目录,LAMP环境搭建所需要的软件都使用C语言开发的,所以安装源代码文件最
少需要配置(configure)、编译(make)、安装(make install)三个步骤。
1、确认搭建LAMP所需要的环境是否已经安装
此步骤前面已经完成。
2、编译安装libxml2
注:libxml2是一个xml的c语言版的解析器,不仅支持c语言,还支持c++、php、Pascal、
Ruby、Tcl等语言的绑定
[root@centos6 LAMP]# pwd
/usr/local/src/LAMP
[root@centos6 LAMP]# tar -zxvf
[root@centos6 LAMP]# cd ./libxml2-2.7.8
[***********************.8]#./configure --prefix=/usr/local/libxml2/
[***********************.8]#make
[***********************.8]#makeinstall
注:选项--prefix=/usr/local/libxml2作用是将软件安装到/usr/local/libxml2 目录下。
如果安装成功以后,在/usr/local/libxml2/目录下将生成bin,include,lib,share四个目录。在后面
安装 PHP5源代码的配置时,会通过在configure命令的选项中加上
"--with-libxml-dir=/usr/local/libxml2"选项,用于指定安装libxml2库文件的位置。
3、编译安装libmcrypt
注:libmcrypt是加密算法扩展库。支持DES, 3DES, RIJNDAEL, Twofish, IDEA, GOST, CAST-256,
ARCFOUR, SERPENT, SAFER+等算法。
[root@centos6 LAMP]# pwd
/usr/local/src/LAMP
[root@centos6 LAMP]# tar -zxvf
[root@centos6 LAMP]# cd ./libmcrypt-2.5.8
[*************************.8]#./configure --prefix=/usr/local/libmcrypt/
[*************************.8]#make;makeinstall
如果安装成功就会在/usr/local/libmcrypt/目录下生成bin,include,lib,man,share五个目录。然
后在安 装PHP5源代码包的配置时,就可以通过configure命令加上
“--with-mcrypt-dir=/usr/local/libmcrypt” 选项,指定这个libmcrypt库文件的位置。
如./configure时报错:configure: error: C++ compiler cannot create executables 。
解决方案:
运行下面命令,然后重新configure(配置)
yum install gcc gcc-c++ gcc-g77
安装完成libmcrypt库以后,不同的linux系统版本有可能还要安装一下libltdl库。安装方法和
前面的步骤相同,可以进入到解压缩的 目录/usr/local/src/libmcrypt-2.5.8下,找到libltdl库源代码
所在的目录libltdl,进入这个目录按照下面几个 命令配置、编译、安装就可以了。
[root@localhost libltdl]# pwd
/usr/local/src/libmcrypt-2.5.8/libltdl //进入软件源代码目录
[root@localhost libltdl]# ./configure –enable-ltdl-install //配置ltdl库的安装
[root@localhost libltdl]# make //编译
[root@localhost libltdl]# make install //安装
4、编译安装zlib
注:zlib是提供数据压缩用的函式库
[root@centos6 LAMP]# pwd
/usr/local/src/LAMP
[root@centos6 LAMP]# tar -zxvf
[root@centos6 LAMP]# cd ./zlib-1.2.5
[********************.5]#./configure --prefix=/usr/local/zlib/
[********************.5]#make;makeinstall
如果安装成功将会在/usr/local /zlib目录下生成include,lib,share三个目录。在安装PHP5配置
时,在configure命令的选项中加上“--with- zlib-dir=/usr/local/libmcrypt”选项,用于指定zlib
库文件位置。
5、编译安装libpng
[root@centos6 LAMP]# pwd
/usr/local/src/LAMP
[root@centos6 LAMP]# tar -zxvf
[root@centos6 LAMP]# cd ./libpng-1.5.4
[**********************.4]#
./configure --prefix=/usr/local/libpng/ --enable-shared
[**********************.4]#make;makeinstall
在./configure --prefix=/usr/local/libpng这步最后会提示:configure: error: ZLib not
installed
解决方法如下:
1)进入zlib的源文件目录,执行命令 make clean,清除zlib;
2)重新配置 ./configure,后面不要接--prefix参数;
3)make && make install;
4)进入libpng目录,执行命令 ./configure --prefix=/usr/local/libpng;
5)make && make install;
6)安装成功.
如果安装成功将会在/usr/local/libpng目录下生成bin,include,lib和share四个目录。在安装
GD2库配置时,通 过在configure命令选项中加上“--with-png=/usr/local/libpng”选项,指定
libpng库文件的位置。
6、编译安装jpeg
注:安装GD2库前所需的jpeg8库文件,需要自己手动创建安装需要的目录,它们在安装时不能
自动创建。
[root@centos6 LAMP]# pwd
/usr/local/src/LAMP
[root@centos6 LAMP]# tar -zxvf
[root@centos6 LAMP]# cd ./jpeg-8c/
[root@centos6 jpeg-8c]# mkdir /usr/local/jpeg/ (创建jpeg软件的安装目录)
[root@centos6 jpeg-8c]# mkdir /usr/local/jpeg/bin/ (创建存放命令的目录)
[root@centos6 jpeg-8c]# mkdir /usr/local/jpeg/lib/ (创建jpeg库文件所在目录)
[root@centos6 jpeg-8c]# mkdir /usr/local/jpeg/include/ (创建存放头文件目录)
[root@centos6 jpeg-8c]# mkdir -p /usr/local/jpeg/man/man1 (建立存放手册的目录)
[root@centos6 jpeg-8c]# ./configure --prefix=/usr/local/jpeg/
> --enable-shared
> --enable-static(建立共享库使用的GNU的libtool和静态库使用的GNU的libtool)
[root@centos6 jpeg-8c]# make ; make install
在安装GD2库配置时,可以在configure命令的选项中加上“--with-jpeg=/usr/local/jpeg8”
选项,指定jpeg8库文件的位置。安装PHP时也要指定该库文件的位置。
7、编译安装freetype
[root@centos6 LAMP]# pwd
/usr/local/src/LAMP
[root@centos6 LAMP]# tar -zxvf
[root@centos6 LAMP]# cd ./freetype-2.4.6
[************************.6]#
./configure --prefix=/usr/local/freetype/ --enable-shared
[************************.6]#make;makeinstall
如果安装成功将会在/usr/local/freetype目录下存在bin,include,lib和share四个目录。并在安
装GD2库时,通过configure命令选项中加上“--with-freetype=/usr/local/freetype/”选项,指
定freetype库文件位置。
8、编译安装autoconf
唯一注意的地方是configure时,不用指定路径。
[root@centos6 LAMP]# pwd
/usr/local/src/LAMP
[root@centos6 LAMP]# tar -zxvf
[root@centos6 LAMP]# cd ./autoconf-2.68
[*************************]#./configure
[*************************]#make;makeinstall
9、 编译安装GD
[root@centos6 LAMP]# pwd
/usr/local/src/LAMP
[root@centos6 LAMP]# tar -zxvf
[root@centos6 LAMP]# cd ./gd-2.0.35
[******************.35]#./configure/配置命令
> --prefix=/usr/local/gd //指定安装软件的位置
> --with-jpeg=/usr/local/jpeg/ //指定去哪找jpeg库文件
> --with-png=/usr/local/libpng/ //指定去哪找png库文件
> --with-zlib=/usr/local/zlib/ //指定去哪找zlib库文件
> --with-freetype=/usr/local/freetype/ //指定去哪找freetype 2.x字体库的位置
[******************.35]#make;makeinstall
如果安装成功会在/usr/local/gd/目录下存在bin、include和lib这三个目录。在安装PHP5时,
通过在configure命令选项中加上“--with-gd=/usr/local/gd”选项,指定GD库文件的位置。
如果报错:
gd_png.c 中 gdMalloc函数的问题
make[2]: *** [gd_] Error 1
make[2]: Leaving directory `/tmp/gd-2.0.35'
make[1]: *** [all-recursive] Error 1
make[1]: Leaving directory `/tmp/gd-2.0.35'
make: *** [all] Error 2
解决方案:
vi gd_png.c
找到#include "png.h"改成#include "/usr/local/libpng/include/png.h"
如果报错:unrecognized option –with-zlib
那就重新安装一次zlib,注意,需要把原先解压出来的源码删掉,重新解压进行安装。
10、 安装apache
卸载apr、apr-util
[root@centos6 LAMP]# yum remove apr apr-util
编译安装
[root@centos6 LAMP]# tar zxvf
[root@centos6 LAMP]# cd apr-1.5.1
[*******************.1]#./configure--prefix=/usr/local/apr-httpd/&&make&&make
install
编译安装
[root@centos6 LAMP]# tar zxvf
[root@centos6 LAMP]# cd apr-util-1.5.1
[root@centos6 apr-util-1.5.3]# ./configure --prefix=/usr/local/apr-util-httpd/
--with-apr=/usr/local/apr-httpd/ && make && make install
编译安装
[root@centos6 LAMP]# unzip -o
[root@centos6 LAMP]# cd pcre-8.35
[*********************]#./configure--prefix=/usr/local/pcre
[*********************]#make
[*********************]#makeinstall
编译安装apache
[root@centos6 LAMP]# tar zxvf
[root@centos6 LAMP]# cd httpd-2.4.9
[*********************.9]#./configure
> --prefix=/usr/local/apache249
> --enable-mods-shared=all
> --enable-deflate
> --enable-speling
> --enable-cache
> --enable-file-cache
> --enable-disk-cache
> --enable-mem-cache
> --enable-so
> --enable-expires=shared
> --enable-rewrite=shared
> --enable-static-support
> --sysconfdir=/etc/httpd
> --with-z=/usr/local/zlib/
> --with-apr=/usr/local/apr-httpd/
> --with-apr-util=/usr/local/apr-util-httpd/
> --with-pcre=/usr/local/pcre/
> --disable-userdir
[*********************.9]#make&&makeinstall
安装完成后,进入/usr/local/apache243/目录下,检查是否有以下文件:
bin build cgi-bin error htdocs icons include logs man manual modules
启动Apache服务器,并查端口是否开启,启动Apache服务器的命令行如下:
[*********************.9]#/usr/local/apache249/bin/apachectlstart
提示信息:
AH00558: httpd: Could not reliably determine the server's fully qualified domain name,
using ::1. Set the 'ServerName' directive globally to suppress this message
解决方案:
[*********************.9]#vi/etc/httpd/
加上下面一行,重启apache
ServerName localhost:80
查看端口命令行如下:
#netstat -tnl|grep 80
tcp 0 0 0.0.0.0:80 0.0.0.0:* LIST
测试安装结果,打开浏览器,在地址栏中输入URL为:192.168.146.129/
如果浏览器中出现It works!则表明Apache服务器可以使用。
每种服务器软件都有必要制成开机时自动启动,Apache服务器开机自动启动,只要在
“/etc/rc.d/”文件,加上 Apache服务器的启动命令即可。可以直接打开
“/etc/rc.d/”文件,在最后一行写入Apache启动命令,也可以用echo 命令追加进去,如下
命令行示:
[root@localhost apache243]# echo "/usr/local/apache243/bin/apachectl start" >>
/etc/rc.d/
[root@centos6 LAMP]# /usr/local/apache/bin/apachectl start
[root@centos6 LAMP]# cp /usr/local/apache/bin/apachectl /etc/init.d/httpd
[root@centos6 LAMP]# chmod +x /etc/init.d/httpd
[root@centos6 ~]# chkconfig --add httpd
注意:如果提示service httpd does not support chkconfig错误
解决办法:编辑/etc/rc.d/init.d/httpd在文件第二行加入
#chkconfig:2345 10 90
#description:Activates/Deactivates Apache Web Server
[root@centos6 ~]# chkconfig --level 2345 httpd on
[root@centos6 LAMP]# service httpd restart
开机自动启动apache的另一种方法:
修改/etc/文件
# vim /etc/
在文件中添加/usr/local/apache/bin/apachectl start
11、编译安装mysql(新版本的mysql编译)
mysql版本5.5以上编译安装时需要用到软件cmake,cmake特性是独立于源码编译,编译工作
可以在另外一个目录中而非源码目录中进行,好处是可以保证源码目录不受任何一次编译的影响。估计
以后的版本也会采用这种方式,所以特地记录一下安装步骤及过程,以供参考。
注意:此安装是默认centos下已经安装了最新工具包,比如
GNU make, GCC, Perl, libncurses5-dev,如果在编译安装过程中发现有缺失的工具包,先
yum install 单独下载安装再继续即可。
以下安装中涉及的几点需要提前说明的问题:
所有下载的文件将保存在 /usr/local/src/ 目录下
mysql将以mysql用户运行,而且将加入 service 开机自动运行
mysql将被安装在 /usr/local/mysql/ 目录下
mysql默认安装使用 utf8 字符集
mysql的数据和日志文件保存在 /usr/local/mysql/data/ 对应目录下
mysql的配置文件保存于/etc/
1.下载安装cmake
下载软件 /
[root@centos6 ~]# tar zxvf
[root@centos6 ~]# cd cmake-3.0.0
[root@centos6 ~]# ./bootstrap
[root@centos6 ~]# gmake
[root@centos6 ~]# make && make install
在使用时可能会出现error,若提示是/usr/bin/cmake文件不存在。
解决办法:
[root@centos6 ~]#whereis cmake
得到cmke的可执行文件的路径,如在:/usr/local/bin/cmake
[root@centos6 ~]# ln -s /usr/local/bin/cmake /usr/bin/cmake
创建一个链接文件即可解决。
2.安装ncurses-devel
首先需要使用yum安装了下ncurses-devel
[root@centos6 ~]# yum –y install ncurses-devel
否则在下面安装过程中会出现缺少如下的ERROR:
Could NOT find Curses (missing: CURSES_LIBRARY CURSES_INCLUDE_PATH)
CMake Error at cmake/:83 (MESSAGE):
Curses library not found. Please install appropriate package,
3.安装mysql
(1)创建用户、组和目录
[root@centos6 ~]# groupadd mysql
[root@centos6 ~]# useradd mysql -g mysql
[root@centos6 ~]# passwd mysql //设置密码为:123
[root@centos6 ~]# mkdir /usr/local/mysql //创建安装目录
[root@centos6 ~]# mkdir /usr/local/mysql/data //创建数据仓库目录(不创建的话默认就
//是这个目录即$PREFIX_DIR/data)
[root@centos6 ~]# chown -R /usr/local/mysql/
(2)编译安装mysql-5.7.4
[root@centos6 ~]# tar zxvf
[root@centos6 ~]# cd mysql-5.7.4
[root@centos6 ~]# cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql
> -DMYSQL_UNIX_ADDR=/usr/local/ //最好不要指定
> -DMYSQL_DATADIR=/usr/local/mysql/data
> -DDEFAULT_CHARSET=utf8
> -DDEFAULT_COLLATION=utf8_general_ci
> -DWITH_EXTRA_CHARSETS:STRING=utf8,gbk
> -DWITH_MYISAM_STORAGE_ENGINE=1
> -DWITH_INNOBASE_STORAGE_ENGINE=1
> -DWITH_MEMORY_STORAGE_ENGINE=1
> -DWITH_READLINE=1
> -DENABLED_LOCAL_INFILE=1
> -DMYSQL_USER=mysql
> -DMYSQL_TCP_PORT=3306
[root@centos6 ~]# make && make install
注意:若第一次的配置错误,需要先删除当前mysql源码目录中的 (不是cmake
源码目录中的),然后再重新进行cmake配置。
cmake参数说明:
-DCMAKE_INSTALL_PREFIX= 数据库程序安装路径;
-DMYSQL_DATADIR= 数据库文件存放路径(不配置的话会默认创建$PREFIX_DIR/data)
-DMYSQL_UNIX_ADDR= 默认位置是/var/lib/mysql/,如果指定其他路径,需要做
一个软链接,或者在配置文件中进行设置。
-DDEFAULT_CHARSET= 默认数据库编码
-DDEFAULT_COLLATION= 默认数据库整理编码
-DWITH_EXTRA_CHARSETS= 扩展支持编码(all | utf8,gbk,gb2312 | none)
-DWITH_MYISAM_STORAGE_ENGINE= MYISAM引擎支持(1|0)
-DWITH_INNOBASE_STORAGE_ENGINE= innoDB引擎支持(1|0)
-DWITH_MEMORY_STORAGE_ENGINE= MEMORY引擎支持(1|0)
(3)配置mysql
权限设置:
[root@resource mysql]# pwd
/usr/local/mysql //mysql安装目录
[root@localhost mysql]# chown -R . //设置安装目录下所有文件的权限
[root@resource mysql]# chown -R ./data //data的权限
[root@resource mysql]# chown -R /var/lib/mysql //的权限
修改配置文件
首先查看是否存在/etc/文件,有则直接打开编辑,否则请复制配置文件,目标路径自己设
定:
[root@centos6 ~]# cp support-files/ /usr/local/mysql/
修改参数,没有则加入如下:
basedir = /usr/local/mysql(不配置的话默认为$PREFIX_DIR)
datadir = /usr/local/mysql/data(不配置的话默认为$PREFIX_DIR/data)
log-error = /usr/local/mysql/mysql_(不配置的话默认为
$PREFIX_DIR/data/$)
pid-file = /usr/local/mysql/(不配置的话默认为
$PREFIX_DIR/data/$)
user = mysql
tmpdir = /tmp(不配置的话默认为/tmp)
/etc/的配置请参考下面的例子进行配置:
**********************************
****************************************
/etc/配置示例
[mysqld]
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
socket=/var/lib/mysql/ //要正确配置
user=mysql
port=3306
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
[mysqld_safe]
log-error=/var/log/
pid-file=/usr/local/mysql/data/ //这个要配置正确
**********************************
****************************************
/etc/配置示例
注意:在/etc/文件中的pid-file一定要设定正确,否则后面会出现无法登录的情况,我在
这里被耽误来好久好久。该pid-file的路径名在哪里,可使用下面的命令:
[root@centos6 ~]# ps aux | grep mysql
会出现类似下面的情况,如果没有则重新启动mysql就有了,在下面的输出信息中找到pid-file
的路径名。
root 3534 0.0 0.0 106232 1408 pts/0 S 23:40 0:00 /bin/sh
/usr/local/mysql/bin/mysqld_safe
--pid-file=/usr/local/mysql/data/
--datadir=/usr/local/mysql/data
mysql 3741 2.0 26.8 1248408 550728 pts/0 Sl 23:40 0:00
/usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
--plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --log-error=/var/log/
--pid-file=/usr/local/mysql/data/
--port=3306
--socket=/var/lib/mysql/
root 3952 0.0 0.0 103252 824 pts/3 S+ 23:41 0:00 grep mysql
初始化数据库
执行前需赋给scripts/mysql_install_db文件执行权限:
[root@centos6 ~]# pwd
/usr/local/mysql //mysql安装目录
[root@centos6 ~]# chmod 755 scripts/mysql_install_db
[root@centos6 ~]# scripts/mysql_install_db --user=mysql
> --basedir=/usr/local/mysql
> --datadir=/usr/local/mysql/data
注:basedir:mysql安装路径 datadir:数据库文件储存路径,(--user一定要加,其他可不加,
默认会是$PREFIX_DIR和$PREFIX_DIR/data,因为--help看到说不加--user会以当前系统登录用户
启动mysql)
在数据库成功初始化之后,可以根据现在屏幕上的提示信息来做,先启动mysql:
/usr/local/mysql574/bin/mysqld_safe --user=mysql & //启动mysql
/usr/local/mysql574/bin/mysqladmin --version //测试下
再修改root密码:
/usr/local/mysql574/bin/mysqladmin -u root password '123456'
设置mysqld的开机启动
[root@centos6 ~]# cp support-files/ /etc/init.d/mysql
[root@centos6 ~]# chmod 755 /etc/init.d/mysql
[root@centos6 ~]# chkconfig mysql on
可使用chkconfig –list | grep mysql 命令查询刚才的设置情况。
为MySQL配置环境变量
将mysql的bin目录加到PATH中,有利于以后管理和维护,在/etc/profile中加入myslq/bin,
同时增加两个别名方便操作。
注:后面两个别名不加也可以,加上以后的操作更方便。
[root@centos6 ~]# export PATH=/usr/local/mysql/bin:$PATH
[root@centos6 ~]# alias mysql_start="mysqld_safe &"
[root@centos6 ~]# alias mysql_stop="mysqladmin -u root -p shutdown"
启动mysql服务:
[root@centos6 ~]# /etc/init.d/mysql start
启动完成之后用ps -ef |grep mysql 命令查看是否启动
登陆mysql:
[root@centos6 ~]# mysql -u root -p
[问题] 如果出现错误:MYSQL:The server quit without updating PID file。
一种可能是selinux惹的祸,如果是centos系统,默认会开启selinux。解决方法就是关闭它。
[root@centos6 ~]# vi /etc/selinux/config
详细修改如下所示:
#SELINUX=enforcing #注释掉
#SELINUXTYPE=targeted #注释掉
SELINUX=disabled #增加
:wq #保存,关闭
[root@centos6 ~]#shutdown -r now #重启系统
另外一种可能就是pid文件的路径设置不正确,可参考上文中对pid文件的设置方法。
[问题] Can’t connect to local Mysql server through socket ‘/tmp/’ (2)
问题分析:mysql安装之后,需要使用的socket文件链接mysql数据库,默认的引
用位置为/tmp/,而文件一般在/var/lib/mysql/路径下,因此需要做一个软链
接。另外注意的权限属性。
解决方法:
[root@centos6 ~]# ln -s /var/lib/mysql/ /tmp/
[root@CentOS6 hcyj]# ll /tmp/
lrwxrwxrwx 1 mysql mysql 25 Jul 17 23:21 /tmp/ -> /var/lib/mysql/
[root@CentOS6 hcyj]# ll /var/lib/mysql/
srwxrwxrwx 1 mysql mysql 0 Jul 18 10:05 /var/lib/mysql/
再次连接:
[root@centos6 ~]# /usr/local/mysql/bin/mysql -u root -p
连接上了,问题解决。
[问题] 若出现ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using
password: YES(NO)) 这种情况。
解决方法,如下:
[root@centos6 ~]# /etc/init.d/mysql stop
[root@centos6 ~]# /usr/local/mysql/bin/mysqld_safe --user=mysql --skip-grant-tables
--skip-networking &
[root@centos6 ~]# /usr/local/mysql/bin/mysql -u root mysql
mysql> UPDATE user SET Password=PASSWORD('newpassword') where USER='root';
//请将newpassword更换为自己设定的密码即可,其他不变
mysql> FLUSH PRIVILEGES;
mysql> quit
重启mysql并使用密码登录:
[root@centos6 ~]# /etc/init.d/mysql restart
[root@centos6 ~]# /usr/local/mysql/bin/mysql -uroot -p
Enter password: <输入新设的密码newpassword>
至此,就可以成功登录MySQL。
MySQL标准设置(仅供参考,本人未使用)
1) 为root帐户设置初始密码
[root@centos6 ~]# /usr/local/mysql/bin/mysqladmin -u root password 'new-password'
或者限制只能通过本机登陆
[root@centos6 ~]# /usr/local/mysql/bin/mysqladmin -u root -h ‘hostname’ password
'new-password'
2) 删除本机匿名连接的空密码帐号
本机登录mysql
mysql>use mysql; //选择默认数据库mysql
mysql>update user set password=’root123’ where user = '127.0.0.1';
mysql>delete from user where password="";//不允许root密码为空
mysql>flush privileges;
mysql>quit
容许root用户是远程登录
对于root账号,如果考虑安全应该新建其他账号用于远程登录,root账号可以不必开启远程登录。
不过对于一般使用,没有太多安全需求,允许root用户远程登录可以方便管理,毕竟使用专用管理软
件的图形界面在操作方面要方便的多。
3) 设置MySQL远程连接
mysql 数据库端设置
# /mysql -u root -p //进入数据库
mysql>use mysql
mysql>select user,password,host from user;
mysql>update user set host = '192.168.%' where user = '127.0.0.1';
mysql>grant all privileges on *.* to root@'%' identified by "root123";//给以root@ip登录
的远程连接赋予权限,能够连接数据库。远程无法连接的常见问题原因。并把远程登录用户的密码设置
为root
mysql> flush privileges;
mysql>quit
12、编译安装php
安装PHP之前,需要先安装libXpm-devel,否则在安装php的时候会出现下面的错误:
/usr/local/src/LAMP/php-5.5.14/ext/gd/gd.c:57:22: error: X11/xpm.h: No such file or
directory
make: *** [ext/gd/] Error 1
编译安装libXpm-devel:
[*******************.14]#yum-yinstalllibXpm-devel
[*******************.14]#rpm-qllibXpm-devel
/usr/bin/cxpm
/usr/bin/sxpm
/usr/include/X11/xpm.h
/usr/lib64/
/usr/lib64/pkgconfig/
/usr/share/man/man1/
/usr/share/man/man1/
查找到libXpm-devel的安装位置为/usr/lib64/,将选项--with-xpm-dir=/usr/lib64
添加到php的配置选项中。
编译安装php
[root@centos6 LAMP]# pwd
/usr/local/src/LAMP
[root@centos6 LAMP]# tar -zxvf
[root@centos6 LAMP]# cd ./php-5.4.11
[*********************.11]#./configure
> --prefix=/usr/local/php
> --with-config-file-path=/usr/local/php/etc //配置文件路径,指定位置
> --with-apxs2=/usr/local/apache249/bin/apxs // apxs功能是使用mod_so中的
// LoadModule指令,加载指定模块到 apache,要求 apache 要打开SO模块
> --with-mysql=/usr/local/mysql //mysql安装目录,对mysql的支持
> --with-mysqli=/usr/local/mysql/bin/mysql_config //mysqli文件目录,优化支持
> --with-libxml-dir=/usr/local/libxml2 //打开libxml2库的支持
> --with-png-dir=/usr/local/libpng //打开对png图片的支持
> --with-jpeg-dir=/usr/local/jpeg //打开对jpeg图片的支持
> --with-freetype-dir=/usr/local/freetype //打开对freetype字体库的支持
> --with-gd=/usr/local/gd //打开gd库的支持
> --with-zlib-dir=/usr/local/zlib //打开zlib库的支持
> --with-mcrypt=/usr/local/libmcrypt //打开libmcrypt库的支持
> --with-xpm-dir=/usr/lib64 //打开libXpm库的支持
> --enable-soap //
> --enable-mbstring=all //多字节,字符串的支持
> --enable-sockets //打开 sockets 支持
[*********************.11]#make;makeinstall
安装完成后,需要建立PHP配置文件。在使用configure命令安装配置时使用
“--with-config-file-path=/usr /local/php/etc/”选项,指定了配置文件的位置。将源码包下面的
-development 文件复制到/usr/local /php/etc/中,并改名为即可,如下所示:
[root@localhost php-5.4.11]# cp -development /usr/local/php/etc/
修改 把;ne 前面的分号去掉,改成ne ="PRC"
[问题] pear有什么作用?PHP-PEAR
13、更改apache的配置文件,达到解析php文件的目的
编辑配置文件/etc/httpd/,在LoadModule最后面添加以下内容
LoadModule php5_module modules/
##通常正确编译安装PHP后会自动增加,如果没有,需要手工添加。
接下来要检查apache目录下生成的php动态连接库文件,在目录/usr/local/apache/modules,
找到是否存在文件。若不存在呢?则说明php安装不正确。
[root@centos6 ~]# vim /etc/httpd/
在/etc/httpd/conf/文件中添加如下内容:
AddType application/x-compress .Z
AddType application/x-gzip .gz .tgz
Addtype application/x-httpd-php .php .phtml
Addtype application/x-httpd-php-source .phps
将下面一行:
DirectoryIndex
修改为:
DirectoryIndex
配置结束后重启Apache
[root@centos6 ~]#service httpd restart
14、 验证
Apache服务器的根目录默认为:/usr/local/apache/htdocs/,此目录下面存放资源:
[root@centos6 ~]# vim /usr/local/apache/htdocs/
添加内容为
echo phpinfo();
>
在客服端验证,出现下图说明php搭建成功


发布评论