matsudaira 发布的文章

nginx负载均衡

ngx_http_upstream_module七层负载均衡

相关参数:

upstream:定义后端服务器组,会引入一个新的上下文
server:在upstream上下文中server成员,以及相关的参数
least_conn;:最少连接调度算法,当server拥有不同的权重时其为wlc
ip_hash;:源地址hash调度方法
hash :基于指定的key的hash表来实现对请求的调度,此处的key可以直接文本、变量或二者的组
合
keepalive connections;:为每个worker进程保留的空闲的长连接数量;
weight=number # 权重,默认为1;
max_fails=number # 失败尝试最大次数;超出此处指定的次数时,server将被标记为不可用;
fail_timeout=time # 设置将服务器标记为不可用状态的超时时长;
max_conns # 当前的服务器的最大并发连接数;
backup # 将服务器标记为“备用”,即所有服务器均不可用时此服务器才启用;
down # 标记为“不可用

负载均衡算法

轮询(默认): 每个请求按时间顺序逐一分配到不同的后端服务,如果后端某台服务器死机,自动剔
除故障系统,使 用户访问不受影响。
weight(轮询权值):weight的值越大分配到的访问概率越高,主要用于后端每台服务器性能不均
衡的情况下。或 者仅仅为在主从的情况下设置不同的权值,达到合理有效的地利用主机资源
ip_hash:每个请求按访问IP的哈希结果分配,使来自同一个IP的访客固定访问一台后端服务器,
并且可以有效解决 动态网页存在的session共享问题。
fair:比 weight、ip_hash更加智能的负载均衡算法,fair算法可以根据页面大小和加载时间长短智
能地进行负载均 衡,也就是根据后端服务器的响应时间 来分配请求,响应时间短的优先分配。
Nginx本身不支持fair,如果需要这 种调度算法,则必须安装upstream_fair模块。
url_hash:按访问的URL的哈希结果来分配请求,使每个URL定向到一台后端服务器,可以进一步
提高后端缓存服 务器的效率。Nginx本身不支持url_hash,如果需要这种调度算法,则必须安装
Nginx的hash软件包。

七层负载均衡

七层负载均衡是基于URL等应用层信息的负载均衡,也被成为“内容交换”,主要是通过报文中真正有意义的应用层内容,再加上负载均衡设备设置的服务器选择方式,决定最终选择的服务器

以TCP为例,负载均衡器需要先跟客户端建立连接,才能接收到客户端应用层内容的报文,然后根据报文中的特定字段,再加上负载均衡设置的服务器选择方式,最终选定内部服务器。负载均衡器和客户端与服务器会分别建立TCP连接,在这种情况下更像一个代理服务器

七层负载对设备的要求更高,但是对内容的处理更为灵活,例如访问一个网站的游客量,可以把图片类的请求转发到特定的图片服务器并使用缓存技术,对文字类的请求可以转发到特定的文字服务器并使用压缩技术,极大提高网络的灵活性。而且七层负载的特性也决定了面对SYN Flood攻击时,会在负载均衡器这一步就被拦下,不会影响到后台服务器的正常运行

server1作为反向代理服务器,server3,4,5作为apache web站点

先在后面三台上面配置完apache,然后再server1进行反向代理服务器配置七层代理

[root@server1 ~]# vim /etc/nginx/conf.d/proxy.conf

upstream webs{
server 192.168.226.149 weight=2; #weight为权重,可加可不加
server 192.168.226.153 weight=2;
server 192.168.226.152 weight=6;


}
server {
listen *:8787;
server_name 192.168.226.148:8787;
location{
proxy_pass http://webs;
}
}

测试访问

[root@server1 ~]# for i in {1..20};do curl 192.168.226.148:8787; done
server3
server2
server3
server2
server3
server3
server4
server3
server3
server2
server3
server4
server4
server3
server3
server2
server3
server3
server3
server4

nginx-mod-stream四层负载均衡

四层负载均衡基于IP+端口,主要通过报文中的目标地址和端口,再加上负载均衡设备设置的服务器选择方式,最终决定内部的服务器,负载均衡器仅作转发功能。

以TCP为例,当负载均衡设备接收到第一个来自客户端的SYN请求时,会通过上述方式选择一个最佳服务器,然后修改报文中目标IP之后直接转发给改服务器,TCP的连接也是客户端跟服务器直接连接,负载均衡设备只起一个类似路由转发的功能

avatar

实验

yum默认没装这个模块,yum install -y nginx-mod-stream

vim /etc/nginx/nginx.conf

events {
    worker_connections 1024;
}
stream{
        upstream sshers{
                server 192.168.226.149:22;
                server 192.168.226.152:22;
                server 192.168.226.153:22;
                least_conn;#请求将被传递给当前拥有最少活跃连接的server,同时考虑权重weight的因素
}
        server{
                listen *:7878;
                proxy_pass sshers;
}
}

这里用ssh 7878端口远程登陆来测试

MHA

原理

avatar
MHA是一套mysql高可用方案,在MySQL故障切换过程中,MHA能做到在0~30秒之内自动完成数据库的故障切换操作,并且 在进行故障切换的过程中,MHA能在最大程度上保证数据的一致性,以达到真正意义上的高可用。 MHA里有 两个角色一个是MHA Node(数据节点)另一个是MHA Manager(管理节点)。 MHA Manager可以单独部署 在一台独立的机器上管理多个master-slave集群,也可以部署在一台slave节点上。MHA Node运行在每台 MySQL服务器上,MHA Manager会定时探测集群中的master节点,当master出现故障时,它可以自动将最新 数据的slave提升为新的master,然后将所有其他的slave重新指向新的master。整个故障转移过程对应用程序完 全透明。

工作流程

  • 把宕机的master二进制日志保存下来
  • 找到binlog位置点最新的slave
  • 用这个slave的relay log来修复其他的slave
  • 把宕机的master上保存下的二进制日志恢复到其他最新位置点的slave上
  • 把含有最新位置点的slave提拔为新的master
  • 把其他slave指向新的master

MHA软件的包括manager和node两个工具包

manager

Manager工具包主要包括以下几个工具:
masterha_check_ssh              检查MHA的SSH配置状况
masterha_check_repl             检查MySQL复制状况
masterha_manger                 启动MHA
masterha_check_status           检测当前MHA运行状态
masterha_master_monitor       检测master是否宕机
masterha_master_switch          控制故障转移(自动或者手动)
masterha_conf_host               添加或删除配置的server信息

node

save_binary_logs        保存和复制master的二进制日志
apply_diff_relay_logs   识别差异的中继日志事件并将其差异的事件应用于其他的slave
purge_relay_logs        清除中继日志(不会阻塞SQL线程)

配置

现准备四台机器,一台server做manager,21为主,22,23为从,其中22为候选,在21宕机的时候成为新的master

mha需要通过ssh来交互,所以要先创建ssh免密登录环境

manager和三台机子,三台机子之间互相

ssh-keygen
ssh-copy-id 192.168.226.149
ssh-copy-id 192.168.226.152
ssh-copy-id 192.168.226.153

在21,22,23上面先搭建一主两从

vim /etc/yum.repos.d/mariadb.repo
[mariadb]
name=MariaDB
baseurl=http://mirrors.ustc.edu.cn/mariadb/yum/10.2/centos7-amd64/
gpgkey=http://mirrors.ustc.edu.cn/mariadb/yum/RPM-GPG-KEY-MariaDB
gpgcheck=1

yum install -y mariadb-server.x86_64

yum -y install mha4mysql-node-0.56-0.el6.noarch.rpm

systemctl start mysql
mysql_secure_installation #密码此处设置为mariadb123456

