LAMP理论整理

关于PHP

官网:http://www.php.net

一、PHP简介
    
PHP是通用服务器端脚本编程语言,其主要用于web开发以实现动态web页面,它也是最早实现将脚本嵌入HTML源码文档中的服务器端脚本语言之一。同时,php还提供了一个命令行接口,因此,其也可以在大多数系统上作为一个独立的shell来使用。

Rasmus Lerdorf于1994年开始开发PHP,它是初是一组被Rasmus Lerdorf称作“Personal Home Page Tool” 的Perl脚本, 这些脚本可以用于显示作者的简历并记录用户对其网站的访问。后来,Rasmus Lerdorf使用C语言将这些Perl脚本重写为CGI程序,还为其增加了运行Web forms的能力以及与数据库交互的特性,并将其重命名为“Personal Home Page/Forms Interpreter”或“PHP/FI”。此时,PHP/FI已经可以用于开发简单的动态web程序了,这即是PHP 1.0。1995年6月,Rasmus Lerdorf把它的PHP发布于comp.infosystems.www.authoring.cgi Usenet讨论组,从此PHP开始走进人们的视野。1997年,其2.0版本发布。

1997年,两名以色列程序员Zeev Suraski和Andi Gutmans重写的PHP的分析器(parser)成为PHP发展到3.0的基础,而且从此将PHP重命名为PHP: Hypertext Preprocessor。此后,这两名程序员开始重写整个PHP核心,并于1999年发布了Zend Engine 1.0,这也意味着PHP 4.0的诞生。2004年7月,Zend Engine 2.0发布,由此也将PHP带入了PHP5时代。PHP5包含了许多重要的新特性,如增强的面向对象编程的支持、支持PDO(PHP Data Objects)扩展机制以及一系列对PHP性能的改进。

二、PHP Zend Engine

Zend Engine是开源的、PHP脚本语言的解释器,它最早是由以色列理工学院(Technion)的学生Andi Gutmans和Zeev Suraski所开发,Zend也正是此二人名字的合称。后来两人联合创立了Zend Technologies公司。

Zend Engine 1.0于1999年随PHP 4发布,由C语言开发且经过高度优化,并能够做为PHP的后端模块使用。Zend Engine为PHP提供了内存和资源管理的功能以及其它的一些标准服务,其高性能、可靠性和可扩展性在促进PHP成为一种流行的语言方面发挥了重要作用。

Zend Engine的出现将PHP代码的处理过程分成了两个阶段:首先是分析PHP代码并将其转换为称作Zend opcode的二进制格式(类似Java的字节码),并将其存储于内存中;第二阶段是使用Zend Engine去执行这些转换后的Opcode。

三、PHP的Opcode

Opcode是一种PHP脚本编译后的中间语言,就像Java的ByteCode,或者.NET的MSL。PHP执行PHP脚本代码一般会经过如下4个步骤(确切的来说,应该是PHP的语言引擎Zend):
1、Scanning(Lexing) —— 将PHP代码转换为语言片段(Tokens)
2、Parsing —— 将Tokens转换成简单而有意义的表达式
3、Compilation —— 将表达式编译成Opocdes
4、Execution —— 顺次执行Opcodes,每次一条,从而实现PHP脚本的功能

四、php的加速器

基于PHP的特殊扩展机制如opcode缓存扩展也可以将opcode缓存于php的共享内存中,从而可以让同一段代码的后续重复执行时跳过编译阶段以提高性能。由此也可以看出,这些加速器并非真正提高了opcode的运行速度,而仅是通过分析opcode后并将它们重新排列以达到快速执行的目的。

常见的php加速器有:

1、APC (Alternative PHP Cache)
遵循PHP License的开源框架,PHP opcode缓存加速器,目前的版本不适用于PHP 5.4。项目地址,http://pecl.php.net/package/APC。

