MySQL运维面试必备:基础问答与实战解析

需积分: 42 12 下载量 95 浏览量 更新于2024-08-12 收藏 484KB PDF 举报
“mysql运维基础知识面试问答题.pdf”包含了大量的MySQL运维相关的面试问题,涵盖了数据库的基础概念、产品特性、SQL语法、安全配置、故障处理、性能优化以及备份与恢复策略等多个方面,适合准备MySQL运维面试或者提升运维技能的人士阅读。 **1. 关系型数据库与非关系型数据库** 关系型数据库(如MySQL)基于关系模型,特点是数据以表格形式存储,支持ACID(原子性、一致性、隔离性、持久性)特性,适合结构化数据存储。非关系型数据库(如MongoDB)则采用键值对、文档、列族或图形等数据模型,强调高扩展性和灵活性,适用于大数据和分布式环境。 **2. SQL语句与关键字** SQL是Structured Query Language的缩写,用于管理和操作数据库。其关键字包括SELECT(查询数据)、INSERT(插入数据)、UPDATE(更新数据)、DELETE(删除数据)、CREATE(创建对象)、ALTER(修改对象)、GRANT(授权)和REVOKE(撤销权限)等。 **3. 数据类型char和varchar** char是固定长度字符串类型,预分配指定长度空间;varchar是可变长度字符串,只分配实际存储所需空间,节省存储空间。 **4. 字符集配置与用户授权** 创建utf8字符集数据库通常用`CREATE DATABASE db_name CHARACTER SET utf8;`,授权用户访问语句如`GRANT ALL PRIVILEGES ON db_name.* TO 'user'@'%' IDENTIFIED BY 'password';`,限制IP访问则修改为`WHERE clause`,如`... FROM '172.16.1.0/24'`. **5. MySQL多实例配置** 多实例意味着在一台服务器上运行多个MySQL服务,通过不同的端口和数据目录实现。配置时需修改my.cnf配置文件,指定不同的端口和数据路径。 **6. MySQL安全** 加强MySQL安全包括设置强密码、限制远程访问、定期更改密码、使用SSL加密连接、合理分配用户权限、启用审计日志等。 **7. 密码找回** 忘记root密码可通过启动MySQL服务时跳过权限表来重置,或使用`mysqladmin -u root password 'new_password'`命令。 **8. 数据删除区别** DELETE删除数据会记录在事务日志中,可以回滚,且影响索引;TRUNCATE删除整个表,不记录事务,速度快但不可回滚。 **9. 解决sleep线程过多** 检查并优化长时间运行的查询,设置合适的wait_timeout和interactive_timeout参数。 **10. sort_buffer_size参数** 该参数控制排序操作时内存使用,调整大小可优化排序性能,使用`SET GLOBAL sort_buffer_size = value;`在线修改。 **11. Binlog工作模式与选择** MySQL Binlog有ROW、STATEMENT和MIXED三种模式,ROW记录所有变更细节,STATEMENT记录SQL语句,MIXED根据情况选择。企业选择时要考虑一致性、性能和复制需求。 **12. 数据恢复与备份** 误操作恢复通常依赖于备份和binlog,如使用mysqldump恢复单表需结合特定参数。主从复制则涉及主从配置、同步状态监控和故障处理。 **13. 读写分离与级联复制** 读写分离通过代理或数据库内置功能实现,减少主库压力;级联复制用于多级同步,常用于复杂网络环境。 **14. 复制故障解决** 监控通过`SHOW SLAVE STATUS\G`检查,故障可能由网络、权限、主从延迟等原因引起,需针对性解决。 **15. 备份策略** 全备、增备、冷备和热备分别对应完整数据备份、增量备份、停止服务备份和不停服务备份,企业实践中通常结合使用,以平衡成本和恢复速度。 **16. SQL优化** SQL优化包括查询重构、索引优化、避免全表扫描、合理使用JOIN和子查询等。 以上仅是部分问题的解答,完整的PDF文件将提供更详细的信息,对于MySQL运维人员来说是一份宝贵的参考资料。