5月23日任务

课程内容:

11.1 LAMP架构介绍
11.2 MySQL、MariaDB介绍
11.3/11.4/11.5 MySQL安装
扩展
mysql5.5源码编译安装 http://www.aminglinux.com/bbs/thread-1059-1-1.html
mysql5.7二进制包安装(变化较大) http://www.apelearn.com/bbs/thread-10105-1-1.html

11.1 LAMP架构介绍

LAMP包含Linux+Apache(httpd)+MySQL+PHP

(Google、淘宝、百度、51CTO博客、猿课论坛)等,这些网站都属于PHP网站。

Linux服务器里面三个角色可以在一台机器,也可以分开(httpd和PHP要在一起),可以把httpd和PHP理解成一个整体,MySQL可以单独一台机器,这样是可以的,对于一些访问量不大的网站,可以在一台机器上跑3个程序是可以的,httpd和PHP是一个整体,最终相当于在一台服务器上起了2个服务,一个是httpd一个是MySQL,也可以把httpd装在一台机器上,MySQL装在另外一台机器上,通过网络的形式连接起来。

Apache和PHP是一个整体,因为PHP是以一个模块的形式和Apache结合在一起的,但是Apache不能直接和MySQL相互去打交道,只能够通过PHP这个模块去MySQL里面拿数据,拿到数据后PHP把结果交给Apache,Apache再交给用户,是这样的一个过程,这种PHP和MySQL相连去取数据的行为叫动态请求。

举例说明什么是动态请求:比如现在访问的猿课论坛,每天都需要发帖子,登录时候输入网址,然后用户名和密码的请求交给Apache,Apache把用户名和密码的数据去数据库比对,检查是否正确,通过PHP模块和MySQL打交道,首先从MySQL去查这个用户名信息对不对,然后PHP再做一个对比,如果对的话Apache就会返回用户一个登录状态,这样的过程就是动态请求。

静态请求: 访问猿课网站时候的一个Log图片,同样也是需要到Apache上去请求,图片文件不会存放到MySQL,Apache拿到Log直接从静态文件目录获取(在Linux服务器上的某一个目录里面),然后返回给用户,这个过程并没有和MySQL打交道,这样的过程就是静态请求。

猿课论坛的用户名和密码,以及每天回复的帖子和积分都是存放到MySQL里面。

11.2 MySQL、MariaDB介绍

11.3/11.4/11.5 MySQL安装

安装MySQL的方法步骤:

[root@jimmylinux-002 ~]# uname -a  可以查看Linux属于32位还是64位平台,X86_64就表示64位,如果是i586、i686就表示32位平台的,当然在CentOS7里面直接就是64,不再有32位之分。

安装包虽然有32位的,但是也建议大家使用64位,因为64位的兼容性会更好。

[root@jimmylinux-002 ~]# wget http://mirrors.sohu.com/mysql/MySQL-5.6/mysql-5.6.36-linux-glibc2.5-x86_64.tar.gz

[root@jimmylinux-002 src]# tar zxvf mysql-5.6.36-linux-glibc2.5-x86_64.tar.gz  下载完以后首先解压软件包

[root@jimmylinux-002 src]# mv mysql-5.6.36-linux-glibc2.5-x86_64 /usr/local/mysql  移动目录并且改名

[root@jimmylinux-002 src]# cd /usr/local/mysql  进入到MySQL目录

[root@jimmylinux-002 mysql]# useradd mysql  创建MySQL用户

[root@jimmylinux-002 mysql]# mkdir /data/  创建data目录,如果已经存在可以省略这一步。

[root@jimmylinux-002 mysql]# ./scripts/mysql_install_db --user=mysql --datadir=/data/mysql

指定用户为MySQL,在指定它的datadir等于/data/mysql

出现报错信息,这个脚本属于Perl脚本,和PHP和Python类似的脚本语言,少了一个模块Dumper。

如果不知道到底安装缺少的包是什么名字,那么就可以yum模糊搜索。

[root@jimmylinux-002 mysql]# yum list |grep perl |grep -i dumper  包含Perl和dumper的模糊搜索,-i表示不区分大小写,这里指的是Dumper。

搜索出来的安装包,如果在拿不准的情况下,可以一个一个去尝试安装。

[root@jimmylinux-002 mysql]# yum install -y perl-Data-Dumper