mysql -uroot -pmariadb123456
#在21,22上安装插件,开启半同步复制
install plugin rpl_semi_sync_master soname 'semisync_master.so';
install plugin rpl_semi_sync_slave soname 'semisync_slave.so';
set global rpl_semi_sync_master_enabled = 1;
set global rpl_semi_sync_slave_enabled = 1;
grant replication slave on *.* to 'repluser'@'192.168.226.%' identified by 'repluser123456';
flush privileges;

在23上只开启同步
install plugin rpl_semi_sync_slave soname 'semisync_slave.so';
set global rpl_semi_sync_slave_enabled = 1;

修改三台机器配置

# MariaDB-21配置文件
cat /etc/my.cnf.d/server.cnf
[mysqld]
skip_name_resolve = ON
innodb_file_per_table = ON
server-id = 21
log-bin = master-bin
relay_log_purge = 0
rpl_semi_sync_master_enabled = 1
rpl_semi_sync_master_timeout = 3000
rpl_semi_sync_slave_enabled = 1
 
# MariaDB-22配置文件
cat /etc/my.cnf.d/server.cnf
[mysqld]
skip_name_resolve = ON
innodb_file_per_table = ON
server-id = 22
log-bin = master-bin
relay_log_purge = 0
rpl_semi_sync_master_enabled = 1
rpl_semi_sync_master_timeout = 3000
rpl_semi_sync_slave_enabled = 1
 
# MariaDB-23配置文件
cat /etc/my.cnf.d/server.cnf
[mysqld]
skip_name_resolve = ON
innodb_file_per_table = ON
server-id = 23
log-bin = master-bin
relay_log_purge = 0
rpl_semi_sync_slave_enabled = 1

重启服务,加载配置文件,配置主从同步

[root@21 ~]# systemctl restart mariadb.service
[root@21 ~]# mysql -uroot -pmariadb123456
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 9
Server version: 10.2.43-MariaDB-log MariaDB Server

Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> show master status\G;
*************************** 1. row ***************************
            File: master-bin.000001
        Position: 329
    Binlog_Do_DB:
Binlog_Ignore_DB:
1 row in set (0.00 sec)

ERROR: No query specified

#在22,23上配置主从同步
MariaDB [(none)]> show master status\G;
*************************** 1. row ***************************
            File: master-bin.000001
        Position: 329
    Binlog_Do_DB:
Binlog_Ignore_DB:
1 row in set (0.00 sec)


change master to master_host='192.168.226.149',master_user='repluser',master_password='repluser123456',master_log_file='master-bin.000001',master_log_pos=329;


MariaDB [(none)]> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.226.149
                  Master_User: repluser
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: master-bin.000001
          Read_Master_Log_Pos: 329
               Relay_Log_File: server5-relay-bin.000002
                Relay_Log_Pos: 556
        Relay_Master_Log_File: master-bin.000001
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes

在21上授权manager用户管理mha各节点,两台slave会同步这个用户

MariaDB [(none)]> grant all on *.* to 'mhauser'@'192.168.226.%' identified by 'mhauser123456';
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> flush privileges;
Query OK, 0 rows affected (0.00 sec)

配置mha-manager

yum install -y epel-release.noarch
yum -y install mha4mysql-manager-0.56-0.el6.noarch.rpm \
mha4mysql-node-0.56-0.el6.noarch.rpm

mkdir /etc/mha
cat /etc/mha/app1.conf
[server default]
user=mhauser
password=mhauser123456
ssh_user=root
master_binlog_dir=/var/lib/mysql
remote_workdir=/data/log/masterha
manager_workdir=/usr/local/mha
manager_log=/usr/local/mha/manager.log
 
ping_interval=1
repl_user=repluser
repl_password=repluser123456
 
[server1]
hostname=192.168.226.149
candidate_master=1
 
[server2]
hostname=192.168.226.152
candidate_master=1
 
[server3]
hostname=192.168.226.153
no_master=1
 
# ssh检测,授权检测,启动MHA
chmod +x /etc/mha/app1.conf
mkdir /usr/local/mha
 
masterha_check_ssh --conf=/etc/mha/app1.conf
masterha_check_repl --conf=/etc/mha/app1.conf
masterha_manager --conf=/etc/mha/app1.conf  2>&1 &
masterha_check_status --conf=/etc/mha/app1.conf

app1 (pid:17140) is running(0:PING_OK), master:192.168.226.149

验证

21创库
MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
+--------------------+
3 rows in set (0.00 sec)

MariaDB [(none)]> create database db1;
Query OK, 1 row affected (0.00 sec)

22同步
MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| db1                |
| information_schema |
| mysql              |
| performance_schema |
+--------------------+
4 rows in set (0.00 sec)

22创库

MariaDB [(none)]> create database db2;
Query OK, 1 row affected (3.01 sec)

23不同步
MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| db1                |
| information_schema |
| mysql              |
| performance_schema |
+--------------------+
4 rows in set (0.00 sec)


21关机
[root@21 ~]# mysqladmin -uroot -pmariadb123456  "shutdown"

22建库
MariaDB [(none)]> create database db3;
Query OK, 1 row affected (0.00 sec)

23同步,可见22已变成新的主
MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| db1                |
| db3                |
| information_schema |
| mysql              |
| performance_schema |
+--------------------+
5 rows in set (0.00 sec)

切换复原

先让21指向22

MariaDB [(none)]> change master to master_host='192.168.226.152',master_user='repluser',master_password='repluser123456',master_log_file='master-bin.000001',master_log_pos=583;
Query OK, 0 rows affected (0.01 sec)

MariaDB [(none)]> start slave;

再在mha拉起
masterha_master_switch --conf=/etc/mha/app1.conf --master_state=alive --new_master_host=10.0.0.21 --new_master_port=3306 --orig_master_is_new_slave

再在mha手动切换

MySQL调优

  1. 采用合适的存储引擎
  2. 高可用框架
  3. 创建阶段选择更合适的变量种类,如使用日期时间类型而不是字符串来保存时间,用枚举来代替字符串
  4. 适当把一些大而不常访问的字段拆分到别的表里面
  5. 开启缓存
  6. 建立合适的索引
  7. 优化查询语句,如count(*)-->count(某一列),关联查询访问建有索引的列
  8. 避免冗余和重复的索引,比如有一个索引(A,B),再创建索引(A)就是冗余索引
  9. 建立合适的视图,保障数据安全性,提高查询效率

基础概念

基本操作见我的此篇博客Mysql

关系型数据课和非关系型数据库

关系型数据库:以多张二维表及他们之间的关系所组成

优点:

  • 易于维护,结构一致
  • sql语言通用,使用方便
  • 支持单表和多表之间的复杂查询

缺点:

  • 读写性能较差
  • 固定表结构,灵活度稍欠
  • 高并发读写需求对硬盘i/o造成很大罚单

非关系型数据库:以键值对(或者文档、图形等)来存储数据

优点:

  • 基于键值对,数据间没有耦合性,可扩展性好
  • 不需要sql层的解析,性能高

mysql常用参数:

-u:用户

-host:主机

-p:密码

--port:端口

-D:登录指定的数据库

工作流程

一个mysql进程实例=mysql后台守护进程+master 线程+worker 线程+预分配的内存.一台机子上可以启动多个mysql进程

连接方式

TCP/IP(远程)
mysql -uroot -pxxx -h 192.168.226.148 -P3306

socket
mysql -u -p -S /emp/mysql.sock

avatar
avatar

上层服务通过连接池组件来连接mysql。

  • 提供连接协议:TCP/IP 、SOCKET
  • 提供验证:用户、密码,IP,SOCKET
  • 提供专用连接线程:接收用户SQL,返回结果

