分离php和mysql搭建LAMP平台

分离php和mysql搭建LAMP平台

 

前言:

原先的lamp我们在练习的时候通常在一台计算机上完成的,那么可否将apache、php和mysql分离,如何做到

 

实验准备:

准备两台机子:

192.168.10.251: 安装mysql

192.168.10.252: 安装apache+php

关闭防火墙,selinux

安装mysql

卸载系统存在的rpm软件包,并建立用户,不允许登录系统

for mysql in `rpm -qa |grep mysql`; do rpm -e --nodeps $mysql;done &> /dev/null

if (id mysql); then userdel -r mysql;useradd -s /sbin/nologin -M mysql;else useradd -s /sbin/nologin ;fi &> /dev/null

解压缩包:

tar xf mysql-5.1.55.tar.gz -C /usr/src/

cd /usr/src/mysql-5.1.55

三把斧:

./configure --prefix=/usr/local/mysql  \

--with-charset=utf8  \

--with-extra-charsets=gbk,gb2312  \

--with-collation=utf8_general_ci

make&& make install

 

拷贝启动模版文件和服务启动进程并给予脚本执行权限

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

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

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

初始化数据库:

cd  /usr/local/mysql/bin

./mysql_install_db --user=mysql

数据库路径优化:

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

chown -R mysql /usr/local/mysql/var/

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

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

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

添加开机启动并启动服务:

chkconfig --add mysqld

service mysqld start

进入mysql对apache所在ip给予用户的权限

mysql> grant all on *.* to [email protected] identified by '123';

mysql> flush privileges;

安装apache+php

apache

卸载系统存在的rpm软件包,并建立用户,不允许登录系统

for httpd in `rpm -qa |grep httpd`; do rpm -e $httpd --nodeps; done

解压缩包:

tar xf httpd-2.2.17.tar.gz -C /usr/src/

cd /usr/src/httpd-2.2.17/

三把斧:

./configure --prefix=/usr/local/httpd  \

--enable-so  \

--enable-rewrite  \

--enable-charset  \

--enable-cgi 

make && make install

 

拷贝启动模版文件和服务启动进程并给予脚本执行权限

cd /usr/local/httpd/conf

cp -p httpd.conf httpd.conf.bak

\cp -f /usr/local/httpd/bin/apachectl /etc/rc.d/init.d/httpd

Apache路径优化:

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

