LAMP是一个缩写,它指一组常用于来搭建动态网站或者服务器的开源软件,包括:Linux操作系统,Apache网络服务器,MySQL数据库,PHP、Perl或者 Python编程语言。
LAMP这个特定名词最早出现在1998年。当时,Michael Kunze为德国计算机杂志c't写作的一篇关于自由软件如何成为商业软件替代品的文章时,创建了LAMP这个名词,用来指代Linux、Apache、MySQL和PHP (Perl或Python)脚本语言的组合(由四种技术的开头字母组成)。由于IT世界众所周知的对缩写的爱好,Kunze提出的LAMP这一术语很快就被市场接受。O'Reilly和MySQL AB更是在英语人群中推广普及了这个术语。随之LAMP技术成为了开源软件业的一盏真正的明灯。
HTTPD不仅可以支持静态还可以支持动态像php,per1,jsp
HTTPD+PHP之间通信可以通过以下3种方式
1.cgi通用网关接口http 80结合要通过cgi才能连接到外部的程序,而cgi是可以通过php或者per1实现的,cgi也就相当于中介意思。特点:工作效率低,每一次工作都需要派出一个进程来支持两者通信,一但停止fork也就消失。
2.fastcgi 分布式的指两者在进行通信http通过tcp协议于fpm(管理员)9000端口来进行通信,这时候fpm会派生许多进程与外部程序相连接,一但结束,HTTP与fpm之间会断,而派生出来的进程与外部程序是不会断的。
3.模块
搭建环境:linux+apache+php+mysql lamp只是一种平台
mysql
MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司。
MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。
MySQL的SQL语言是用于访问数据库的最常用标准化语言。
MySQL软件采用了双授权政策(本词条“授权政策”),它分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点, GA一般中小型网站的开发都选择MySQL作为网站数据库。由于其社区版的性能卓越,搭配PHP和Apache可组成良好的开发环境。与其他的大型数据库例如Oracle、DB2、SQL Server等相比,MySQL自有它的不足之处,如规模小、功能有限(MySQLCluster的功能和效率都相对比较差)等,但是这丝毫也没有减少它受欢迎的程度。对于一般的个人使用者和中小型企业来说,MySQL提供的功能已经绰绰有余,而且由于MySQL是开放源码软件,因此可以大大降低总体拥有成本。
LAMP目前Internet上流行的网站构架方式是LAMP (Linux+Apache+MySQL+PHP/Perl/Python)
LNMP(Linux+Nginx+MySQL+php/perl/Python),即使用Linux作为操作系统,Apache和Nginx作为Web服务器,MySQL作为数据库,PHP/Perl/Python作为服务器端脚本解释器。
由于这四个软件都是免费或开放源码软件(FLOSS),因此使用这种方式不用花一分钱(除开人工成本)就可以建立起一个稳定、免费的网站
PHPwww.php.net
PHP原始为Personal Home Page的缩写,现已经正式更名为 "PHP: Hypertext Preprocessor"的缩写。
注意不是“Hypertext Preprocessor”的缩写,
这种将名称放到定义中的写法被称作递归缩写。
PHP于1994年由Rasmus Lerdorf创建,
刚刚开始是Rasmus Lerdorf 为了要维护个人网页而制作的一个简单的用Perl语言编写的程序。
最初这些工具程序用来显示 Rasmus Lerdorf 的个人履历,以及统计网页流量。后来又用C语言重新编写,包括可以访问数据库。他将这些程序和一些表单直译器整合起来,称为 PHP/FI。PHP/FI 可以和数据库连接,产生简单的动态网页程序。
搭建lamp
首先我们先配置yum
vim/etc/yum.repos.d/rhel-debuginfo.repo
[rhel-server]
name=Red Hat Enterprise Linux server
baseurl=file:///mnt/cdrom/Server
enabled=1
gpgcheck=1
gpgkey=file:///mnt/cdrom/RPM-GPG-KEY-redhat-release
安装数据包
yum install httpd mysql-server mysql php php-gd php-mysql
图1
打开80端口
server httpd start
chkconfig httpd on
server mysql start mysql端口号是3306
chkconfig mysql on
对mysql 设置安全机制
mysqladmin -u root -p password ‘ 123’
mysql –u root –p 进入设置密码的数据库需要加上-p选项
create database stu 创建一个名为stu 的数据
show database 查看已经创建的数据库
use stu 打开数据库
create table stu_name (
name varchear(10),
stu_id int);
insert into 可以往数据库里面添加数据
desc stu_name; 查看已经创建好的数据表里面的字段信息
\P 退出
说明:httpd80 和php是通过模块来连接的,php和mysql是通过php_mysql这个工具来进行连接的,模块:/usr/lib/httpd/modules/libphp5.so.
PHP的配置/etc/httpd/conf.d/php.conf
图2
<?php
Phpinfo();
?>
测试:http://192.168.2.100/index.php
Php和mysql结合
测试
vim index.php
<?php
$link=mysql_connect(‘127.0.0.1’,’root’,’123’) 以管理员的身份来调用数据库
If ($link)
echo“ ok”
elso
ehco“not”
?>
应用商城
环境:ECShop_2.7.2_utf8_Relesde0505.zip
unzip ECShop_2.7.2_utf8_Relesde0505.zip
图3
物理目录访问
mv upload//var/www/html/ecshop(ecshop为了方便记忆更改的一个名字)
测试:
图4
提示:更改目录权限,需要把要求这些权限手动一个一个的更改,不可按递归的方式来更改,免造成不必要的损失
chmod –R a+w cert
chmod –R a+w p_w_picpaths/ 注:这里我为了方便快速,采用了递归。
chmod –R a+w temp/
chmod –R a+w themes/
chmod –R a+w data
填写资料
图5
重新刷新测试,则进入商城界面。
观察数据库里面数据
mysql –u root –p 123
图6
show database
desc 可以查看表结构
select cat_id,goods_name,shop_price from ecs_goods从ecs_goods这个表中筛选商品的名称和本店价格,并且你属于哪个栏目。
set names gbk设置字体
PHOMYADMIN
可以通过PHP来管理数据库里面的数据
环境:phpMyAdmin-2.11.10.1-all-languages.zip
物理目录访问
unzip phpMyAdmin-2.11.10.1-all-languages.zip
mv phpMyAdmin-2.11.10.1-all-languages.zip /var/www/html/phpmyadmin
图7
cp –p config.sample.inc.php config.inc.php 把样例文件拷贝成配置文件
图7,1
测试
图8
Phpmyadmin中无法加载mcrypt扩展以下是我的处理方法:
环境:php-mcrypt-5.1.6-5.e15.i386.rpm
libmcrypt-2.5.7-5.e15.i386.rpm
yum localinstall libmcrypt-2.5.7-5.e15.i386.rpm php-mcrypt-5.1.6-5.e15.i386.rpm --nogpgcheck
service httpd restart
这个时候最好把你的浏览器上面的以下缓存,临时文件及安全级别降低一下,重新刷新
图9