第二层包含mysql大部分核心服务,如查询分析优化缓存内置函数等,所有跨存储引擎功能都在这一层实现,如存储过程触发器视图等。

  • 接收上层传送的SQL语句
  • 语法验证模块:验证语句语法,是否满足SQL_MODE
  • 语义检查:判断SQL语句的类型

    • DDL :数据定义语言
    • DCL :数据控制语言
    • DML :数据操作语言
    • DQL: 数据查询语言
  • 权限检查:用户对库表有没有权限
  • 解析器:对语句执行前,进行预处理,生成解析树(执行计划),说白了就是生成多种执行方案
  • 优化器:根据解析器得出的多种执行计划,进行判断,选择最优的执行计划。代价模型:资源(CPU IO MEM)的耗损评估性能好坏
  • 执行器:根据最优执行计划,执行SQL语句,产生执行结果
  • 提供查询缓存(默认是没开启的),会使用redis tair替代查询缓存功能
  • 提供日志记录(日志管理章节):binlog,默认是没开启的。

第三层是存储引擎,存储引擎负责mysql数据的存储和提取,服务器通过API和存储引擎进行通信。这些接口屏蔽了不同存储引擎之间的差异,使得这些差异对上层的查询过程透明化,但存储引擎一般不会去解析sql,不同存储引擎之间不会互相通信,只是简单的响应上层服务器的请求。mysql采用插件式结构的存储引擎,可以根据场景来选择不同的引擎,引擎对于上层应用程序和底层的文件系统都是透明的。

  • 负责根据SQL层执行的结果,从磁盘上拿数据
  • 将16进制的磁盘数据,交由SQL结构化化成表
  • 连接层的专用线程返回给用户

第四层是文件系统,所有数据和日志最终以文件的形式存储在硬盘上

数据库:物理操作系统文件或者其他形式文件类型的集合

数据库实例:由数据库后台进程线程以及一个共享内存区组成,数据库实例才是真正用来操作数据库文件的,也即是说,数据库是由一个个文件组成的,而当要对这些文件执行select等操作的时候,就得要通过数据库实例来完成对数据库的操作

mysql区别于别的数据库最大的特点就是插件式的表存储引擎,这个插件式存储引擎架构提供了一系列标准的管理和服务,这些标准和存储引擎本身无关,是数据库系统本身所需,如sql分析器优化器等,而存储引擎是底层物理结构的实现。存储引擎是基于表的,而不是数据库

引擎

存储引擎的功能

  • 数据读写
  • 数据安全
  • 提高性能
  • 热备份
  • 自动故障恢复
  • 高可用方面支持

https://blog.csdn.net/qq_35642036/article/details/82820178

InnoDB与MyISAM的区别

  • innodb支持事务,对于每一条sql语言都默认封装成事务,自动提交,影响速度,所以最好把多条sql语言组成一个事务;;;;myisam不支持事务
  • innodb支持外键,myisam不支持。对于包含外键的innodb表转为myisam会失败
  • innodb是聚集索引,使用B+树作为索引结构,数据文件和(主键)索引绑在一起,所以必须要又主键,通过主键所以效率很高。但是辅助索引需要两次查询,先查询到主键,再通过主键查询到数据,因此主键不应该太大,不然其他索引也会很大
  • myisam是非聚集索引,也使用B+树作为索引结构,索引和数据分离,索引保存的是数据文件的指针,主键索引和辅助索引相互独立
  • innodb不保存表的行数,在执行select count(*) from table时候需要扫描全表,因为innodb的事务特性,在同一时刻表的行数对于不同的事务是不一样的,innodb会去尝试遍历一个尽可能小的索引。myisam用一个变量保存了整个表的行数,执行时只需要读出该变量
  • innodb支持表、行级锁(默认),innodb的锁是是现在索引上的,而不是锁在物理行立即上,如果访问没有命中索引,无法使用行锁,而是退化成表锁。myisam支持表级锁
  • myisam表格可以被压缩后进行查询操作
  • innodb必须要有唯一索引,如果用户没有指定会自己找一个隐藏列来充当默认主键,myisam可以没有
  • Innodb存储文件有frm、ibd,而Myisam是frm、MYD、MYI

      Innodb:frm是表定义文件,ibd是数据文件
    
      Myisam:frm是表定义文件,myd是数据文件,myi是索引文件
    

InnoDB为什么推荐使用自增ID作为主键?

答:自增ID可以保证每次插入时B+索引是从右边扩展的,可以避免B+树和频繁合并和分裂(对比使用UUID)。如果使用字符串主键和随机主键,会使得数据随机插入,效率比较差。


innodb引擎的4大特性

   插入缓冲(insert buffer),二次写(double write),自适应哈希索引(ahi),预读(read ahead)
MariaDB [(none)]> show engines\G;
*************************** 1. row ***************************
      Engine: InnoDB
     Support: DEFAULT
     Comment: Percona-XtraDB, Supports transactions, row-level locking, and foreign keys
Transactions: YES
          XA: YES
  Savepoints: YES
*************************** 2. row ***************************
      Engine: MRG_MYISAM
     Support: YES
     Comment: Collection of identical MyISAM tables
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 3. row ***************************
      Engine: MyISAM
     Support: YES
     Comment: Non-transactional engine with good performance and small data footprint
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 4. row ***************************
      Engine: BLACKHOLE
     Support: YES
     Comment: /dev/null storage engine (anything you write to it disappears)
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 5. row ***************************
      Engine: PERFORMANCE_SCHEMA
     Support: YES
     Comment: Performance Schema
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 6. row ***************************
      Engine: CSV
     Support: YES
     Comment: Stores tables as CSV files
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 7. row ***************************
      Engine: ARCHIVE
     Support: YES
     Comment: gzip-compresses tables for a low storage footprint
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 8. row ***************************
      Engine: MEMORY
     Support: YES
     Comment: Hash based, stored in memory, useful for temporary tables
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 9. row ***************************
      Engine: FEDERATED
     Support: YES
     Comment: Allows to access tables on other MariaDB servers, supports transactions and more
Transactions: YES
          XA: NO
  Savepoints: YES
*************************** 10. row ***************************
      Engine: Aria
     Support: YES
     Comment: Crash-safe tables with MyISAM heritage
Transactions: NO
          XA: NO
  Savepoints: NO
10 rows in set (0.00 sec)

索引

https://blog.csdn.net/guanyasu/article/details/53443142

索引的作用是加速查找,主键\unique\联合唯一\联合主键\index\联合index都是索引

当表中已有大量数据时,建立索引会占用大量磁盘空间且速度很慢,但是等建完后查询会变快

常用索引

普通索引INDEX:加速查找 
唯一索引: 
-主键索引PRIMARY KEY:加速查找+约束(不为空、不能重复) 
-唯一索引UNIQUE:加速查找+约束(不能重复) 
联合索引: 
-PRIMARY KEY(id,name):联合主键索引 
-UNIQUE(id,name):联合唯一索引 
-INDEX(id,name):联合普通索引

创建方式

CREATE INDEX indexName ON table_name (column_name)创建

ALTER table tableName ADD INDEX indexName(columnName)修改

CREATE TABLE mytable(  
 
ID INT NOT NULL,   
 
username VARCHAR(16) NOT NULL,  
 
INDEX [indexName] (username(length))  
 
);  创建表时

DROP INDEX [indexName] ON mytable; 删除

CREATE UNIQUE INDEX indexName ON mytable(username(length)) 唯一索引

索引分类:B+树索引,hash索引

对比

MariaDB [db2]> select count(*) from s1;
+----------+
| count(*) |
+----------+
|  2999999 |
+----------+
1 row in set (2.02 sec)