2、eAccelerator
源于Turck MMCache,早期的版本包含了一个PHP encoder和PHP loader,目前encoder已经不在支持。项目地址, http://eaccelerator.net/。

3、XCache
快速而且稳定的PHP opcode缓存,经过严格测试且被大量用于生产环境。项目地址,http://xcache.lighttpd.net/

4、Zend Optimizer和Zend Guard Loader
Zend Optimizer并非一个opcode加速器,它是由Zend Technologies为PHP5.2及以前的版本提供的一个免费、闭源的PHP扩展,其能够运行由Zend Guard生成的加密的PHP代码或模糊代码。 而Zend Guard Loader则是专为PHP5.3提供的类似于Zend Optimizer功能的扩展。项目地址,http://www.zend.com/en/products/guard/runtime-decoders

5、NuSphere PhpExpress
NuSphere的一款开源PHP加速器,它支持装载通过NuSphere PHP Encoder编码的PHP程序文件,并能够实现对常规PHP文件的执行加速。项目地址,http://www.nusphere.com/products/phpexpress.htm

五、PHP源码目录结构

PHP的源码在结构上非常清晰。其代码根目录中主要包含了一些说明文件以及设计方案,并提供了如下子目录:

1、build —— 顾名思义,这里主要放置一些跟源码编译相关的文件,比如开始构建之前的buildconf脚本及一些检查环境的脚本等。
2、ext —— 官方的扩展目录,包括了绝大多数PHP的函数的定义和实现,如array系列,pdo系列,spl系列等函数的实现。 个人开发的扩展在测试时也可以放到这个目录,以方便测试等。
3、main —— 这里存放的就是PHP最为核心的文件了,是实现PHP的基础设施,这里和Zend引擎不一样,Zend引擎主要实现语言最核心的语言运行环境。
4、Zend —— Zend引擎的实现目录,比如脚本的词法语法解析,opcode的执行以及扩展机制的实现等等。
5、pear —— PHP 扩展与应用仓库,包含PEAR的核心文件。
6、sapi —— 包含了各种服务器抽象层的代码,例如apache的mod_php,cgi,fastcgi以及fpm等等接口。
7、TSRM —— PHP的线程安全是构建在TSRM库之上的,PHP实现中常见的*G宏通常是对TSRM的封装,TSRM(Thread Safe Resource Manager)线程安全资源管理器。
8、tests —— PHP的测试脚本集合,包含PHP各项功能的测试文件。
9、win32 —— 这个目录主要包括Windows平台相关的一些实现,比如sokcet的实现在Windows下和*Nix平台就不太一样,同时也包括了Windows下编译PHP相关的脚本。

关于数据库与MySQL

一、RDBMS(Relational Data Base Management System——关系型数据库管理系统)应有的功能

1、数据库的创建、删除、修改

2、创建表、删除表、修改表

3、索引的创建、删除

4、用户和权限管理

5、数据的增、删、查、改

二、数据库语言分类:

1、DML:Data Manapulate Language:——数据操作语言
  INSERT、 REPLACE、 UPDATE、 DELETE
2、DDL:Data Defination Lanuage——数据定义语言
  CREATE、 ALTER、 DROP
3、DCL:Data Control Language——数据控制语言
  GRANT、 REVOKE

4、SELECT

三、RDBMS的作用

1、数据管理独立性
2、有效地完成数据存取
3、数据完整性和安全性
4、数据集中管理
5、并发存储与故障恢复
6、减少应用程序开发时间

四、关系数据库对象:

1、库

2、表

3、索引

4、视图

5、约束

6、存储过程

7、存储函数

8、触发器

9、游标

10、用户

11、权限

12、事务

五、SQL接口:

  Oracle:PL/SQL

  SQL Server T-SQL

