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差不多。
LAMP架构介绍、MySQL、MariaDB介绍、MySQL安装的更多相关文章
- CentOS 7 x64下Apache+MySQL(Mariadb)+PHP56的安装
每次搭建新服务器,都要来来回回把这些包再装一下,来来回回搞了不下20遍了吧,原来都是凭经验,配置过程中重复入坑是难免的,故写此文做个备忘.虽然有像xampp这样的集成包,但是在生产环境的Linux发行 ...
- ubuntu 安装 mysql mariadb
本教程面向Ubuntu服务器,适用于Ubuntu的任何LTS版本,包括Ubuntu 14.04,Ubuntu 16.04,Ubuntu 18.04,甚至非LTS版本(如Ubuntu 17.10和其他基 ...
- Ubuntu安装MySQL/MariaDB
安装MariaDB/MySQL MariaDB是MySQL的分支,与MySQL高度兼容,几乎所有的命令都一样.MariaDB是由前MySQL的开发人员离开Sun公司后开发的,目的是为了防止Oracle ...
- Centos7 安装配置优化mysql(mariadb分支)
1.说明 由于在centos7的yum仓库中没有mysql,centos7用mariadb替代了mysql. mariadb是mysql源代码的一个分支, mysql被ORACLE闭源,而mariad ...
- 编译安装基于 fastcgi 模式的多虚拟主机的wordpress和discuz的LAMP架构
目录 实现CentOS 7 编译安装基于 fastcgi 模式的多虚拟主机的wordpress和discuz的LAMP架构 准备环境: 准备软件版本: 主机名修改用以区分 数据库服务器 实现数据库二进 ...
- MySQL/MariaDB系列文章目录
以下是本系列文章的大纲,此页博文完全原创,花费了作者本人的极大心血,如转载,请务必标明原文链接. 如果觉得文章不错,还请帮忙点下"推荐",各位的支持,能激发和鼓励我更大的写作热情. ...
- Linux centos7 LAMP架构介绍、 MySQL、MariaDB介绍、MySQL安装
一.LAMP架构介绍 为Linux+Apache(httpd)+MySQL+PHP简写,把后三者安装在Linux Apache是最常用的的web服务软件,MySQL为小型的数据库存储软件,PHP为脚本 ...
- Mysql数据库介绍、安装和配置文件
Mysql数据库介绍.安装和配置文件 MySQL数据库介绍 mysql是开源关系型数据库,遵循GPL协议. mysql的特点是性能卓越且服务稳定,开源,无版本限制,成本低,单进程多线程,多用户,基于C ...
- MySQL高级知识- MySQL的架构介绍
[TOC] 1.MySQL 简介 概述 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司. MySQL是一种关联数据库管理系统,将数据保存在不同的表中,而 ...
随机推荐
- python3 自己写的一个小算法(比对中文文本相似度)
函数使用说明: 函数的三个参数分别是“匹配语句”,“匹配语料”,“相关度”: 匹配语句,和匹配预料中的语句匹配的语句,必须为字符串: 匹配语料,被匹配语句来匹配的语句列表,必须为列表: 相关度,函数只 ...
- wpf使用技巧
1.设置资源 <Window.Resources> <ResourceDictionary> <ResourceDictionary.MergedDictionaries ...
- js判断是否微信浏览器、IE浏览器
/*判断(微信)浏览器*/ function isWeiXin(){var ua = window.navigator.userAgent.toLowerCase();if(ua.match(/Mic ...
- 揭秘——TCP的三次握手和四次挥手
1.前言 本文以博主在某次前端面试中被问到"什么是TCP协议中的三次握手和四次挥手?"为契机,经过整理教材.百度百科以及他人博客,再结合博主自身的理解,尽可能的以通俗易懂的语言来解 ...
- CF741D Arpa’s letter-marked tree and Mehrdad’s Dokhtar-kosh paths——dsu on tree
题目描述 一棵根为1 的树,每条边上有一个字符(a-v共22种). 一条简单路径被称为Dokhtar-kosh当且仅当路径上的字符经过重新排序后可以变成一个回文串. 求每个子树中最长的Dokhtar- ...
- 在线WEB开发编辑器,edt.df5d.com
在线WEB开发编辑器,http://edt.df5d.com 本地服务端下载 : https://pan.baidu.com/s/11SlcoU_D-KbzGFbs-_9Dpg 即可加载本地磁盘,也可 ...
- CSP-S 94 (sb lsc gc赛)
不要问我为什么题解倒着写,因为在填坑! 关于这场比赛就是我sb的再现 考完试旁边_LH叱的一声说道:“lsc真**垃圾”; lsc:........确实很垃圾! ------------------- ...
- Scrapy进阶知识点总结(一)——基本命令与基本类(spider,request,response)
一.常见命令 scrapy全局命令可以在任何地方用,项目命令只能在项目路径下用 全局命令: 项目命令: startproject crawl genspider check settings list ...
- 单元测试JUnit案例
被测试模块 package packagedemo; public class Largest { public int minimal(int [] array1) { int index = 0 ...
- Git: Setup a remote Git repository
o setup a folder on a server which service for remote Git repository, apply the following steps: Cre ...