[root@jimmylinux-002 mysql]# ./scripts/mysql_install_db --user=mysql --datadir=/data/mysql  安装完成以后再执行这条命令

如果有如下报错

需要再创建绝对路径的目录  mkdir -p /data/mysql/ 

再执行初始化命令,如果出现如下图2个OK表示成功,或者在刚执行的命令下紧着输入echo $? 如果非0表示不成功,0表示成功。

初始化完成以后,再copy配置文件和启动脚本。

cp support-files/my-default.cnf /etc/my.cnf
cp support-files/mysql.server /etc/init.d/mysqld

[root@jimmylinux-002 mysql]# ls support-files/my-defaulet.cnf  配置文件在这个路径下,并且有一个模板的配置文件。

默认的模板配置文件没有什么内容,而且大多数都是以#号注释掉的。

cp support-files/my-default.cnf  /etc/my.cnf  拷贝配置文件到/etc,而且改名my.cnf

MySQL的配置文件就叫my.cnf,而且固定放在etc下,如果想放到其他地方,那么在启动的时候需要做一个指定,不然默认会去etc下面的my.cnf。在复制之前可以看一下etc下面有一个自带的my.cnf  还可以查看自带的my.cnf是由那个rpm包安装来的。

[root@jimmylinux-002 mysql]# vi /etc/my.cnf  当然不用拷贝my.cnf文件,也可以直接使用etc下自带的my.cnf,但是必须要修改下里面的内容才行(如下图)。

cp support-files/mysql.server /etc/init.d/mysqld  拷贝启动脚本到/etc/init.d/下并改名为mysqld

vi /etc/init.d/mysqld  编辑启动脚本,定义成以下内容,其他保持默认不用修改,保存退出。

在把文件/etc/init.d/mysqld 修改成755权限,其实默认已经是755,不需要再修改。

如果想开机自动启动,需要把mysqld加入到系统服务列表里面去,这样下次开机就会自动启动。

[root@jimmylinux-002 mysql]# service mysqld start  也可以直接使用命令启动

假如没有把启动的脚本放到/etc/init.d/下面去,或者根本就没有这样的启动脚本模板去拷贝,那么可以使用命令的方式去启动。

首先停掉mysqld服务

然后再执行命令方式启动

[root@jimmylinux-002 mysql]# /usr/local/mysql/bin/mysqld_safe --defaults-file=/etc/my.cnf --user=mysql --datadir=/data/mysql &

MySQL启动了,如何去关闭呢,可以使用killall mysqld 关闭,一般使用这样的方式会更加安全些。

MySQL在实时的写入数据的时候,如果使用kill+PID方式,这样很容易导致文件丢失或损坏,要是使用killall,它会先停止当前的写读操作,然后把没有完成的写入到磁盘的数据慢慢写进去,直到写完之后才把进程杀死,如果以后遇到mysqld的进程始终杀不死,等了一分钟还没有杀死,ps还会有进程,说明数据量很大,正在慢慢的写入到磁盘里去,这个时候不要强制使用kill -9去杀进程,这个时候很容易丢数据甚至会损坏表,只能慢慢的等,尤其是数据量有几百个G,而且用的引擎是innodb的引擎,关于MySQL有2个引擎,一个是innodb,一个是myisam,myisam空间小存储量很小,innodb比较大和oracle差不多。

