一  Nosql 指的是非关系型数据库,作为传统关系型数据库的一个有效补充,针对特定场景。以高性能和使用便利为目一 

的功能特异化的数据库产品


Nosql特点:

Noosql数据库存储不需要固定的表结构

1 他不是否定关系数据库,而是作为关系数据库的一个重要补充

2 Nosql为了高性能高并发而产生的

3 Nosql典型产品memcache(纯内存) 一重启就丢数据

  redis(持久化缓存)  持久化缓存  

  mongodb   


二  非关系型数据库种类:

1 键值存储数据库

2 列存储数据库

3 面向文档的数据库  mongodb 

4 图形数据库


三 关系型数据库

1  oracle主要应用范围:传统大企业 大公司 政府 金融 证券

关系型数据库比较笨重一个软件很大 几个G左右

2  mysql数据库互联网公司最常用的公司 适用于大中小型网站,开源,体积小速度快成本低等特点

3 mariaDB 数据库诞生  mysql被收购  

4 SQL server 数据库 微软开发的大型数据库 和sybase合作开发

5 access和offcices 绑定的一个入门级小型的桌面数据库,性能和安全性一般,可提供个人管理或者小型网站之用


四 数据库的备份


【1】sql语句如何优化:

1 抓慢sql  show for testlist 执行一下查看慢的  给慢sql添加索引  2 在配置文件里添加参数 添加索引  增加慢sql的查询日志收集  脚本切割  分析定时任务发给db 


【2】 网站打开慢 给出排查方法,如何使因为导致数据库慢导致,如何排查解决?分析并举例

思路:

负载均衡到web服务器                      web到存储                  php到数据库           web到数据库 

访问静态网页一下                         动态网页慢php问题                                uptime可定负载均衡高

慢 则是负载高 cpu高  查看io              cure慢的话是存储问题                             创建索引  创建sql慢查询日志

   



测试环境 生产环境  开发环境

五  数据库备份:


  mysqldump -u 用户名 -p 数据库名  表名 >备份的文件名

mysqldump -uroot -poldboy123  -S/data/3306/mysql.sock -B oldboy oldboy-gbk >/opt/bak_$(data +%F).sql

 

  -B 参数的作用  不加-B 第一个是库 后面都是表  加上-B 第一个是库 后面的都是表

--compact 减少输出 但不用于生产


六 mysqldump的工作原理

利用mysqldump命令把数据备份的过程,就是直接拿mysql数据库里面的数据以逻辑的sql语句的形式直接输出或者生成备份的过程

mysql分库脚本


mysql -uroot -poldboy123 -e "show databases;"|egrep -v "_schema|atabase"|sed -r 's#^(.*)#mysqldump  -uroot -poldboy123 --events -B \1 |gzip >/opt/\1.sql.gz#g'|bash

备份单个表:

mysqldump -uroot -poldboy23 -S /data/3306/mysql.scok oldboy test --compact



分表备份:

mysqldump -u 用户名 -p 数据库名 表名 > 备份的文件名

mysqldump -uroot -poldboy student >/opt/table1.sql


备份多个表:


mysqldump -u 用户名 -p 数据库名 表名1 表名2 > 备份的文件名

分表备份缺点:文件多 很碎


备份表结构:-d 

利用mysqldump -d参数只备份表的结构 备份oldboy库的所有表的结构


备份表数据 -t  备数据库里面的数据







七 刷新binlog参数  参数-F

mysqldump用于定时对某一时刻的数据全备,例如00 点进行备份

增量备份:当有数据写入到数据库时,还会同时把更新出的sql语句写入到对应的文件。这个文件叫做binlog文件

例子:

10点丢失数据需要恢复数据:

1  00点时刻备份的.sql数据还原到数据库,这时数据库恢复到了00点

2  00-10点数据,就需要binlog里恢复

binlog文件生效则需要log-bin

-F 作用:binlog日志 生成新的而文件  将来新的增量恢复从这个文件开始

--master-data 在备份语句里添加CHANGES MASTER 语句及binlog文件

及位置点信息

当--master-data=1时 可执行的change master语句  一般等于1时做的是从库 

当--master-data=2时 注释的change master语句     一般用于做单纯的增量恢复

--master-data 除了增量恢复确定临界点外 做主从复制时作用更大


八 mysqldump的关键参数说明:

mysqldump的参数:

-B 备份多格库

-t 只备份数据

-d 只备份表结构

-T 分离库表和数据成不同的文件,数据是文本,非sql语句

-A 备份所有库

-L --lock-all-tables 锁表

备份时一定要锁表,在某一时刻数据库不能更新

当--master-data=1时 可执行的change master语句  一般等于1时做的是从库 

当--master-data=2时 注释的change master语句     一般用于做单纯的增量恢复

--master-data 除了增量恢复确定临界点外 做主从复制时作用更大

--single-transaction  适合innodb属无数据库备份

InnoDB 表在备份时  通常启用选项  --single-transaction来保证备份的一致性,实际上它的工作原理是设定本次会话的隔离级别:repeataable read 以确保本次会话dump时 。不会看到其他会话已经提交了数据

-q --quick   ACID会话隔离数据  -enevts事务性是innoDB独有的特性  事物有隔离性 


未完待续。。。。。。。