MariaDB [db2]> create index a on s1(id);
Query OK, 0 rows affected (11.52 sec)
Records: 0  Duplicates: 0  Warnings: 0

MariaDB [db2]> select count(*) from s1;
+----------+
| count(*) |
+----------+
|  2999999 |
+----------+
1 row in set (1.23 sec)

b+树

avatar
b+树数据全存在叶子节点,非叶子节点只放指向这些元素记录的指针(索引),父节点跟子节点重复的元素是这个子节点当中最大的元素,叶子节点的元素按从小到大的顺序依次排列,且互相之间有指针连在一起
b+树漫画,小仓鼠还挺可爱的

sql模型

ANSI QUOTES::宽松模式,对插入数据进行校验,如果不符合定义类型或长度,对数据类型调
整或截断保存,报warning警告。 双引号相当于反引号,只可以引用表名等字段名称,字符串只可
以使用单引号引用;
IGNORE_SPACE:在内建函数中忽略多余的空白字符;
STRICT_ALL_TABLES:如果没有设置这个值,非法的数据都允许存入,但是会有一个警告提示。如
果设置了,所有非法的数据都不允许填入,并且返回一个错误;
STRICT_TRANS_TABLES:向一个支持事务的表中插入非法数据的时候不允许,并且返回一个错
误;
TRADITIONAL:严格模式,当向mysql数据库插入数据时,进行数据的严格校验,保证错误数据不
能插入,报error错误。用于事物时,会进行事物的回滚


SELECT @@[GLOBAL | SESSION].sql_mode; 显示值 
set GLOBAL | SESSION sql_mode=[值]; 修改值

事务

innodb引擎支持事务,事务保证一批sql语句要么全部执行,要么全部不执行(回滚),把数据库从一种一致性转换为另外一种一致性,来保证数据库的完整性.事务一般针对update,delete,insert

ACID

事务必须满足ACID特性:

  • A:原子性,事务必须是执行任务的最小单位,事务要么成功要么撤回
  • C:一致性,把数据库从一种一致性转换为另外一种一致性
  • I:隔离性:每个事务之间是隔离的
  • D:持久性:事务一旦执行,数据的修改是永久的

隔离等级

read uncommitted(未提交读):允许读取尚未提交的数据变更,可能会导致脏读、幻读或不可重复读
read conmitted (提交读):允许读取并发事务已经提交的数据,能够解决脏读
repeatable read (可重读):对同一字段的多次读取结果都是一致的,除非数据是被本身事务自己所修改,能够解决不可重复读、脏读现象
serializable(可串行化读):事务需要按串行化解决(MVCC)

格式

一个事务只能由commit(提交)或者rollback(回滚)结束,事务在执行过程中不是真的对数据进行了修改,在提交之前都是暂存于内存当中.当一个事务开启时,如果再开启另外一个事务,那么那个新开的事务会被卡住

begin;#开始
操作

commit/rollback

日志

错误日志log_error

存放数据库启动\关闭\日常中的状态信息错误警告等

MariaDB [db2]> show variables like "%log_error%";
+---------------+------------------------------+
| Variable_name | Value                        |
+---------------+------------------------------+
| log_error     | /var/log/mariadb/mariadb.log |
+---------------+------------------------------+
1 row in set (0.01 sec)

二进制日志binlog

备份、主从都依赖二进制日志,binlog位于sql层,记录变更数据的sql语句,不记录查询语句

二进制日志默认关闭,需要去配置文件手动开启

vim /etc/my.cnf 
server_id=6 # 设置id 
log_bin=mysql-bin # 开启并指定二进制日志目录及前缀名,记得关selinux 
binlog_format=row # binlog 的日志记录格式

日志记录格式

SBR:可读性较高,日志量少,但是不够严谨
ROW:可读性很低,日志量大,足够严谨

event事件:二进制日志的最小记录单元

对于DDL(数据库定义语言,create等),DCL(数据库控制语言,grant等),一个语句就是一个event,对于DML(数据操纵,insert等),只记录已提交的事务

查看日志开启情况

MariaDB [(none)]> show variables like '%log_bin%';
+---------------------------------+-------+
| Variable_name                   | Value |
+---------------------------------+-------+
| log_bin                         | ON    |
| log_bin_trust_function_creators | OFF   |
| sql_log_bin                     | ON    |
+---------------------------------+-------+

查看二进制文件数量

MariaDB [(none)]> show binary logs;
+------------------+-----------+
| Log_name         | File_size |
+------------------+-----------+
| mysql-bin.000001 |       245 |
+------------------+-----------+
1 row in set (0.00 sec)

MariaDB [(none)]> flush logs;
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> show binary logs;
+------------------+-----------+
| Log_name         | File_size |
+------------------+-----------+
| mysql-bin.000001 |       288 |
| mysql-bin.000002 |       245 |
+------------------+-----------+
2 rows in set (0.00 sec)

查看正在使用的二进制文件

MariaDB [(none)]> show master status;
+------------------+----------+--------------+------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000002 |      245 |              |                  |
+------------------+----------+--------------+------------------+
1 row in set (0.01 sec)

查看日志内容

MariaDB [(none)]> show binlog events in 'mysql-bin.000002';
+------------------+-----+-------------+-----------+-------------+-------------------------------------------+
| Log_name         | Pos | Event_type  | Server_id | End_log_pos | Info                                      |
+------------------+-----+-------------+-----------+-------------+-------------------------------------------+
| mysql-bin.000002 |   4 | Format_desc |         6 |         245 | Server ver: 5.5.68-MariaDB, Binlog ver: 4 |
+------------------+-----+-------------+-----------+-------------+-------------------------------------------+
1 row in set (0.00 sec)

详细查看日志内容

[root@server1 ~]# mysqlbinlog --base64-output=decode-rows -vvv /data/binlog/mysql-bin.000002

基于position进行日志截取

mysqlbinlog --start-position=219 --stop-position=1347 /data/binlog/mysql-bin.000003 >/tmp/bin.sql

使用二进制日志进行数据恢复

创建一个库表,往里面放点数据
MariaDB [db1]> show binlog events in 'mysql-bin.000002';
+------------------+-----+-------------+-----------+-------------+-------------------------------------------+
| Log_name         | Pos | Event_type  | Server_id | End_log_pos | Info                                      |
+------------------+-----+-------------+-----------+-------------+-------------------------------------------+
| mysql-bin.000002 |   4 | Format_desc |         6 |         245 | Server ver: 5.5.68-MariaDB, Binlog ver: 4 |
| mysql-bin.000002 | 245 | Query       |         6 |         326 | create database db1                       |
| mysql-bin.000002 | 326 | Query       |         6 |         412 | use `db1`; create table tb1(id int)       |
| mysql-bin.000002 | 412 | Query       |         6 |         479 | BEGIN                                     |
| mysql-bin.000002 | 479 | Table_map   |         6 |         520 | table_id: 33 (db1.tb1)                    |
| mysql-bin.000002 | 520 | Write_rows  |         6 |         564 | table_id: 33 flags: STMT_END_F            |
| mysql-bin.000002 | 564 | Xid         |         6 |         591 | COMMIT /* xid=18 */                       |
+------------------+-----+-------------+-----------+-------------+-------------------------------------------+
7 rows in set (0.00 sec)

MariaDB [db1]> select * from tb1;
+------+
| id   |
+------+
|    1 |
|    2 |
|    3 |
+------+
MariaDB [db1]> drop database db1;# 模拟故障
Query OK, 1 row affected (0.01 sec)

MariaDB [(none)]> show master status; #查看正在使用的二进制日志
+------------------+----------+--------------+------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000002 |      670 |              |                  |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)

