LAMP架构介绍、MySQL、MariaDB介绍、MySQL安装
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 安装完成以后再执行这条命令
如果有如下报错
再执行初始化命令,如果出现如下图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差不多。