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服务与当前系统环境的测试页面 <?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