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

(1)
M20-1马星M20-1马星
上一篇 2016-11-07 09:44
下一篇 2016-11-07 10:02

相关推荐

  • 文本处理三剑客之一的sed

    处理文本的工具sed Stream EDitor, 行编辑器 sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。Se…

    Linux干货 2017-04-27
  • Linux计划任务

    计划任务 工作当中有时候需要将某件事情在未来的某个特定的时间执行,而自己确不在机器旁,该如何是好?像这样在每天特定的时间内去安排做一些事情这样,一种事情我们就称之为例行性的计划任务,其实在我们的操作系统当中都有类似的例行性任务计划功能,那如何去像设定闹钟一种在Linux上指定例行性计划任务并实施,主要有两种工具:at和crontab   计划任务分…

    Linux干货 2016-09-19
  • Linux系统结构 详解

    Linux系统一般有4个主要部分: 内核、shell、文件系统和应用程序。内核、shell和文件系统一起形成了基本的操作系统结构,它们使得用户可以运行程序、管理文件并使用系统。部分层次结构如图1-1所示。  1. linux内核         内核是操作系统的核心,具有很多最基本功能,它负责管理系…

    Linux干货 2015-04-13
  • MySQL/MariaDB DML操作之Select

    前言 上文我们已经讲解了MySQL/MariaDB的基础知识和DDL相关操作,接下来我们来说一下MySQL/MariaDB的DML操作,因select查询较复杂也较重要,所以本文主要是对select查询的详解。 DML操作 DML之select 投影查询 select col_name,[col_name1,…] from …

    Linux干货 2015-05-07
  • http服务之二

    httpd http协议: http事务:    请求:request    响应:response 报文语法格式: request报文 <method> <request-URL> <version>     <he…

    Linux干货 2016-10-21
  • 第三周练习

    列出当前系统上所有已经登录的用户的用户名,注意:同一用户登录多次,只显示一次。                     ~]# who | cut -d" " …

    Linux干货 2016-11-09