MariaDB [(none)]> show binlog events in 'mysql-bin.000002';
+------------------+-----+-------------+-----------+-------------+-------------------------------------------+
| Log_name         | Pos | Event_type  | Server_id | End_log_pos | Info                                      |
+------------------+-----+-------------+-----------+-------------+-------------------------------------------+
| mysql-bin.000002 |   4 | Format_desc |         6 |         245 | Server ver: 5.5.68-MariaDB, Binlog ver: 4 |
| mysql-bin.000002 | 245 | Query       |         6 |         326 | create database db1                       |
| mysql-bin.000002 | 326 | Query       |         6 |         412 | use `db1`; create table tb1(id int)       |
| mysql-bin.000002 | 412 | Query       |         6 |         479 | BEGIN                                     |
| mysql-bin.000002 | 479 | Table_map   |         6 |         520 | table_id: 33 (db1.tb1)                    |
| mysql-bin.000002 | 520 | Write_rows  |         6 |         564 | table_id: 33 flags: STMT_END_F            |
| mysql-bin.000002 | 564 | Xid         |         6 |         591 | COMMIT /* xid=18 */                       |
| mysql-bin.000002 | 591 | Query       |         6 |         670 | drop database db1                         |
+------------------+-----+-------------+-----------+-------------+-------------------------------------------+
8 rows in set (0.00 sec)

[root@server1 ~]# mysqlbinlog --start-position=245 --stop-position=591 /var/lib/mysql/mysql-bin.000002  > /tmp/bin2.sql
[root@server1 ~]# ll /tmp/bin2.sql
-rw-r--r--. 1 root root 2265 3月  12 11:03 /tmp/bin2.sql

MariaDB [(none)]> set sql_log_bin=0;#暂时关闭记录
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> source /tmp/bin2.sql;
Query OK, 0 rows affected (0.00 sec)
MariaDB [db1]> set sql_log_bin = 1;
Query OK, 0 rows affected (0.00 sec)MariaDB [db1]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| db1                |
| mysql              |
| performance_schema |
+--------------------+

慢日志slow_log

记录比较慢的sql语句,默认关闭,需要通过修改配置文件来开启

[root@server1 ~]# vim /etc/my.cnf

slow_query_log=1
slow_query_log_file = /var/log/mariadb/slow.log
long_query_time=0.1
log_queries_not_using_indexes

[root@server1 ~]# systemctl restart mariadb.service
MariaDB [(none)]> show variables like "%slow%";
+---------------------+--------------------------------------------------------------------------------------------------------------+
| Variable_name       | Value                                                                                                        |
+---------------------+--------------------------------------------------------------------------------------------------------------+
| log_slow_filter     | admin,filesort,filesort_on_disk,full_join,full_scan,query_cache,query_cache_miss,tmp_table,tmp_table_on_disk |
| log_slow_queries    | ON                                                                                                           |
| log_slow_rate_limit | 1                                                                                                            |
| log_slow_verbosity  |                                                                                                              |
| slow_launch_time    | 2                                                                                                            |
| slow_query_log      | ON                                                                                                           |
| slow_query_log_file | /var/log/mariadb/slow.log                                                                                    |
+---------------------+--------------------------------------------------------------------------------------------------------------+

主从复制

avatar
主服务器上的更新操作会被写入二进制文件中,从服务器用io线程去读主的二进制日志,然后写道relaylog里,sql线程会去执行relaylog。而对从服务器操作不会对主造成影响

主从的三种模式:https://zhuanlan.zhihu.com/p/307288925

https://zhuanlan.zhihu.com/p/521863168

实验

两台机器,一主一从

vim /etc/my.conf

server_id=1
log_bin=mysql-bin
binlog_format=row

重启服务

#创建主从复制用户
MariaDB [(none)]> grant replication slave on *.* to rep@'192.168.226.%' identified by '123';
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> show master status;
+------------------+----------+--------------+------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000003 |     2971 |              |                  |
+------------------+----------+--------------+------------------+

vim /etc/my.cnf
server_id =2 #不能和主一样

systemctl restart mariadb.service 12345

MariaDB [(none)]> change master to master_host='192.168.226.148',master_port=3306,master_user='rep',master_password='123',master_log_file='mysql-bin.000003',master_log_pos=2971;

MariaDB [(none)]> start slave;
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> show slave status\G;
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.226.148
                  Master_User: rep
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000003
          Read_Master_Log_Pos: 2971
               Relay_Log_File: mariadb-relay-bin.000002
                Relay_Log_Pos: 529
        Relay_Master_Log_File: mysql-bin.000003
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
              Replicate_Do_DB:
          Replicate_Ignore_DB:
           Replicate_Do_Table:
       Replicate_Ignore_Table:
      Replicate_Wild_Do_Table:
  Replicate_Wild_Ignore_Table:
                   Last_Errno: 0
                   Last_Error:
                 Skip_Counter: 0
          Exec_Master_Log_Pos: 2971
              Relay_Log_Space: 825
              Until_Condition: None
               Until_Log_File:
                Until_Log_Pos: 0
           Master_SSL_Allowed: No
           Master_SSL_CA_File:
           Master_SSL_CA_Path:
              Master_SSL_Cert:
            Master_SSL_Cipher:
               Master_SSL_Key:
        Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: No
                Last_IO_Errno: 0
                Last_IO_Error:
               Last_SQL_Errno: 0
               Last_SQL_Error:
  Replicate_Ignore_Server_Ids:
             Master_Server_Id: 1
1 row in set (0.00 sec)

ERROR: No query specified

验证

从
MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
+--------------------+
3 rows in set (0.00 sec)
主
MariaDB [(none)]> create database db1;
Query OK, 1 row affected (0.01 sec)

从
MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| db1                |
| mysql              |
| performance_schema |
+--------------------+
4 rows in set (0.00 sec)

备份

备份分类

按照备份数据位置分类
  热备:硬盘以及内存中的⼀些数据进⾏备份
  冷备:数据库硬盘中的数据
按照备份后⽂件的内容
  逻辑备份:⼀般内容分是sql语句
  裸⽂件备份:拷⻉数据库的物理文件,⼀般内容是⼆进制数据
按照备份数据的内容
  完全备份:对数据库进⾏⼀个完整的备份
  增量备份:在上次的完全备份基础上对更新的数据进⾏备份
  ⽇志备份:⼆进制⽇志备份-->当数据库宕机之后进⾏数据恢复的依据

冷备份的优点:
  备份简单,只要拷⻉相关⽂件即可
  易于跨平台
  恢复简单,只要把⽂件恢复到相关位置即可
  恢复速度快,不需要执⾏任何sql语句,也不需要重新建索引
冷备份缺点
  冷备⽂件通常⽐逻辑⽂件⼤很多
  不是总可以轻易跨平台
逻辑备份:
  mysqldump
  selcet * into outfile 'path/to/file' from tbname;

mysqldump

参数

-B:连接多个库
-A:备份所有库
-d:只备份表结构,没有行数据
-t:之备份行数据,没有表结构
-F:刷新binlog
-l:锁定所有表为只读

备份

mysqldump 库名 > /路径/文件
mysqldump -B 库名 库名2 库名3 > /xxx/xx.sql
mysqldump -B 库 | gzip> 文件  #gzip压缩
mysqldump 数据库名 表名1 表名2 … > 备份文件名 #备份表

恢复

mysql 库名< 文件#库名必须存在,且要与原来库名一致
source 文件 #必须处在那个数据库里

实例