六、MySQL(http://www.mysql.com/

MySQL:
Community Edtion 社区版本
Enterprise Edtion 企业版本

软件包格式:
1、软件包管理器特有的格式
rpm包、exe格式等
2、通用二进制格式
3、源程序

MySQL客户端的运行模式:
  1、交互式模式

  注:交互式模式中的命令类别:
    客户端命令:在客户端本身执行的命令,例如:quit
    服务器端命令:要发送到服务器端由服务器执行并返回到客户端的命令,都必须使用语句结束符,默认为分号
  2、批处理模式——通过执行mysql脚本来完成数据操作

基本MySQL语句:

DDL:

  创建数据库
    CREATE DATABASE db_name;
    CREATE DATABASE [IF NOT EXISTS] db_name;

  删除数据库
    DROP DATABASE [IF EXISTS] db_name;

  创建表
    CREATE TABLE tb_name(col1,col2,...);

  查看库中的表

    SHOW TABLES FROM db_name;

  查看表的结构

    DESC tb_name;

  删除表:

    DROP TABLE tb_name;

  修改表
    ALTER TABLE tb_name
      MODIFY  修改某个字段的属性
      CHANGE  修改某个字段的名称和属性
      ADD  添加字段
      DROP  删除字段

    注:详细用法可通过help alter table查询

DML:

  插入数据
    INSERT INTO tb_name (col1,col2,...) VALUES|VALUE (‘STRING‘, NUM,...);
    INSERT INTO tb_name (col1,col2,...) VALUES|VALUE (‘STRING‘, NUM,...),(‘STRING‘,NUM,...);

  更改数据
    UPDATE tb_name SET column=value WHERE

  

  删除数据

    DELETE FROM tb_name WHERE CONDITION;

  查询数据
    SELECT 字段 FROM tb_name WHERE CONDITION
      *: 所有字段
      WHERE:没有条件表示显示所有行;

  创建用户
    CREATE USER ‘USERNAME‘@‘HOST‘ [IDENTIFIED BY ‘PASSWORD‘];

    HOST字段可以为:HOST、IP、HOSTNAME、NETWORK、也可以使用通配符

        _:匹配任意单个字符, 172.16.0._
        %:匹配任意字符;

  删除用户
    DROP USER ‘USERNAME‘@‘HOST‘;

DCL:

  授权
    GRANT pri1,pri2,... ON DB_NAME.TB_NAME TO ‘USERNAME‘@‘HOST‘ [IDENTIFIED BY ‘PASSWORD‘];

  取消授权
    REVOKE pri1,pri2,... ON DB_NAME.TB_NAME FROM ‘USERNAME‘@‘HOST‘;

  查看用户的授权

    SHOW GRANTS FOR ‘USERNAME‘@‘HOST‘;

为用户设定密码:
  1、mysql>SET PASSWORD FOR ‘USERNAME‘@‘HOST‘=PASSWORD(‘password‘);

  2、# mysqladmin -uUSERNAME -hHOST -p password ‘password‘

  3、mysql> UPDATE user SET Password=PASSWORD(‘password‘) WHERE USER=‘root‘ AND Host=‘127.0.0.1‘;

  注:每次更改或者设定密码后,都需要执行FLUSH PRIVILEGES;让mysql重新读取配置文件到内存当中,否则新密码没有生效。

时间: 2024-10-14 23:58:27

LAMP理论整理的相关文章

数据库优化理论整理之思维导图

经过整整一个月的整理,最新版的数据库优化理论梳理之思维导图版本已经出炉.这里先放出部分截图给大家欣赏.

mongodb副本集和分片存储理论整理

目录 理论概述 一.各种集群简述 二.原理 主从复制 Mongodb副本集 理论概述 一.各种集群简述 mongodb有三种集群搭建方式: 分片:sharding.指为处理大量数据,将数据分开存储,不同服务器保存不同的数据,它们的数据总和即为整个数据集.追求的是高性能. 复制集:Master-Slave 模式(主从复制). 副本集:副本集其实一种互为主从的关系,可理解为主主.副本集指将数据复制,多份保存,不同服务器保存同一份数据,在出现故障时自动切换.对应的是数据冗余.备份.镜像.读写分离.高可

理论整理(四)

1.Git 和 SVN 之间的区别: 1.GIT是分布式的,SVN不是分布式:   (最核心的区别) 2.GIT把内容按元数据方式存储,而SVN是按文件: 3.GIT分支和SVN的分支不同: 4.GIT没有一个全局的版本号,而SVN有: 5.GIT的内容完整性要优于SVN: 2.JQuery的功能和作用: jQuery是一个快速.简洁的JavaScript框架, 核心特性: 1.具有独特的链式语法和短小清晰的多功能接口 2.具有高效灵活的css选择器,并且可对CSS选择器进行扩展 3.拥有便捷的

SQL常用语句积累

SQL 常用语句积累: 一. SQL 基本语句 SQL 分类: DDL -数据定义语言 (Create , Alter , Drop , DECLARE) DML -数据操纵语言 (Select , Delete , Update , Insert) DCL -数据控制语言 (GRANT , REVOKE , COMMIT , ROLLBACK) 首先 , 简要介绍基础语句: 1 .说明:创建数据库 Create DATABASE database-name 2 .说明:删除数据库 drop d

Sql基本知识回顾

一. SQL 基本语句 SQL 分类: DDL —数据定义语言 (Create , Alter , Drop , DECLARE) DML —数据操纵语言 (Select , Delete , Update , Insert) DCL —数据控制语言 (GRANT , REVOKE , COMMIT , ROLLBACK) 首先 , 简要介绍基础语句: 1 .说明:创建数据库 Create DATABASE database-name 2 .说明:删除数据库 drop database dbna

(转)SQL 常用语句

SQL 常用语句积累: 一. SQL 基本语句 SQL 分类: DDL —数据定义语言 (Create , Alter , Drop , DECLARE) DML —数据操纵语言 (Select , Delete , Update , Insert) DCL —数据控制语言 (GRANT , REVOKE , COMMIT , ROLLBACK) 首先 , 简要介绍基础语句: 1 .说明:创建数据库 Create DATABASE database-name 2 .说明:删除数据库 drop d

南阳任书山:以国学助力企业文化,以文化促进企业发展

7月13日河南中兴博达集团董事长任书山一行在北京九华山庄与前国家主席导师王汉中先生以及国学大师陈青群先生举行会谈.    会谈围绕"国学普及的意义"."国学普及和社会主义核心价值体系"等诸多话题进行了热烈的讨论.    王汉中导师在谈到国学现状时表示"要向传统文化汲取营养最紧要的是读经典其次要学习儒家道德建设中融合"应然"和"实然"的方法让共产主义理想与现实结合最后是要处理好"普世价值"和&quo

社交时代,如何组建并运营一个高质量的社群?

---恢复内容开始--- 简介:石皮先生,一个从Coder转为运营的斜杠青年. 微信公众号:石皮先生 何为社群,日前常见的社群形式有哪些? 社群即基于兴趣或需求的某一人群的集合,常见的社群形式有:微信群.QQ群.论坛.社区.贴吧等.一个社群起源于事件驱动/兴趣驱动,活跃于区域驱动.关系驱动.荣誉驱动.利益驱动. 优秀/高质量社群定义:人们相互认识.相互信任.成员之间互动频繁. 根据我一年多的社群学习(推荐徐志斌老师小群策略)和实践(运营一个土耳其旅游群),总结了社群运营的几点方法论. 一.社群定

LAMP搭建--未整理版

[[email protected] ~]#yum search  关键字   //安装过程中提示少哪个程序就搜关键字找包名 [[email protected] httpd-2.2.25]# ./configure --prefix=/usr/local/httpd --enable-so --enable-rewrite --enable-cgi --enable-charrset-lite --enable-ssl [[email protected] ~]#useradd -M -s /