先从 MySQL 对数据库复制的能力看,MySQL 支持单向、异步的复制。复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器。...主服务器将更新写入二进制日志文件,并维护日志文件的一个索引以跟踪日志循环。当一个从服务器连接到主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置。...下面我们就介绍下 CentOS7 中如何搭建 MySQL 主主互备服务器。 1....MySQL 安装 参考:https://blog.csdn.net/hongguo_cheng/article/details/80293264,要在两个虚拟机中均安装成功。 3....MySQL 配置 既然是主主互备,就说明两个数据库都要对外进行服务,为了防止 id 重复,我们需要在配置文件中对两个数据库的自增长的 offset 设置为不同的值,具体如下: master-1 服务器中文件
示例: ALTER TABLE spPick DROP PRIMARY KEY ,ADD PRIMARY KEY (cid,startday); 单删的话会报错...
Mysql 中的GTID是什么 ? 答:全局事务ID,为每一个在Master上提交的事务在集群内Replication时只生成一个唯一的ID,为规避冗余和错误提供了有力保障。 ...首次启动时生成,保存在DB的数据目录中auto.conf文件里,存放server-uuid的值(唯一性)。...GTID Replication中Slave会将执行完的事务的GTID值告知Master,之后Master把所有没在Slave端执行过的事务发送到Slave端并执行。.../data/master-binlog.000001 | tail -20 (备注:当调用mysqlbinlog这个工具无法识别binlog中配置中的default-character-set=utf8mb4...37.jpg 主备关系修复成功。
这个值后面对应的utf8_unicode_ci是什么意思呢?面试的时候用这个题目考一考DBA,应该可以难倒一大部分人。 COLLATE是用来做什么的?...对于mysql中那些字符类型的列,如VARCHAR,CHAR,TEXT类型的列,都需要有一个COLLATE类型来告知mysql如何对该列进行排序和比较。...这里顺便讲个题外话,mysql中有utf8和utf8mb4两种编码,在mysql中请大家忘记utf8,永远使用utf8mb4。...在mysql8.0以下版本中,你如果什么都不修改,默认的CHARSET是Latin1,默认的COLLATE是latin1_swedish_ci。...以上就是关于mysql的COLLATE相关知识。不过,在系统设计中,我们还是要尽量避免让系统严重依赖中文字段的排序结果,在mysql的查询中也应该尽量避免使用中文做查询条件。
如题,我在phpmyadmin中发现自己新建的用户的权限是usage,这是什么权限啊? 但是我能够进行常规的插入,删除,建表操作啊?拜托,明确知道再回答好不好,这又不是贴吧,就别灌水了。...GRANT OPTION 可以看出,不知USAGE一种权限,所以,你才会正常的执行查删等操作 usage的字面意思就是用法,其实就是让你这个用户可以像个用户似的登录,但是除了能看到有那写数据库外,什么权限也没有
♣ 题目部分 在Oracle中,单列索引和复合索引分别是什么? ♣ 答案部分 按照索引列的个数,索引可以分为单列索引和复合索引。单列索引是基于单个列所建立的索引。...复合索引(Composite Indexes),也称为连接索引、组合索引或多列索引,是在某个表中的多个列上建立的索引。复合索引中的列应该以在检索数据的查询中最有意义的顺序出现,但在表中不必是相邻的。...若WHERE子句引用了复合索引中的所有列或前导列,则复合索引可以加快SELECT语句的数据检索速度。所以,在复合索引的定义中所使用的列顺序很重要。一般情况下,把最常被访问和选择性较高的列放在前面。...复合索引适合于单列条件查询返回多、组合条件查询返回少的场景。需要注意的是,创建复合索引可以消除索引回表读的操作,所以,在很多情况下,DBA通过创建复合索引来提高查询SQL的性能。...在Oracle中,可以使用视图DBA_IND_COLUMNS来查询复合索引的索引列。
172.72.0.15)上执行 6.2、其他节点加入MGR,在从库(172.72.0.16,172.72.0.17)上执行 七、多主和单主模式切换 7.1、查询当前模式 7.2、函数实现多主和单主切换...7.2.1、单主切多主模式 7.2.2、多主切单主模式 7.3、手动切换 7.3.1、单主切多主模式 7.3.2、多主切单主模式 八、测试同步 九、MGR新增节点 9.1、创建新MySQL...------+--------------+-------------+----------------+ 3 rows in set (0.01 sec) 可以看到,3个节点状态为online,并且主节点为...7.2、函数实现多主和单主切换 函数切换:从MySQL 8.0.13开始,可以使用函数进行在线修改MGR模式。...-- 单主切多主 select group_replication_switch_to_multi_primary_mode(); -- 多主切单主,入参需要传入主库的server_uuid select
优点: 1、实现mysql数据库集群架构的高可用性和数据的 强一致性。 2、完成了真正的多节点读写的集群方案。 ...=123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=123456 -v v1:/var/lib/mysql -v backup:/data --privileged...=123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=123456 -e CLUSTER_JOIN=node1 -v v2:/var/lib/mysql...=123456 -e CLUSTER_NAME=PXC -e XTRABACKUP_PASSWORD=123456 -e CLUSTER_JOIN=node1 -v v3:/var/lib/mysql...+Haproxy+Keepalived+MGR高可用(多主同时写入)→
一、前言 在工作中经常要与 mysql 打交道,但是对 mysql 的各个字段类型一直都是一知半解,因此写本文总结记录一番。 二、简介 ? ...对于 int 类型的一些基础知识其实上图已经说的很明白了,在这里想讨论下常用的 int(11) 代表什么意思,很长时间以来我都以为这代表着限制 int 的长度为 11 位,直到有天看到篇文章才明白,11...那么照文中所说,所以无论怎么设置 int 类型的显示宽度,int 所能存储的最大值和最小值是固定的,那么这个显示宽度到底有什么用呢? ...当 int 字段类型设置为无符号且填充零(UNSIGNED ZEROFILL)时,当数值位数未达到设置的显示宽度时,会在数值前面补充零直到满足设定的显示宽度,为什么会有无符号的限制呢,是因为 ZEROFILL...三、结论 从上个例子我们可以得出以下几个结论: 1、如果一个字段设置了无符号和填充零属性,那么无论这个字段存储什么数值,数值的长度都会与设置的显示宽度一致,如上述例子中的字段 b,插入数值 1 显示为
mysql中primary key是什么 说明 1、primary key主键约束是一个列或者列的组合,其值能唯一地标识表中的每一行。...实例 mysql> create table t2(id int not null unique, name varchar(4)); Query OK, 0 rows affected (0.01 sec...) mysql> desc t2; +-------+------------+------+-----+---------+-------+ | Field | Type | Null...中primary key的介绍,希望对大家有所帮助。...更多mysql学习指路:MySQL 推荐操作系统:windows7系统、mysql5.8、DELL G3电脑 收藏 | 0点赞 | 0打赏
MariaDB Galera Cluster(下文简称 MGC 集群),是一套在 MySQL innodb 存储引擎上面实现多主、数据实时同步以及强一致性的关系存储架构,业务层面无需做读写分离工作,数据库读写压力都能按照既定的规则分发到...*5、*自动节点加入 6、真正并行的复制,基于行级 *7、*直接客户端连接,原生的 MySQL 接口 **8、**每个节点都包含完整的数据副本 9、多台数据库中数据同步由 wsrep 接口实现 缺点:...=yse mariadb:10.3 分别在三个容器中添加 mysql 账户 注: 生产环境注意安全,我是在测试环境为了方便 mysql -uroot -p GRANT ALL PRIVILEGES ON...解决办法: 选定主节点启动时加 --wsrep-new-cluster 参数启动 正常启动后的节点重新生成 gvwstate.dat 文件 5、MySQL Unknown/unsupported storage...下一篇: 在Docker中安装使用MySQL 部署PXC高可用(多主同时写入)→
mysql中binlog有什么作用 1、数据恢复。只要有数据库在某个时刻的备份以及此时后的所有binlog,就可以恢复数据库的数据。...在我们的日常工作中,我们的DBA学生经常可以帮助我们将数据库的数据恢复到任何一秒。 2、主从复制。为了提高MySQL的效率,经常做读写分离,即一主多从。 一个主库(写库),多个从库(读库)。...实例 binlog_format = MIXED log-bin = E:mysql路径\\mysql-5.6.35-winx64\\logs\\mysql-bin.log expire-logs-days... = 7 max_binlog_size = 200m binlog_cache_size = 10m max_binlog_cache_size = 500m 以上就是mysql中binlog的作用,...更多mysql学习指路:Mysql
mysql中enum类型是什么 说明 1、枚举类型,其值范围需要在创建表时通过枚举显示。 2、enum忽略了大小写。也支持通过下标(从1开始,下标越界时报错)插入数据。特殊值0表示空值。...实例 --创建表te,包含字段f1(enum('a','b','c')) mysql> create table te(f1 enum('a','b','c')); --向表中插入几条记录 mysql>... insert into te values('a'),('B'),('3'),(null); 以上就是mysql中enum类型的介绍,希望对大家有所帮助。...更多mysql学习指路:MySQL 推荐操作系统:windows7系统、mysql5.8、DELL G3电脑 收藏 | 0点赞 | 0打赏
mysql中replace函数是什么 说明 1、可以替换字符串中的内容,直接替换数据库中某字段中的特定字符串,不再需要自己写函数去替换。 是mysql里面处理字符串比较常用的函数。...实例 SELECT REPLACE('MySQL字符串函数', '字符串', '日期') AS str1, REPLACE('MySQL字符串函数', '字符串', '') AS str2...; str1 |str2 | ------------+---------+ MySQL日期函数|MySQL函数| 以上就是mysql中replace函数的介绍,希望对大家有所帮助...更多mysql学习指路:MySQL 推荐操作系统:windows7系统、mysql5.8、DELL G3电脑 收藏 | 0点赞 | 0打赏
mysql中Explain命令是什么 概念 1、explain用来分析SELECT查询语句,开发人员可以通过分析Explain结果来优化查询语句。...实例 explain select * from table_user ; 以上就是mysql中Explain命令的介绍,希望对大家有所帮助。
偶尔还会出现因 pid 文件找不到而启动失败的现象,那么 pid 与 socket 文件究竟是干什么用的呢?我们一起来看下本篇文章。...1.pid-file介绍 MySQL 中的 pid 文件记录的是当前 mysqld 进程的 pid ,pid 亦即 Process ID 。...进程运行后会给 pid 文件加一个文件锁,只有获得 pid 文件写入权限的进程才能正常启动并把自身的 PID 写入该文件中,其它同一个程序的多余进程则自动退出。...在本地登录时,如果 my.cnf 配置文件中的 [client] 部分没有指定 socket 文件路径,mysql 默认会去寻找 /tmp/mysql.sock ,所以如果 mysqld 服务启动的时候...同样的,socket 文件目录权限要对 mysql 系统用户放开。 总结: 本篇文章介绍了 MySQL 中的 pid 及 socket 文件的具体配置及作用。
MySQL中join buffer是什么 说明 1、在MySQL对于join操作的处理过程中,join buffer是一个重要的概念。...2、是MySQL对于table join的一个重要的优化手段。虽然这个概念实现并不复杂,但是这个是实现MySQL join连接优化的一个重要方法,在连接的时候可以极大提高join查询的效率。...all stored t1, t2 combinations in cache - If row satisfies join condition, send it to client 以上就是MySQL...中join buffer的介绍,希望对大家有所帮助。...更多mysql学习指路:MySQL 推荐操作系统:windows7系统、mysql5.8、DELL G3电脑
以前只是简单听说过Mysql有全文索引,但是一直没有认真去了解过。最近在《MYSQL必知必会》中学习到这个知识点,做下记录。 首先,什么是全文索引?...那么问题来了,既然只是达到这个需求的话使用LIKE就行了,LIKE不行的话也还能使用正则表达式,为什么还要大费周章弄个全文索引出来呢?...②不能明确控制,单单使用通配符和正则表达式很难甚至不能明确地控制匹配什么和不匹配什么。 ③结构不够智能,通配符和正则都是返回所有满足条件的所有行,并且这种返回是相对无序的,不智能的。...相当于 LIKE ‘%rabbit%’ ; 但是这里必须谈一谈,文章开头所说到的智能是什么意思,问什么会和LIKE不同?...③Mysql再次进行全文索引,并且 不仅使用原查询词语,而且加上步骤②选出的词。
所以,经常酱油,不知道该学习什么? 于是,我发了一套面试题,如下: ? 结果,他们都来要答案了。哎,做伸手党可不好,什么时候才能独立呢?所以,我一一的拒绝了他们。...不同的场景,还真不能说 MyISAM 比 InnoDB 中的查询快! 下面我们一起来看看 Innodb 和 Myisam 的 5 大区别: ? 上面的“事务”写错了。...那么为什么大家喜欢说 MyisAM 查询快呢?那是因为,InnoDB 的表是根据主键进行展开的 B+tree 的聚集索引。...MyIsam 则非聚集型索引,myisam 存储会有两个文件,一个是索引文件,另外一个是数据文件,其中索引文件中的索引指向数据文件中的表数据。...当有聚簇索引时,它的索引实际放在叶子页中。 ? 结合上图,可以看出:INNODB 在做 SELECT 的时候,要维护的东西比 MYISAM 引擎多很多。 ?
双码流能实现本地和远程传输的两种不同的带宽码流需求,本地传输可以用主码流,能获得更清晰的存储录像,远程传输就因为带宽限制的原因,而使用子码流来获得流畅的图像和录像。...当一路视频进入录像机后,录像机可以编码提供了主码流和子码流两种码流,主码流用来本地录像,子码流用来网络传输。默认是录像机本地访问,自动主码流显示。远程访问自动子码流显示。 ?...主码流一般码流较大,清晰度高,占用的带宽也就高。子码流,在主码流的图像环境下降低了图像格式,清晰度较主码流要低,占用带宽小。主码流一般用于存储,子码流用于网传。...主码流本地存储,子码流适用于图像在低带宽网络上传输。 我们的流媒体服务器能够将监控视频网页无插件直播,在这其中就充当了取流和分发的作用,一边是从摄像机取流,一边是转换协议之后进行分发。...视频直播点播流媒体服务器可以进行视频直播/录像/回放,在取流的时候可以根据自己的需要来取流,可以是主码流,也可以是子码流。 ?
领取专属 10元无门槛券
手把手带您无忧上云