[root@server1 ~]# mysqldump tb1 > tb1.sql
mysqldump: Got error: 1045: "Access denied for user 'root'@'localhost' (using password: NO)" when trying to connect
[root@server1 ~]# mysqldump tb1 -p123456 > tb1.sql
[root@server1 ~]# ll
总用量 12
-rw-------. 1 root root 1241 1月  12 10:11 anaconda-ks.cfg
-rw-r--r--. 1 root root 6335 3月  11 21:22 tb1.sql

MariaDB [(none)]> drop database tb1;
Query OK, 6 rows affected (0.00 sec)

MariaDB [(none)]> create database db1;
Query OK, 1 row affected (0.00 sec)

MariaDB [(none)]> use db1;
Database changed
MariaDB [db1]> source tb1.sql

MariaDB [db1]> show tables;
+---------------+
| Tables_in_db1 |
+---------------+
| employee      |
| t1            |
| t2            |
| t3            |
| t4            |
| t5            |
+---------------+
6 rows in set (0.00 sec)

配置文件

#[client] 客户端配置
#port  = 3306客户端默认连接端口

[mysqld]
datadir=/var/lib/mysql#数据库数据文件存放目录
socket=/var/lib/mysql/mysql.sock#为mysql客户端和服务器之间的本地通讯指定一个套接字文件
#user = mariadb mysql启动用户
#basedir= 安装目录
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
# Settings user and group are ignored when systemd is used.
# If you need to run mysqld under a different user or group,
# customize your systemd unit file for mariadb according to the
# instructions in http://fedoraproject.org/wiki/Systemd

[mysqld_safe]
log-error=/var/log/mariadb/mariadb.log
pid-file=/var/run/mariadb/mariadb.pid

#
# include all files from the config directory
#
!includedir /etc/my.cnf.d

~
~
~
~
"/etc/my.cnf" 19L, 570C 

子配置文件

[root@server1 ~]# ls /etc/my.cnf.d/
client.cnf  mysql-clients.cnf  server.cnf

架构

部署

安装mariadb

yum install mariadb-server.x86_64 -y

[root@server1 ~]# systemctl start mariadb.service
[root@server1 ~]# mysql_secure_installation

NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MariaDB
      SERVERS IN PRODUCTION USE!  PLEASE READ EACH STEP CAREFULLY!

In order to log into MariaDB to secure it, we'll need the current
password for the root user.  If you've just installed MariaDB, and
you haven't set the root password yet, the password will be blank,
so you should just press enter here.

Enter current password for root (enter for none):
OK, successfully used password, moving on...

Setting the root password ensures that nobody can log into the MariaDB
root user without the proper authorisation.

Set root password? [Y/n]
New password:
Re-enter new password:
Password updated successfully!
Reloading privilege tables..
 ... Success!


By default, a MariaDB installation has an anonymous user, allowing anyone
to log into MariaDB without having to have a user account created for
them.  This is intended only for testing, and to make the installation
go a bit smoother.  You should remove them before moving into a
production environment.

Remove anonymous users? [Y/n]
 ... Success!

Normally, root should only be allowed to connect from 'localhost'.  This
ensures that someone cannot guess at the root password from the network.

Disallow root login remotely? [Y/n]
 ... Success!

By default, MariaDB comes with a database named 'test' that anyone can
access.  This is also intended only for testing, and should be removed
before moving into a production environment.

Remove test database and access to it? [Y/n]
 - Dropping test database...
 ... Success!
 - Removing privileges on test database...
 ... Success!

Reloading the privilege tables will ensure that all changes made so far
will take effect immediately.

Reload privilege tables now? [Y/n]
 ... Success!

Cleaning up...

All done!  If you've completed all of the above steps, your MariaDB
installation should now be secure.

Thanks for using MariaDB!

systemctl start mariadb.service

mysql -uroot -p密码

修改管理员密码

正常修改

[root@server1 ~]# mysqladmin -uroot -p password
Enter password:旧密码
New password:
Confirm new password:

忘记密码

[root@server1 ~]# systemctl stop mariadb.service
[root@server1 ~]# mysqld_safe --skip-grant-tables --skip-networking &
[1] 7435

[root@server1 ~]# mysql
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 1
Server version: 5.5.68-MariaDB MariaDB Server

Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> use mysql
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
MariaDB [mysql]> flush privileges;
Query OK, 0 rows affected (0.00 sec)

MariaDB [mysql]> grant all on *.* to root@'localhost' identified by '123456';
Query OK, 0 rows affected (0.01 sec)
# 这一步也可以用于给其他ip账户远程登陆授权
MariaDB [mysql]> flush privileges;
Query OK, 0 rows affected (0.00 sec)

MariaDB [mysql]> exit
Bye
[root@server1 ~]# pkill mysqld
[root@server1 ~]# systemctl restart mariadb
[1]+  完成                  mysqld_safe --skip-grant-tables --skip-networking
[root@server1 ~]# mysql -uroot -p123456

基础操作

库的增查改删

\G可以将结果以竖排的方式显示

# 查
MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
+--------------------+
3 rows in set (0.00 sec)

# 增
MariaDB [(none)]> create database db1 charset utf8;
Query OK, 1 row affected (0.00 sec)

MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| db1                |
| mysql              |
| performance_schema |
+--------------------+
4 rows in set (0.01 sec)
# 查看详细的建库指令
MariaDB [(none)]> show create database db1;
+----------+--------------------------------------------------------------+
| Database | Create Database                                              |
+----------+--------------------------------------------------------------+
| db1      | CREATE DATABASE `db1` /*!40100 DEFAULT CHARACTER SET utf8 */ |
+----------+--------------------------------------------------------------+
1 row in set (0.00 sec)


# 修改编码
MariaDB [(none)]> alter database db1 charset utf8;
Query OK, 1 row affected (0.00 sec)

# 使用这个数据库
use db1

# 删除数据库
drop database db1;

表的操作

切换表
use tablesname;
增:create table name(字段 类型,字段 类型);
查:show tables;
查看结构:describe/desc tablename;
查看创建时的配置:MariaDB [db1]> show create table tb1;

改:
增加字段:
alter table tablename modify 字段 类型;
改名
alter table tablename change 字段1 新字段1 旧/新类型 [完整性约束条件];
改表名
alter table tablename rename newtablename;
删除字段
alter table tablename drop 字段;
修改顺序
alter table tablename add 字段 类型 [完整性] first/(after 字段名)
alter table tablename change 字段 旧名 新名 新类型 [完整性] first/after


删:drop table tablename

指定引擎:create......ENGINE=xxx
alter tablename ai engine = xxx

表的约束规则

NOT NULL:非空

create table tb1 (id int not null);

default:设置默认值

create table tb1 (id int nut null default 111);

UNIQUE:唯一

create table tb1(id int unique);
create table t1(id int unique not null,ip int unique not null);
MariaDB [tb1]> desc t1;
+-------+---------+------+-----+---------+-------+
| Field | Type    | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| id    | int(11) | NO   | PRI | NULL    |       |
| ip    | int(11) | NO   | UNI | NULL    |       |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)
#当一个值同时not null 和unique,先创建的那个会成为主键(innodb)

MariaDB [tb1]> create table t2(id int primary key auto_increment,ip int not null,host char(10) not null,unique(ip,host));#联合unique,host+ip组合不能相同
MariaDB [tb1]> desc  t2;
+-------+----------+------+-----+---------+----------------+
| Field | Type     | Null | Key | Default | Extra          |
+-------+----------+------+-----+---------+----------------+
| id    | int(11)  | NO   | PRI | NULL    | auto_increment |
| ip    | int(11)  | NO   | MUL | NULL    |                |
| host  | char(10) | NO   |     | NULL    |                |
+-------+----------+------+-----+---------+----------------+
3 rows in set (0.00 sec)


auto_increment

create table tb3(id int auto_increament primary key);自增且必须为主键

