博文目录
1、LAMP平台概述
2、部署LAMP架构
3、部署phpMyAdmin系统php
LAMP是一个缩写词,具体包括以下:
L:Linux操做系统、
A:APache网站服务器、
M:MySQL数据库服务器、
P:PHP(或Perl、Python)网页编程语言、html
在LAMP平台的四个构成组件中,每一个组件都承担着一部分关键的应用。通过十几年的发展,各组件间的兼容性获得了不断的完善,写做能力和稳定性也不断加强,能够构建出很是优秀的Web应用系统。各组件的主要做用以下:前端
Linux操做系统:做为LAMP架构的基础,提供用于支撑Web站点的操做系统,可以与其余三个组件提供更好的稳定性、兼容性(AMP组件也支持windows、UNIX等操做系统)。mysql
APache网站服务器:做为LAMP架构的前端,是一款功能强大、稳定性好的Web服务器程序,该服务器之间面向用户提供网站访问,发生网页、图片等文件内容。linux
MySQL数据库服务器:做为LAMP架构的后端,是一款流行的开源关系数据库系统。在企业网站,业务系统等应用中,各类帐户信息、产品信息、客户资料、业务数据等均可以存储到MySQL数据库,其余程序能够经过SQL语句来查询、更改这些信息。程序员
成本低廉:构成组件都是开放源代码的软件,能够自由得到和无偿使用,在技术上和许可证方面没有太严格的限制,大大下降了企业的实施成本。sql
可定制:拥有大量的额外组件和可扩展功能的模块,可以知足大部分企业应用的定制需求,甚至能够自行开发、添加新的功能。数据库
易于开发:基于LAMP平台的动态网站中,页面代码简洁,与HTML标记语言的结合度很是好,即便是非专业的程序员也可以轻松读懂乃至修改网页代码。apache
方便易用:PHP、Perl等属于解释性语言,开发的各类Web程序不须要编译,方便进行移植使用。整套的网站项目程序,一般只要复制到网站目录中,就能够直接访问。编程
在构建LAMP平台时,各组件的安装顺序依次为Linux、Apache、MySQL、PHP。其中APache和MySQL的安装并无严格的顺序;而PHP环境的安装通常放到最后,负责沟通Web服务器和数据库系统以协调工做。
Linux环境能够参考博文:制做Centos 7.4操做系统模板机
部署LAMP用到的全部光盘能够到网盘提取:连接:https://pan.baidu.com/s/1TkzHigBOHvFDuLykbukl3w
提取码:jsam
切换Linux光盘
[root@centos01 ~]# mount /dev/cdrom /mnt/ <!--挂载Linux光盘--> [root@centos01 ~]# tar zxvf /mnt/httpd-2.2.17.tar.gz -C /usr/src/ <!--解压缩httpd到/usr/src/目录--> [root@centos01 ~]# tar zxvf /mnt/cmake-2.8.6.tar.gz -C /usr/src/ <!--解压缩cmake到/usr/src/目录--> [root@centos01 ~]# tar zxvf /mnt/mysql-5.5.22.tar.gz -C /usr/src/ <!--解压缩mysql到/usr/src/目录--> [root@centos01 ~]# tar zxvf /mnt/php-5.3.28.tar.gz -C /usr/src/ <!--解压缩php到/usr/src/目录--> [root@centos01 ~]# tar zxvf /mnt/phpMyAdmin-4.2.5-all-languages.tar.gz -C /usr/src/ <!--解压缩phpMyAdmin到/usr/src/目录--> [root@centos01 ~]# tar zxvf /mnt/ZendGuardLoader-php-5.3-linux-glibc23-x86_64.tar.gz -C /usr/src/ <!--解压缩ZendGuardLoader到/usr/src/目录--> [root@centos01 ~]# cd /usr/src/httpd-2.2.17/ <!--进入httpd目录--> [root@centos01 httpd-2.2.17]# ./configure --prefix=/usr/local/httpd --enable-so --enable-rewrite --enable-charset-lite --enable-cgi <!--配置Apache--> [root@centos01 httpd-2.2.17]# make && make install <!--编译及安装Apache--> [root@centos01 httpd-2.2.17]# ls -ld /usr/local/httpd/ <!--查看服务是否安装成功--> [root@centos01 ~]# ln -s /usr/local/httpd/bin/* /usr/local/bin/ <!--优化Apache程序运行目录 --> [root@centos01 ~]# cp /usr/local/httpd/bin/apachectl /etc/init.d/httpd <!--建立Apache系统服务--> [root@centos01 ~]# chmod +x /etc/init.d/httpd <!--添加执行权限--> [root@centos01 ~]# vim /etc/init.d/httpd <!--使用chkconfig添加系统服务--> #!/bin/sh #chkconfig: 35 80 20 <!--服务识别参数,在级别三、5中启动;启动和关闭的顺序分别为80、20--> #description:apache server <!--服务描述信息--> [root@centos01 ~]# chkconfig --add httpd <!--添加系统服务--> [root@centos01 ~]# chkconfig --level 35 httpd on <!--添加系统服务--> [root@centos01 ~]# systemctl start httpd <!--启动Apache服务--> [root@centos01 ~]# systemctl enable httpd <!--设置开启自动启动--> [root@centos01 ~]# netstat -anptu | grep 80 <!--监听Apache端口号服务是否正常运行-->
监听80端口httpd服务在运行状态的话证实Apache服务搭建的没有问题,接下来开始搭建MySQL数据库
1)卸载光盘[root@centos01 ~]# umount /mnt/ <!--卸载当前光盘-->
2)切换操做系统光盘
[root@centos01 ~]# mount /dev/cdrom /mnt/ <!--挂载操做系统光盘--> [root@centos01 ~]# rm -rf /etc/yum.repos.d/CentOS-* <!--删除系统自动yum源--> [root@centos01 ~]# yum -y install ncurses-devel <!--安装MySQL服务的依赖包--> [root@centos01 ~]# cd /usr/src/cmake-2.8.6/ <!--进入cmake目录--> [root@centos01 cmake-2.8.6]# ./configure <!--配置cmake--> [root@centos01 cmake-2.8.6]# gmake && gmake install <!--编译及安装cmake--> [root@centos01 ~]# groupadd mysql <!--建立管理mysql的组--> [root@centos01 ~]# useradd -M -s /sbin/nologin mysql -g mysql <!--建立管理MySQL数据库的用户,用户加入到mysql组--> [root@centos01 ~]# cd /usr/src/mysql-5.5.22/ <!--进入mysql目录--> [root@centos01 mysql-5.5.22]# cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSETS=all -DSYSCONFDIR=/etc <!--配置mysql程序--> [root@centos01 mysql-5.5.22]# make && make install <!--编译安装mysql--> [root@centos01 mysql-5.5.22]# chown -R mysql:mysql /usr/local/mysql/ <!--设置安装目录数据的全部者--> [root@centos01 mysql-5.5.22]# cp support-files/my-medium.cnf /etc/my.cnf <!--生成mysql服务配置文件--> cp:是否覆盖"/etc/my.cnf"? y <!--输入Y肯定覆盖--> [root@centos01 ~]# vim /etc/profile <!--优化执行名--> # /etc/profile PATH="$PATH:/usr/local/mysql/bin/" <!--设置环境变量--> [root@centos01 ~]# source /etc/profile <!--当即生效--> [root@centos01 mysql-5.5.22]# cp support-files/mysql.server /etc/init.d/mysqld <!--生成MySQL服务控制文件--> [root@centos01 mysql-5.5.22]# chmod +x /etc/init.d/mysqld <!--设置服务的执行权限--> [root@centos01 ~]# chkconfig --add mysqld <!--添加系统服务--> [root@centos01 ~]# chkconfig --level 35 mysqld on <!--添加系统服务--> [root@centos01 ~]# /usr/local/mysql/scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data <!--初始化管理数据的帐户数据库位置和数据库位置--> [root@centos01 ~]# systemctl start mysqld <!--启动mysql服务--> [root@centos01 ~]# systemctl enable mysqld <!--设置开机自动启动--> [root@centos01 ~]# netstat -anptu | grep 3306 <!--监听mysql服务是否启动正常运行--> [root@centos01 ~]# mysqladmin -u root password <!--mysql数据库root用户设置密码--> New password: <!--输入密码--> Confirm new password: <!--再次输入密码--> [root@centos01 ~]# mysql -u root -p <!--测试登陆MySQL数据库--> Enter password: <!--输入密码-->
能够成功登陆MySQL数据库证实MySQL数据库搭建的没有问题,接下来开始部署PHP。
在实际企业应用中,一部分基于PHP开发的Web应用系统会须要额外的扩展工具,如数据加密工具libmcrypt、mhash、mcrypt等(能够从http://sourceforge.net下载)。 安装PHP软件包以前,应先安装好这些扩展工具程序。
[root@centos01 ~]# yum -y install gd libxml2-devel libjpeg-devel libpng-devel <!--安装依赖程序包--> [root@centos01 ~]# umount /mnt/ <!--卸载光盘切换LAMP光盘-->
切换LAMP光盘
[root@centos01 ~]# mount /dev/cdrom /mnt/ <!--挂载LAMP光盘--> [root@centos01 ~]# tar zxvf /mnt/mcrypt-2.6.8.tar.gz -C /usr/src/ <!--解压缩mcrypt加密工具到/usr/src/目录--> [root@centos01 ~]# tar zxvf /mnt/mhash-0.9.9.9.tar.gz -C /usr/src/ <!--解压缩mhash加密工具到/usr/src/目录--> [root@centos01 ~]# tar zxvf /mnt/libmcrypt-2.5.8.tar.gz -C /usr/src/ <!--解压缩libmcrypt加密工具到/usr/src/目录--> [root@centos01 ~]# cd /usr/src/libmcrypt-2.5.8/ <!--进入libmcrypt目录--> [root@centos01 libmcrypt-2.5.8]# ./configure <!--配置libmcrypt--> [root@centos01 libmcrypt-2.5.8]# make && make install <!--编译安装--> [root@centos01 libmcrypt-2.5.8]# ln -s /usr/local/lib/libmcrypt.* /usr/lib <!--建立系统加载链接-> [root@centos01 ~]# cd /usr/src/mhash-0.9.9.9/ <!--进入mhash目录--> [root@centos01 mhash-0.9.9.9]# ./configure <!--配置mhash--> [root@centos01 mhash-0.9.9.9]# make && make install <!--编译安装mhash--> [root@centos01 mhash-0.9.9.9]# ln -s /usr/local/lib/libmhash* /usr/lib <!--建立系统加载链接--> [root@centos01 ~]# cd /usr/src/mcrypt-2.6.8/ <!--进入mcrypt目录--> [root@centos01 mcrypt-2.6.8]# export LD_LIBRARY_PATH=/usr/local/lib <!--手动指定变量--> [root@centos01 mcrypt-2.6.8]# ./configure <!--配置mcrypt--> [root@centos01 mcrypt-2.6.8]# make && make install <!--编译安装mcrypt-->
[root@centos01 php-5.3.28]# ./configure --prefix=/usr/local/php --with-mcrypt --with-apxs2=/usr/local/httpd/bin/apxs --with-mysql=/usr/local/mysql/ --with-mysqli=/usr/local/mysql/bin/mysql_config --with-config-file-path=/usr/local/php --enable-mbstring <!--配置php--> [root@centos01 php-5.3.28]# make && make install <!--安装php--> [root@centos01 php-5.3.28]# ls -ld /usr/local/php/ <!--查看PHP是否安装成功--> [root@centos01 ~]# cp /usr/src/php-5.3.28/php.ini-production /usr/local/php/php.ini <!--生成php配置文件--> [root@centos01 ~]# vim /usr/local/php/php.ini <!--修改php主配置文件--> 174 short_open_tag = On <!--容许识别PHP短语法标记,即<?...?>--> 740 post_max_size = 8M <!--每次经过表单post提交的数据量限制--> 785 default_charset = "utf-8" <!--设置默认字符集为utf-8--> 883 file_uploads = On <!--容许经过PHP网页上传文件--> 892 upload_max_filesize = 2M <!--容许上传的文件大小限制--> 895 max_file_uploads = 20 <!--每一个HTTP最多容许请求上传的文件数--> 973 ;extension=php_mysqli.dll <!--添加MySQL支持--> [root@centos01 ~]# cd /usr/src/ZendGuardLoader-php-5.3-linux-glibc23-x86_64/php-5.3.x/ <!--进入Zend目录--> [root@centos01 php-5.3.x]# mv ZendGuardLoader.so /usr/local/php/lib/php/ <!--移动zend模块位置--> [root@centos01 ~]# vim /usr/local/php/php.ini <!--修改php主配置文件加载zend--> 2 zend_extension=/usr/local/php/lib/php/ZendGuardLoader.so <!--添加加载ZendGuardLoader.so模块--> 3 zend_loader.enable=1 <!--启用ZendGuardLoader.so模块--> [root@centos01 ~]# vim /usr/local/httpd/htdocs/index.php <!--apache网站根目录编写测试php文件--> <?php <!--标签开始--> phpinfo(); <!--显示PHP的环境信息--> ?> <!--标签结束--> [root@centos01 ~]# vim /usr/local/httpd/conf/httpd.conf <!--修改apache主配置文件支持主页为index.php-> 99 ServerName 192.168.100.10:80 <!--Web站点的IP地址--> 168 DirectoryIndex index.html index.php <!--网站主页添加index.php文档类型--> 299 AddType application/x-httpd-php .php <!--支持对以.php结尾的文件--> [root@centos01 ~]# systemctl stop httpd <!--中止apache服务(重启很差使就中止在启动便可)--> [root@centos01 ~]# systemctl start httpd <!--启动apache服务-->
上述配置命令中,各选项的含义以下:
- --prefix:指定将PHP程序安装到那个目录下。
- --with-pcrypt:加载数据加密等扩展工具支持。
- --with-apxs2:设置Apache HTTP Server提供的apxs模块支持程序的文件位置。
- --with-mysql:设置MySQL数据库服务程序的安装位置。
- --with-mysqli:添加mysqli扩展支持。
- --with-config-file-path:设置PHP的配置文件php.ini将要存放的位置。
- --enable-mbstring:启用多字节字符串功能,以便支持中文等代码。
1)开启客户端,设置和服务器同一块网卡
2)客户端配置IP地址
3)访问测试php
http://192.168.100.10/index.php
[root@centos01 ~]# vim /usr/local/httpd/htdocs/index1.php <!--编写测试网页--> <?php $Link=mysqli_connect('localhost','root','pwd@123'); <!--链接MySQL数据库--> if ($Link) echo "恭喜你,数据库链接成功啦!"; <!--链接成功时的反馈信息--> mysqli_close($Link); <!--关闭数据库链接--> ?>
2) 访问测试
http://192.168.100.10/index1.php
phpMyAdmin是一个使用PHP语言编写,用来管理MySQL数据库的Web应用系统。经过该套件提供的网页界面,即使是对SQL语句不太熟悉的人,也可以很是容易地对MySQL数据库进行管理和维护。
[root@centos01 src]# mv phpMyAdmin-4.2.5-all-languages/ /usr/local/httpd/htdocs/phpMyadmin <!--将项目部署在apache网站根目录--> [root@centos01 ~]# cp /usr/local/httpd/htdocs/phpMyadmin/config.sample.inc.php /usr/local/httpd/htdocs/phpMyadmin/config..inc.php <!--设置phpMyadmin主配置文件-->
2)访问phpMyAdmin系统
http://192.168.100.10/phpMyadmin/
3)建立新的库,数据库名字为benet
4)新建数据表,表名字为student
5)表的第一列名字为姓名,第二列名字为性别,第三列名字为年龄,第四列名字为工号
6)student表插入数据
7)查看表中数据
[root@centos01 ~]# mysql -uroot -ppwd@123 <!--Linux登陆MySQL查看数据表--> mysql> use benet; <!--切换到benet数据库--> mysql> select * from student; <!--查看student表中数据--> +--------+--------+--------+----------+ | 姓名 | 性别 | 年龄 | 工号 | +--------+--------+--------+----------+ | 张三 | 男 | 20 | 11111111 | +--------+--------+--------+----------+ 1 row in set (0.00 sec)
—————— 本文至此结束,感谢阅读 ——————