LAMP架构介绍、MySQL、MariaDB介绍、MySQL安装的更多相关文章

  1. CentOS 7 x64下Apache+MySQL(Mariadb)+PHP56的安装

    每次搭建新服务器,都要来来回回把这些包再装一下,来来回回搞了不下20遍了吧,原来都是凭经验,配置过程中重复入坑是难免的,故写此文做个备忘.虽然有像xampp这样的集成包,但是在生产环境的Linux发行 ...

  2. ubuntu 安装 mysql mariadb

    本教程面向Ubuntu服务器,适用于Ubuntu的任何LTS版本,包括Ubuntu 14.04,Ubuntu 16.04,Ubuntu 18.04,甚至非LTS版本(如Ubuntu 17.10和其他基 ...

  3. Ubuntu安装MySQL/MariaDB

    安装MariaDB/MySQL MariaDB是MySQL的分支,与MySQL高度兼容,几乎所有的命令都一样.MariaDB是由前MySQL的开发人员离开Sun公司后开发的,目的是为了防止Oracle ...

  4. Centos7 安装配置优化mysql(mariadb分支)

    1.说明 由于在centos7的yum仓库中没有mysql,centos7用mariadb替代了mysql. mariadb是mysql源代码的一个分支, mysql被ORACLE闭源,而mariad ...

  5. 编译安装基于 fastcgi 模式的多虚拟主机的wordpress和discuz的LAMP架构

    目录 实现CentOS 7 编译安装基于 fastcgi 模式的多虚拟主机的wordpress和discuz的LAMP架构 准备环境: 准备软件版本: 主机名修改用以区分 数据库服务器 实现数据库二进 ...

  6. MySQL/MariaDB系列文章目录

    以下是本系列文章的大纲,此页博文完全原创,花费了作者本人的极大心血,如转载,请务必标明原文链接. 如果觉得文章不错,还请帮忙点下"推荐",各位的支持,能激发和鼓励我更大的写作热情. ...

  7. Linux centos7 LAMP架构介绍、 MySQL、MariaDB介绍、MySQL安装

    一.LAMP架构介绍 为Linux+Apache(httpd)+MySQL+PHP简写,把后三者安装在Linux Apache是最常用的的web服务软件,MySQL为小型的数据库存储软件,PHP为脚本 ...

  8. Mysql数据库介绍、安装和配置文件

    Mysql数据库介绍.安装和配置文件 MySQL数据库介绍 mysql是开源关系型数据库,遵循GPL协议. mysql的特点是性能卓越且服务稳定,开源,无版本限制,成本低,单进程多线程,多用户,基于C ...

  9. MySQL高级知识- MySQL的架构介绍

    [TOC] 1.MySQL 简介 概述 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司. MySQL是一种关联数据库管理系统,将数据保存在不同的表中,而 ...

随机推荐

  1. InfluxDB常见疑问与解答 - 数据写入时如何在表级别指定保留策略

    网友Siguoei:我想让一个库中不同的measurment能够指定不同的保存策略.而不是写入时使用数据库的默认保留策略. Answer:这个特性InfluxDB支持的,写入时序数据时,在行协议前加上 ...

  2. python基础-数字类型及内置方法

    --数字类型及内置方法 整型-int 用途:多用于年龄.电话.QQ号等变量 定义方法 age = 18 # age = int(18) 常用方式:多用于数学计算 # int(x)将x转换成整数,是向下 ...

  3. 前端技术之:使用webpack构建React程序配置方法

    package.json中需要引入以下依赖:   开发依赖: "@babel/core": "^7.1.2", "@babel/preset-env& ...

  4. Scrapy爬虫day1——环境配置

    安装 Scrapy pip install scrapy 配置虚拟环境 mkvirtualenv Spider 创建项目 在Spider的虚拟环境中运行 scrapy startproject Boo ...

  5. Keepalived+LVS DR模式高可用架构实践

    Keepalived最初是为LVS设计,专门监控各服务器节点的状态(LVS不带健康检查功能,所以使用keepalived进行健康检查),后来加入了VRRP(虚拟路由热备协议(Virtual Route ...

  6. [考试反思]0809NOIP模拟测试15:解剖

    说在前面: 不建议阅读.这里没有考试经验,只有一大堆负面情绪. 看了你不会有什么收获.看完了就不要怪我影响了你的心情. 以后不粘排行榜了.没什么意思没什么用. 但是我的意思并不是因为这次没考好的一时兴 ...

  7. 『题解』LibreOJ6277 数列分块入门 1

    更好的阅读体验 Portal Portal1: LibreOJ Description 给出一个长为\(n\)的数列,以及\(n\)个操作,操作涉及区间加法,单点查值. Input 第一行输入一个数字 ...

  8. CSS3解决字母不换行的方法

    CSS3解决字母不换行的方法 <pre>word-wrap: break-word;</pre>

  9. VMware虚拟机添加5个RAID10磁盘并挂载

    1.打开虚拟机之前先添加硬盘设备 具体添加方法详见我https://www.cnblogs.com/Ghost-m/p/11707996.html这个博客 制作RAID需要用到madam命令 mdad ...

  10. CMDB连接方式

    1.agent agent (放在每台客户端服务器上,定时任务) 脚本演示 # 采集本机的信息 执行命令 import subprocess v1 = subprocess.getoutput('ip ...