create table student( id int primary key auto_increment, name varchar(20), sex enum('male','female') default 'male' )auto_increment=3;设置步长

alter atble student auto_increment=3;
set session auth_increment_increment=2 #修改会话级别的步长

set session auto_increment_offset=5;设置自增的初始值,会话级,如果,offset比increment_increment的值大,offset会被忽略
什么时候会导致自增主键不连续:
1.插入值造成唯一键冲突(如插入自增id=10,但表里面已经有10了,插入失败,但是执行器会对自增键+1)
2.事务添加自增+1,之后回滚,数据被清除,自增没有
3.添加的数据,使用delete删除后,仍然按照删除前的位置增长,所以应该用truncate清空表
truncate tablename

primary key:主键,主键不可空不可重复,可以是单一字段,也可以是多字段组合

1. not null + unique 的第一个会被当成主键
create table department1( id int not null unique, #主键 name varchar(20) not null unique, comment varchar(100) );
2.primary key
create table department2( id int primary key, #主键 name varchar(20), comment varchar(100) );
3.单独指定
create table t4(id int, name varchar(20), comment varchar(100), primary key(id));
4.添加约束
alter table department4 modify id int primary key;
5.unique+not null联合主键
MariaDB [tb1]> create table t3(id int not null,ip int not null,phone int not null,unique(id,phone));
Query OK, 0 rows affected (0.01 sec)

MariaDB [tb1]> desc t3;
+-------+---------+------+-----+---------+-------+
| Field | Type    | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| id    | int(11) | NO   | PRI | NULL    |       |
| ip    | int(11) | NO   |     | NULL    |       |
| phone | int(11) | NO   | PRI | NULL    |       |
+-------+---------+------+-----+---------+-------+

foreign key:外键,参照自另外一个表的唯一性索引。两个表必须都是innodb表,外键列必须建了索引,4.1.12版本后在建立外键时会自动创建索引;外键关系的两个列必须是数据类型相似,即可以互相转换类型的列

MariaDB [tb1]> desc t1;
+-------+---------+------+-----+---------+-------+
| Field | Type    | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| id    | int(11) | NO   | PRI | NULL    |       |
| ip    | int(11) | NO   | UNI | NULL    |       |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.01 sec)

MariaDB [tb1]> create table t5(name varchar(10),user_id int,foreign key(user_id) references t1(id));
Query OK, 0 rows affected (0.00 sec)

MariaDB [tb1]> desc t5;
+---------+-------------+------+-----+---------+-------+
| Field   | Type        | Null | Key | Default | Extra |
+---------+-------------+------+-----+---------+-------+
| name    | varchar(10) | YES  |     | NULL    |       |
| user_id | int(11)     | YES  | MUL | NULL    |       |
+---------+-------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

create table employee( id int primary key, name varchar(20) not null, dpt_id int, foreign key(dpt_id) references department(id) on delete cascade # 级连删除 on update cascade # 级连更新 )engine=innodb;

值的操作

增:insert into tablename [(字段1,字段2...)]values(值1,值2),(),()...;#如果不写字段默认为全部
删:delete from tablename where 条件;
清空整张表:truncate tablename;
改:update tablename set 字段=值 where 条件;
查:select xx from tablename 条件

用户管理

用户格式:用户名@'白名单'

root@'192.168.226.148'
root@'192.168.226.%'
root@'localhost'
root@'server1'
root@'192.168.226.0/255.255.255.0'

添加、查看用户

mysql.user
MariaDB [db1]> create user [email protected] identified by '1';
Query OK, 0 rows affected (0.00 sec)

MariaDB [db1]> select user,host,password from mysql.user;
+-------+-----------------+-------------------------------------------+
| user  | host            | password                                  |
+-------+-----------------+-------------------------------------------+
| root  | localhost       | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| root  | 127.0.0.1       | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| root  | ::1             | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| test1 | 192.168.226.150 | *E6CC90B878B948C35E92B003C792C46C58C4AF40 |
+-------+-----------------+-------------------------------------------+
4 rows in set (0.00 sec)

修改用户密码

MariaDB [mysql]> update user set password=password('123') where user='test1' and host='192.168.226.150';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0

删除用户

drop user 用户名@host;

权限管理

权限类型

ALL: SELECT,INSERT, UPDATE, DELETE, CREATE, DROP, RELOAD, SHUTDOWN, PROCESS, FILE, REFERENCES, INDEX, ALTER, SHOW DATABASES, SUPER, CREATE TEMPORARY TABLES, LOCK TABLES, EXECUTE, REPLICATION SLAVE, REPLICATION CLIENT, CREATE VIEW, SHOW VIEW, CREATE ROUTINE, ALTER ROUTINE, CREATE USER, EVENT, TRIGGER, CREATE TABLESPACE 
ALL : 以上所有权限,一般是普通管理员拥有的 
with grant option:超级管理员才具备的,给别的用户授权的功能

权限管理

授权:grant 权的种类 on 库.表 to 用户 identified by '密码'
grant all on *.* to root@'192.168.226.%' identified by '123456';


查看授权:show grants for 用户
回收:revoke 权的种类 on 库.表  from 用户
刷新:flush privileges

内容管理

这里只列举部分,其他请看我前一篇博客

查询

语法

SELECT DISTINCT [group_concat,聚合,join,union]字段1,字段2... FROM 表名 
WHERE 条件[算数运算符,IN,NOT IN,NOT,any,exists,not exists,and,or] ,可以出现任何字段,但不能有聚合
GROUP BY field 
HAVING 筛选 ,因为在分组后,可以用聚合,只能用分组后的字段
ORDER BY field [asc,desc]
LIMIT 开始,单次最大输出数   #限制条数

优先级

from 
where 
group by 
select 
distinct 
having 
order by 
limit 
1.找到表:from 
2.拿着where指定的约束条件,去文件/表中取出一条条记录 
3.将取出的一条条记录进行分组group by,如果没有group by,则整体作为一组 
4.执行select(去重) 
5.将分组的结果进行having过滤 
6.将结果按条件排序:order by 
7.限制结果的显示条数

查询关键字

between

SELECT emp_name,salary FROM employee WHERE post='teacher' AND salary>10000;

SELECT emp_name,salary FROM employee WHERE salary NOT BETWEEN 10000 AND 20000;

is null

SELECT emp_name,post_comment FROM employee WHERE post_comment IS NULL; 

SELECT emp_name,post_comment FROM employee WHERE post_comment IS NOT NULL;

in

SELECT emp_name,salary FROM employee WHERE salary IN (3000,3500,4000,9000) ;

LIKE模糊查询

通配符’%’ #配任意多个
SELECT * FROM employee 
WHERE emp_name LIKE 'eg%';

通配符’_’ #配一个
SELECT * FROM employee 
WHERE emp_name LIKE 'al__';

综合案例

create database db1 charset utf8;

use db1

create table department( id int primary key, name varchar(20) not null )engine=innodb character set utf8;

insert into department values (1,'教质部'), (2,'技术部'), (3,'人力资源部');

create table employee( id int primary key, name varchar(20) not null, dpt_id int, foreign key(dpt_id) references department(id)
    -> on delete cascade
    -> on update cascade
    -> )engine=innodb character set utf8;

insert into employee values (1,'yuan',1), (2,'nezha',2), (3,'egon',2), (4,'alex',2), (5,'wusir',3), (6,'李沁洋',3), (7,'皮卡丘',3), (8,'程咬金',3), (9,'程咬银',3) ;

级联删除

MariaDB [db1]> select * from employee;
+----+-----------+--------+
| id | name      | dpt_id |
+----+-----------+--------+
|  1 | yuan      |      1 |
|  2 | nezha     |      2 |
|  3 | egon      |      2 |
|  4 | alex      |      2 |
|  5 | wusir     |      3 |
|  6 | 李沁洋    |      3 |
|  7 | 皮卡丘    |      3 |
|  8 | 程咬金    |      3 |
|  9 | 程咬银    |      3 |
+----+-----------+--------+
9 rows in set (0.00 sec)

MariaDB [db1]> select * from department;
+----+-----------------+
| id | name            |
+----+-----------------+
|  1 | 教质部          |
|  2 | 技术部          |
|  3 | 人力资源部      |
+----+-----------------+
3 rows in set (0.00 sec)

MariaDB [db1]> delete from department where id=2;
Query OK, 1 row affected (0.00 sec)
MariaDB [db1]> select * from department;
+----+-----------------+
| id | name            |
+----+-----------------+
|  1 | 教质部          |
|  3 | 人力资源部      |
+----+-----------------+
2 rows in set (0.00 sec)

MariaDB [db1]> select * from employee;
+----+-----------+--------+
| id | name      | dpt_id |
+----+-----------+--------+
|  1 | yuan      |      1 |
|  5 | wusir     |      3 |
|  6 | 李沁洋    |      3 |
|  7 | 皮卡丘    |      3 |
|  8 | 程咬金    |      3 |
|  9 | 程咬银    |      3 |
+----+-----------+--------+
6 rows in set (0.00 sec)

级联修改

MariaDB [db1]> update department set id=2 where id=3;
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0

MariaDB [db1]> select * from employee;
+----+-----------+--------+
| id | name      | dpt_id |
+----+-----------+--------+
|  1 | yuan      |      1 |
|  5 | wusir     |      2 |
|  6 | 李沁洋    |      2 |
|  7 | 皮卡丘    |      2 |
|  8 | 程咬金    |      2 |
|  9 | 程咬银    |      2 |
+----+-----------+--------+
6 rows in set (0.00 sec)

MariaDB [db1]> select * from department;
+----+-----------------+
| id | name            |
+----+-----------------+
|  1 | 教质部          |
|  2 | 人力资源部      |
+----+-----------------+
2 rows in set (0.00 sec)

rsyslog

https://www.cnblogs.com/liuwei-xd/p/11022230.html#%E5%85%AD%E6%97%A5%E5%BF%97%E8%BD%AE%E8%BD%AC

常见系统日志

/var/log/messages 系统主日志文件
/var/log/secure 认证、安全
/var/log/dmesg 和系统启动相关
/var/log/yum.log yum
/var/log/mysqld.log MySQL
/var/log/nginx/  nginx
w 当前登录的用户 /var/log/wtmp

日志级别

日志信息分为以下级别,从上到下级别一次降低
    none    none不是一个等级,它表示不记录服务的所有信息
0     emerg    系统不可用
1    alert    特别留意的报警信息
2    crit    非常严重的状况
3    err        错误信息    
4    warning    警告信息
5    notice    稍微需要注意的信息
6    info    正常信息
7    debug    调试信息,开发人员使用

rsyslog配置

[root@server1 ~]# rpm -qc rsyslog
/etc/logrotate.d/syslog
/etc/rsyslog.conf
/etc/sysconfig/rsyslog


[root@server1 ~]# cat /etc/rsyslog.conf

#### RULES ####

# Log all kernel messages to the console.
# Logging much else clutters up the screen.
#kern.*                                                 /dev/console
#设备名.级别                                            定向到某日志
#.=表示等于某一级别,光.表示大于某个级别,不同设备用;分隔

# Log anything (except mail) of level info or higher.
# Don't log private authentication messages!
*.info;mail.none;authpriv.none;cron.none                /var/log/messages

# The authpriv file has restricted access.
authpriv.*                                              /var/log/secure

# Log all the mail messages in one place.
mail.*                                                  -/var/log/maillog


# Log cron stuff
cron.*                                                  /var/log/cron

# Everybody gets emergency messages
*.emerg                                                 :omusrmsg:*

# Save news errors of level crit and higher in a special file.
uucp,news.crit                                          /var/log/spooler

# Save boot messages also to boot.log
local7.*                                                /var/log/boot.log
#local(数字)为自定义设备

自定义日志

logger "xxx"
logger -p 危险等级 "xxx"
logger -p 设备.等级 "xxx"

实验

远程日志管理

让目标机上的日志发送到一台日志服务器统一管理

服务器

关闭防火墙、selinux

#打开模块相应的端口
vim /etc/rsyslog.conf
# Provides UDP syslog reception
$ModLoad imudp
$UDPServerRun 514

# Provides TCP syslog reception
$ModLoad imtcp
$InputTCPServerRun 514

#重启
service rsyslog restart

#查看监听端口
yum install -y net-tools
netstat -nltup |grep 514

目标机

#修改ssh服务的日志文件的设备载体
vim /etc/ssh/sshd_config 


# Logging
#SyslogFacility AUTH
#SyslogFacility AUTHPRIV
#LogLevel INFO
SyslogFacility LOCAL0
# Authentication:

#重启ssh
service sshd restart

#修改/etc/rsyslog.conf来指定ssh服务的日志发送到远端

# remote host is: name/ip:port, e.g. 192.168.0.1:514, port optional
#*.* @@remote-host:514

local0.*        @192.168.226.148:514    //一个@表示udp,两个@表示tcp 


#重启rsyslog
service rsyslog restart

轮转切割

日志会随着时间越攒越多,对于硬盘来说是个很大的负担,及时切割丢弃旧的日志文件有利于节省空间

[root@server1 ~]# cat /etc/logrotate.conf
# see "man logrotate" for details
# rotate log files weekly
weekly #每周进行一次切割

# keep 4 weeks worth of backlogs
rotate 4 #保留四个文件

# create new (empty) log files after rotating old ones
create #切割后时候创建新的日志文件

# use date as a suffix of the rotated file
dateext #使用日期作为文件名的后缀

# uncomment this if you want your log files compressed
#compress #每次轮转后不需要压缩

# RPM packages drop log rotation information into this directory
include /etc/logrotate.d #导入其他应用的日志轮转规则

# no packages own wtmp and btmp -- we'll rotate them here
/var/log/wtmp {  #具体对应日志的策略,如果有没写的项目则以上面写的为默认配置
    monthly
    create 0664 root utmp
        minsize 1M
    rotate 1
}

/var/log/btmp {
    missingok #丢失不提醒
    monthly
    create 0600 root utmp
    rotate 1
}

firewalld会把数据分区域去进行管理

区域默认规则
trusted允许所有的数据包
home拒绝流入的流量,除非与流出的流量相关;而如果流量与ssh、mdns、ipp-client、
amba-client与dhcpv6-client服务相关,则允许流量
internal等同Home
work拒绝流入的流量,除非与流出的流量数相关;而如果流量与ssh、ipp-client与
dhcpv6-client服务相关,则允许流量
public拒绝流入的流量,除非与流出的流量相关;而如果流量与ssh、dhcpv6-client服务相
关,则允许流量
external拒绝流入的流量,除非与流出的流量相关;ssh
dmz拒绝流入的流量,除非与流出的流量相关;ssh
block拒绝流入的流量,除非与流出的流量相关
drop拒绝流入的流量,除非与流出的流量相关

永久修改分区

firewalld-cmd --permanent --zone=public --add-service=https

[root@server1 ~]# firewall-cmd --zone=public --add-service=https --permanent
success
[root@server1 ~]# firewall-cmd --reload
success

firewall-cmd --zone=public --add-port=8080-8081/tcp

列出开放的端口表

firewall-cmd --zone=public --list-ports

查看可以放行的服务

firewall-cmd --get-services