ln -s /usr/local/httpd/lib/* /usr/local/lib

ln -s /usr/local/httpd/include/* /usr/local/include/

修改启动脚本

sed -i '/#!/a \# chkconfig:35 85 25\n# description:a apache server script' /etc/init.d/httpd

sed -i '/^#ServerName/a \ServerName domain' /usr/local/httpd/conf/httpd.conf 

添加开机启动并启动服务:

chkconfig --add httpd

service httpd start

php

export LD_LIBRARY_PATH=/usr/local/lib:$ LD_LIBRARY_PATH

cd ~

#源代码安装libmcrypt

tar xf libmcrypt-2.5.8.tar.gz -C /usr/src/

cd /usr/src/libmcrypt-2.5.8/

./configure &&make && make install 

ln -s /usr/local/lib/libmcrypt.* /usr/lib/

cd ~

#源代码安装mhash

tar xf mhash-0.9.9.9.tar.gz -C /usr/src/

cd /usr/src/mhash-0.9.9.9/

./configure && make && make install 

ln -s /usr/local/lib/libmhash* /usr/lib/

cd ~

#源代码安装mcrypt

tar xf mcrypt-2.6.8.tar.gz -C /usr/src/

cd /usr/src/mcrypt-2.6.8/

./configure&&make && make install 

cd ~

mount /dev/sr0 /mnt/ 

yum install -y libtool 

#源代码安装PHP

tar xf php-5.3.6.tar.gz -C /usr/src/

cd /usr/src/php-5.3.6/

 

 ./configure --prefix=/usr/local/php5 --with-mcrypt --with-apxs2=/usr/local/httpd/bin/apxs --with-config-file-path=/usr/local/php5 --enable-mbstring  --with-gd --enable-gd-native-ttf --enable-gd-jis-conv 

如遇到以下错误和解决方案如下

configure: error: libpng.(a|so) not found.

yum install libpng libpng-devel

ln -s /usr/lib64/libjpeg.so /usr/lib/

ln -s /usr/lib64/libpng.so /usr/lib/

                             

# --with-mysql=/usr/local/mysql  注意此行去掉

make && make install

#复制样例文件为php的主配置文件,并修改配置打开短标签

\cp -f /usr/src/php-5.3.6/php.ini-development /usr/local/php5/php.ini

sed -i '/^;default_charset/a \

default_charset="utf8"' /usr/local/php5/php.ini

sed -i '/^short_open_tag/ s/Off/On/' /usr/local/php5/php.ini

#添加ZendGuardLoader模块(优化页面加载速度)

cd ~

tar xf ZendGuardLoader-php-5.3-linux-glibc23-i386.tar.gz -C /usr/src/

cd /usr/src/ZendGuardLoader-php-5.3-linux-glibc23-i386/php-5.3.x/

\cp -f ZendGuardLoader.so /usr/local/php5/lib/php/

cat <<EOF >>/usr/local/php5/php.ini

zend_extension=/usr/local/php5/lib/php/ZendGuardLoader.so

zend_loader.enable=1

EOF

#调整Apache配置,添加.php支持及目录索引

sed -i '/php5_module/a \AddType application/x-httpd-php .php .phml'  /usr/local/httpd/conf/httpd.conf

sed -i '/^[[:space:]]*DirectoryIndex/ s/DirectoryIndex/& index.php/' /usr/local/httpd/conf/httpd.conf

#功能测试

cat <<END > /usr/local/httpd/htdocs/test.php

<?php

phpinfo();

?>

END

cat <<END > /usr/local/httpd/htdocs/mysql.php

<?php

\$link=mysql_connect('192.168.10.251:/tmp/mysql.sock','test','123');

if(\$link) echo "mysql Connect Successfully!";

else echo "Connect Faild!";

mysql_close();

?>

END

service httpd restart

 

当然测试的时候php结合成功了,但是mysql连接失败:因为php还没能连接mysql

注意是通过socket的方式连接

test.php

wKiom1XnbCahteCBAACq6-aeBuc845.jpg 

mysql.php

wKioL1XnbkjSJ5-1AACHOi6X7Ac192.jpg 

 

实现PHP连接MYSQL

安装mysql-devel

yum -y install mysql-devel

利用php的扩展命令phpize对mysql进行支持

cd /usr/src/php-5.3.6/ext/mysql

/usr/local/php5/bin/phpize

利用三把斧生成扩展模块mysql.so并在php.ini配置文件内指定此模块路径

./configure --with-mysql \

--with-php-config=/usr/local/php5/bin/php-config

checking for the location of libz... no

configure: error: Cannot find libmysqlclient under /usr.

Note that the MySQL client library is not bundled anymore!

这个错误时因为在64位的linux系统中,libmysqlclient 默认安装到了 /usr/lib64/mysql/ 目录下,但是php编译时,要去/usr/lib目录下查找
解决办法:在/usr/lib目录下创建一个软连接

ln -s /usr/lib64/mysql/libmysqlclient.so.16 /usr/lib/libmysqlclient.so

 

make && make install

See any operating system documentation about shared libraries for

more information, such as the ld(1) and ld.so(8) manual pages.

----------------------------------------------------------------------

 

Build complete.

Don't forget to run 'make test'.

 

Installing shared extensions:     /usr/local/php5/lib/php/extensions/no-debug-non-zts-20090626/

 

vim /usr/local/php5/php.ini

Extension=/usr/local/php5/lib/php/extensions/no-debug-non-zts-20090626/mysql.sowKioL1XnbkjwNUlcAABFkqpDR6o277.jpg

 

重启服务并测试访问

wKiom1XnbCbC5OUHAADJY3XcgJk509.jpg


----------------------------------------------------------------------------------------------------------------------------------

补充说明:因为在之前我部署网站的时候发现如下图:(上文中已经改好失误)

wKioL1XoqoKxqXQ0AADFZYogvJ0709.jpg 

是因为在配置php的时候没有加入gd库的支持,朋友们配置时候可以自行添加如下的三行即可解决

--with-gd \

--enable-gd-native-ttf \ 

--enable-gd-jis-conv \

并在编译的时候报错,上面已经有说明:再次强调下

如遇到以下错误和解决方案如下

yum install libpng libpng-devel

configure: error: libpng.(a|so) not found.

[root@www php-5.3.6]# ln -s /usr/lib64/libjpeg.so /usr/lib/

[root@www php-5.3.6]# ln -s /usr/lib64/libpng.so /usr/lib/

完事后自可解决

wKiom1XoqF6QbB4BAADWEHiIgj0862.jpg

你可能感兴趣的:(mysql,防火墙,计算机,软件包,登录系统)