linux LAMP的作用和现状,lamp简介

lamp

构建一个有着动态服务器端技术的网站

LAMP基础

1)开源领域LAMP组成:

L:Linux;A:apache (httpd);M:mysql, mariadb;P:php, perl, python

httpd:接收用户的web请求;静态资源则直接响应;动态资源为php脚本交由php来运行;

php:运行php程序;

MariaDB:数据管理系统;

2)CGI:Common Gateway Interface,通用网关接口

CGI描述了客户端和服务器程序之间传输的一种标准;可以让一个客户端,从网页浏览器向执行在网络服务器上的程序传输数据;

3)请求流程

Client -- (http协议) --> httpd -- (cgi协议) --> application server (program file) -- (mysql) --> mysql

客户端浏览器发出请求,通过http协议发向Web服务器,若为静态请求则httpd发起系统调用,磁盘IO调用数据,返回给用户;

若为动态请求,则通过CGI通用网关接口协议发送给应用程序服务器,通过 如php脚本等动态执行通过mysql协议调用mysql程序查询结果,并返回。

静态资源:Client -- http --> httpd

动态资源:Client -- http --> httpd --> libphp5.so () -- mysql --> MySQL serve

PHP

php: 脚本编程语言

嵌入到html中的嵌入式web程序开发语言,高度模块化(extensions),无需编译;大多数情况无需用到管理员权限运行,更加安全

基于zend编译成opcode(二进制格式的字节码,重复运行可省略编译环境)

Scanning(扫描) --> Parsing(分析) --> Compilation(编译) --> Execution(执行)

httpd与php结合的方式

1)CGI:最传统方式,必要时需要创建和销毁子进程

2)FastCGI:将php运行成一个服务监听在套接字,有主进程和空闲进程,独立的服务进程;工作模式类似于httpd的prefork;

注意:

1)需要安装php-fpm程序包,非php程序包

2)httpd2.2不支持FastCGI协议功能需自己编译;CentOS 7的httpd2.4将其加入成为模块

3)modules (把php编译成为httpd的模块):当请求动态请求时无需再启动一个新的进程,默认结合方式基于MPM相关的php所编译的模块:

prefork: libphp5.so;

event, worker: libphp5-zts.so

php服务配置文件

1)/etc/php.ini,  /etc/php.d/*.ini ,一般由php-common程序包提供php相关所有配置文件

2)php配置文件在php解释器启动时被读取,修改配置文件后重启httpd服务或重启php-fpm服务;

3)通过配置段[*]配置,directive = value方式配置每段内部信息

[php]表示核心配置信息,其他[ ]为单独安装包组件配置信息

4)注释符:较新的版本中,已经完全使用;进行注释;

#:纯粹的注释信息

;:用于注释可启用的directive

5)相关官方文档

php.ini的核心配置选项文档:  http://php.net/manual/zh/ini.core.php

php.ini配置选项列表:http://php.net/manual/zh/ini.list.php

php应用程序:

开源代表:wordpress, discuzX, phpwind, drupal...

示例:安装测试php

]# yum install php

]# systemctl reload http.service

]# vim /var/www/html/phpinfo.php 编辑测试主页:如下写入一个php能调用自己的内建函数;这个函数可以提供一个php服务与当前系统环境的测试页面

phpinfo{};

?>

http://IP/phpinfo 浏览器访问进行测试

数据库简介

MySQL:支持插件式存储引擎

MySQL是一个多用户,多线程SQL数据库服务器

C/S:MySQL是CS架构的,所要人要与其打教道都应该通过MySQL所监听在套接字上的MySQL协议进行

Server: mysqld, mysqld_safe, mysqld_multi

Client:mysql

MySQL:

Community Edtion

Enterprise Edtion

CentOS 6: mysql-server, mysql

额外添加的配置项:

[mysqld]

...

skip_name_resolve :跳过主机名解析

innodb_file_per_table=ON :每表单独的表空间

MariaDB:

CentOS 7: 服务器端程序包:mariadb-server, 客户端程序包mariadb

配置文件:/etc/my.cnf, /etc/my.cnf.d/*.cnf

经常使用要额外添加的配置项:

[mysql]

skip_name_resolve = ON :跳过主机名解析

innodb_file_per_table = ON :每表单独的表空间

centos7示例:

]# vim /etc/my.cnf 加入配置项

skip_name_resolve = ON

innodb_file_per_table = ON

]# systemctl start mariadb.service 配置后启动,初次启动比较耗时

此时使用mysql命令就可以登录到mysql服务上去了;mysql是需要认证授权以后才允许用户访问数据库的,不过不指定连接的服务器时默认连接的就是本机的mysql server,

所以连接的时候需要用户名和密码,如果用户名不指;

默认的管理员用户为:root,密码为空;首次安装后建议使用mysql_secure_installation命令进行安全设定;

客户端连接mysql server:

mysql --> mysql protocol --> mysql server

语法:mysql [options] db_name

选项  -hHOST

-uUSERNAME

-pPASSWORD

mysql的用户账号:

username@host

username:用户名

host:此用户可通过哪些客户端主机登录当前服务器上的mysql服务;主机名和IP地址属性于不同的主机;

可使用通配符:

_:任意单个字符;

%:任意长度以的任意字符;

root@'10.1.%.%'

首次安装后建议使用mysql_secure_installation命令进行安全设定

进入mysql后会处于mysql命令行界面下,此时可以使用mysql命令;

mysql> 可接受输入mysql命令,分两类

客户端命令:

help可获取命令列表

服务端命令:SQL语句,必须使用语句结束符,默认为分号;

DDL(数据定义语言):CREATE(创建), ALTER(修改), DROP(删除)

DML:INSERT(增), DELETE(删), UPDATE(改), SELECT(查)

GRANT/REVOKE:授权和取消授权命令

授权命令:

GRANT ALL [PRIVILEGES] ON db.tbl TO 'username'@'host' IDENTIFIED BY 'password';

db:数据库的名字,可以使用*通配;

tbl:表的名称,可以使用*通配;

例:mydb.*, *.*, mydb.tbl1

FLUSH PRIVILEGES:重载授权表

数据库的基本操作:

CREATE DATABASE db_name;:创建数据库

DROP DATABASE db_name;  :删除数据库

快速部署lamp环境:

CentOS 7:

# yum install mariadb-server httpd php php-mysql

# systemctl start httpd.service mariadb.service

CentOS 6:

# yum install httpd php php-mysql mysql-server

# service httpd start

# service mysqld start

原创文章,作者:M20-1马星,如若转载,请注明出处:http://www.178linux.com/58130

你可能感兴趣的:(linux,LAMP的作用和现状)