pip install mysqlclient==2.1.1 NameError: name '_mysql' is not defined 有人说版本高了 pip install mysqlclient==1.4.6 symbol not found in flat namespace '_mysql_affected_rows' pip install mysql-Python 报错 ModuleNotFoundError: No module named 'ConfigParser' pip -V pip 21.2.4 from /Users/ge/opt/anaconda3/lib/py More
彻底解决的策略 方案1. 业务妥协,从主库读 方案2. 同步写入缓存redis,修改完成5分钟内都直接从redis读。 其他让延迟变好的策略 1.并行复制 2.降低并发,增加机器 2023.1.16 更新思维导图 思维导图 1.常见的主从架构 随着日益增长的访问量,单台数据库的能力已经捉襟见肘。因此采用主库写数据,从库读数据这种将读写分离开的主从架构便随之衍生了出来 More
1.索引的本质是什么 2.MYSQL为何多数用B+Tree,而不是其他 3. BTree的特点 4. B+Tree的特点 4.1 为何B+Tree叶子节点多了一个指针 4.2 为什么B+Tree上层节点不存储数据 5. 两种不同的索引分别存储文件什么样 6. Innodb索引实现原理 6.1 为什么innodb表必须有主键,并推荐【整型自增】 6.2 为什么非主键索引结构叶子节点存储的是主键 More
问题:你们有没有做 MySQL 读写分离?如何实现 MySQL 的读写分离?MySQL 主从复制原理的是啥?如何解决 MySQL 主从同步的延时问题? 问题1:如何实现 MySQL 的读写分离? 其实很简单,就是基于主从复制架构,简单来说,就搞一个主库,挂多个从库,然后我们就单单只是写主库,然后主库会自动把数据给同步到从库上去。 问题2:MySQL 主从复制原理的是啥 More
总结: 索引的原则: 1. 最左前缀匹配 2. 区分度高的列作为索引,索引并非建立的越多越好,适用就好3. 索引的字段尽量的小4. 尽量扩展索引,建立联合索引,不是建多个索引5. 少用select *6. not in,not exists,<> != 不等于会不触发索引 小于 > 大于 <= >= 这个根据实际查询数据来判断,如果全盘扫描速度比索引速度要快则不走索引 。 建索引的 More
条件: 3亿数据服务不能停,就是不能影响业务进行 常规操作增加一列,ALTER TABLE 你的表 ADD COLUMN 新列 varchar(128);常规的办法会导致锁表,服务暂停 所以大致思路为 简易过程如下: 新建一个和 Table1 完全同构的 Table2在表 Table2 上执行 ALTER TABLE 你的表 ADD COLUMN 新列 char(128)将 Table1 中的数据拷贝到 Table2,最好用 More
服务器记录了一些操作日志经常把空间吃满了 select id,send_email,user_email,from_unixtime(send_time) from email_log order by id desc limit 1; from_unixtime 转换linux格式为可以阅读的格式 删除ID小于20万的数据 delete from email_log where id < 200000; optimize table email_log
情况: MYSQL8 的密码机制导致了大量的软件无法连接 1.导致Navicat无法连接MySQL8.0的 2.Sequel Pro无法连接mysql8 3.php 5.6 的原来代码也连接不上了,显示数据库无法连接(看来要用php7) 提示客户端过期 原因 MySQL 8.0 版本去除了 password 字段,改用 authentication_string 字段,导致网上可以搜到的各种问题的各种解决方法完全没有效果;同时还更 More
MYSQL 开启主从同步后服务器很快空间告急了。 1.1G mysql-bin.000001 1.1G mysql-bin.000002 1.1G mysql-bin.000003 1.1G mysql-bin.000004 1.1G mysql-bin.000005 1.1G mysql-bin.000006 1.1G mysql-bin.000007 1.1G mysql-bin.000008 1.1G mysql-bin.000009 1.1G mysql-bin.000010 1.1G mysql-bin.000011 1.1G mysql-bin.000012 1. More
1.修改主服务器配置文件 vi /etc/my.cnf [mysqld] log-bin=mysql-bin server-id=1 改完 重启动mysql 2. 创建一个账户 mysql > grant replication slave on *.* to 'rep'@'%' identified by '123456'; Query OK, 0 rows affected, 1 warning (0.01 sec) replication 表示这个账户只能用来进行主从复制 3. 获取二进制日志的信息并导出数据 More