image

ZERO

背景

本文主要是介绍在MySQL使用运维过程中所遇到的一些坑爹的地方,予自己以做记录!

前言

因操作系统重装之后,安装了mysql5.7,而由此带来了一系列的问题,现将解决这些mysql坑的过程中一些解决办法记录下来,既是为自己后续查找问题提供方便,也是希望能够给各位猿友减少一些踩坑的过程!

正记二

数据库中的datetime数据显示与实际时间相差14个小时,而通过java应用插入和查询的同一条记录,实际显示的是正确的时间 => 因此,是mysql相关配置的问题

vim /etc/my.cnf

default-time-zone = '+8:00' #在 [mysqld] 之下

systemtcl restart mysqld #重启mysql

正记一

ERROR-1

for error : max_allowed_packet

【ANSWER FOR ERROR-1】:

** (1)在mysql-cmd模式下,执行SQL命令“set global max_allowed_packet = 2*1024*102410;”;*

** (2)并且重启mysql服务(windows下win+R -> services.msc找到MySQL重启即可;linux下执行shell命令“service mysqld restart”)**

ERROR-2

for error: Incorrect string value: '\xF0\x9F...' for column 'XXX' at row

【ANSWER FOR ERROR-2】:

** (1)这是由于linux下mysql执行create table建表命令时默认采用的时latin1字符集建表的,导致一些中文字符的写入而出现的异常信息;但是在windows下,mysql默认所建的表字符是utf8的,这也是为何相同的SQL语句由windows->linux下mysql中运行抛出该异常的原因**

** (2)解决该问题的是需要养成一个习惯,也即无论是什么时候什么环境下执行create table创建mysql数据库表时,务必指定特定的字符集和引擎,如SQL命令(含ENGINE=InnoDB DEFAULT CHARSET=utf8)**

DROP TABLE IF EXISTS `db_test`;

CREATE TABLE `db_test` (

`db_test_id` VARCHAR(100) NOT NULL COMMENT '测试Id',

`db_test_text` VARCHAR(255) NOT NULL COMMENT '测试文本',

`status` VARCHAR(2) DEFAULT '1' COMMENT '状态,1启用(默认),-1禁用',

`update_time` datetime DEFAULT NULL COMMENT '更新时间',

`create_time` datetime NOT NULL COMMENT '创建时间',

PRIMARY KEY (`db_test_id`)

)ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='测试表';

ERROR-3

诡异描述(其实是自我错觉)之“在Springboot+Mybatis+MySQL系统架构下,某个接口的一条查询语句预期正常情况下是可以成功查询到1条返回结果的,但是只要在sql-where条件中对某个字段INDUSTRIENAME进行筛选时查询过来的结果总是0条数据,并且在navicat下手动执行该一模一样SQL语句及where条件是有1条结果的”

=》 经过一整天的折腾:从怀疑SQL的正确性,将SQL不断拆分 -> 去除各种where条件查询均可以有结果且只要加上该字段的筛选就是0条 -> 怀疑mybatis的配置有问题 -> 结果返回java对象的映射有问题->连接的数据库地址不正确->poatman传过来的数据不是预期的那个条件值->应用控制台将SQL语句以及条件值打印出来->重启IDE、重启mysql、重启电脑->……历经了一整天的崩溃过程,一度怀疑人生一度怀疑自己的程序猿生涯之路将就此终结,万万没有想到的是自己并没有错,错的居然是因为查询的条件传过来的值是中文,,,注意是中文、中文、中文,重要的事情强调三遍 -> 于是在建立数据源连接的地方,指定字符集utf8方解决这折腾了自己一整整天的“诡异”问题,归根结底还是自己定位查问题的方式需要优化,如果能够直接去查看mysql的log将问题很快就会被发现和解决!!

【ANSWER FOR ERROR-3】:

** (0)留个心眼----尤其是MySQL数据库版本更新以及自主安装的MySQL中,特别注意当前出现的问题或者异常中有没有环节中是有中文、中文、中文的!!!!**

** (1)养成良好的msyql数据源配置习惯,如:**

jdbc:mysql://127.0.0.1:3306/test?characterEncoding=UTF-8

另外,需要注意的是数据源连接配置的几个选项“&autoReconnect=true&useSSL=true&useUnicode=true”等的含义及引发的问题;同时,若是中文在数据库中显示是“?”或者更新中文文字到数据库中出现异常,则是数据库的默认字符集问题,可通过SQL命令“show VARIABLES LIKE '%character%'”查看当前character-set-server的值

** (2)不仅仅要开启的是应用的SQL-log日志,更需要去开启mysql自身log以实时查看或者落日志文件,保证能够查看到最终mysql中是实际执行的SQL语句,如果这个LOG开启了,只要一查看该log就能够知道该问题是由于java-mysql连接数据源的时候未指定字符集而导致的针对中文字符串为值得查询条件时,实际执行的查询语句并非是预期的那个中文字符串而是乱码(未设置utf8导致的mysql实际接收到是乱码)**

**#Issue 1:

InnoDB: The innodb_system data file 'ibdata1' must be writable**

按照菜鸟教程上的MySQL教程,在CentOS7上利用RPM包安装好MySQL后第一次启动服务:

systemctl start mysqld.service

结果启动失败,查看mysql服务的启动日志:

日志位置:var/log/mysqld.log

2018-07-10T03:28:38.289394Z 0 [System] [MY-010116] [Server] /usr/sbin/mysqld (mysqld 8.0.11) starting as process 10959

2018-07-10T03:28:38.502207Z 1 [ERROR] [MY-012271] [InnoDB] InnoDB: The innodb_system data file 'ibdata1' must be writable

2018-07-10T03:28:38.502279Z 1 [ERROR] [MY-012278] [InnoDB] InnoDB: The innodb_system data file 'ibdata1' must be writable

2018-07-10T03:28:38.502331Z 1 [ERROR] [MY-010334] [Server] Failed to initialize DD Storage Engine

2018-07-10T03:28:38.502619Z 0 [ERROR] [MY-010020] [Server] Data Dictionary initialization failed.

2018-07-10T03:28:38.502667Z 0 [ERROR] [MY-010119] [Server] Aborting

2018-07-10T03:28:38.521513Z 0 [System] [MY-010910] [Server] /usr/sbin/mysqld: Shutdown complete (mysqld 8.0.11) MySQL Community Server - GPL.

注意到第一个Error:[InnoDB] InnoDB: The innodb_system data file 'ibdata1' must be writable,可能是权限不够的原因,于是修改'ibdata1'所在文件夹的权限:

MySQL data默认路径:/var/lib/mysql

chmod -R 777 /var/lib/mysql

再次启动服务,终于启动成功。

mysql运维工资_MySQL运维踩坑相关推荐

  1. mysql 二进制日志变化_MySQL运维之二进制日志

    MySQL二进制日志里保存会造成或可能造成数据变化的SQL语句.通过二进制日志可以完成如实时异地容灾备份.读写分离.数据恢复等功能.下面,我们一起来看看Mysql二进制日志. 开启bin-log日志 ...

  2. 15个必知的Mysql索引失效场景,别再踩坑了

    背景 无论你是技术大佬,还是刚入行的小白,时不时都会踩到Mysql数据库不走索引的坑.常见的现象就是:明明在字段上添加了索引,但却并未生效. 前些天就遇到一个稍微特殊的场景,同一条SQL语句,在某些参 ...

  3. mysql追溯历史性能问题_【踩坑記錄】記一次MySQL主從復制延遲的坑

    最近開發中遇到的一個MySQL主從延遲的坑,記錄並總結,避免再次犯同樣的錯誤. 情景 一個活動信息需要審批,審批之后才能生效.因為之后活動要編輯,編輯后也可能觸發審批,審批中展示的是編輯前的活動內容, ...

  4. mysql运维备份_MySQL运维经验

    原标题:MySQL运维经验 1. 概要 每台机器都使用多实例的模型. 每个机器放多个实例,每个实例放多个DB. 多实例之间没有进行资源隔离,这么做是让每个实例都能发挥最大性能. 目前大部分核心业务已切 ...

  5. MySQL运维知识点_mysql运维必备知识点(转载至其他作者)

    (1)基础笔试命令考察 1.开启MySQL服务 /etc/init.d/mysqld start service mysqld start systemctl start mysqld 2.检测端口是 ...

  6. mysql定制rpm包_mysql运维管理-企业rpm包的定制

    1.安装打包工具 [linzhongniao@rpmbaozhizuo ~]# yum install rpm-build –y 2.规划打包目录 [linzhongniao@rpmbaozhizuo ...

  7. mysql最高平均工资_mysql查询出平均工资最高的部门编号

    mysql查询出平均工资最高的部门编号 一.部门表 DROP TABLE IF EXISTS `depts`; CREATE TABLE `depts` ( `id` int(11) NOT NULL ...

  8. mysql 更改员工工资_MySQL编辑和更新记录,包括员工工资

    UPDATE命令在MySQL中用于更新记录.通过它,SET命令可用于设置新值.让我们首先创建一个表-mysql> create table DemoTable ( EmployeeId int  ...

  9. 本地安装MySQL数据库-8.0.29版本(踩坑版)

    目录 1.下载数据库网址: 2.选择要下载的版本: 3.安装MySQL 3.1安装报错:找不到兼容的服务器 4.配置环境变量 5.验证是否安装.配置环境变量成功 6.使用navicat创建数据库 6. ...

最新文章

  1. springboot相关书籍文献_国内民国时期文献酸化调研与思考
  2. 二值网络--TBN: Convolutional Neural Network with Ternary Inputs and Binary Weights
  3. Mysql系列(三)—— Mysql主从复制配置
  4. 《麻省理工科技评论》:2018年18大科技趋势,2017年7大失败技术
  5. 2020.12.17
  6. Winform中实现将照片剪贴到系统剪切板中(附代码下载)
  7. NumPy之:结构化数组详解
  8. 平台日志架构说明log4j漏洞问题解析
  9. Maven项目的基本创建步骤
  10. 在Ruby中,如何跳过.each循环中的循环,类似于‘continue‘[duplicate]
  11. Swift - 炫酷放射弹出按钮菜单(改造自AwesomeMenu)
  12. ISO/IEC 27002:2022中文版
  13. GenBank数据格式
  14. 数字+字母+特殊字符 的正则表达式
  15. 微信小程序云开发实现一个社区 Demo(补充)
  16. csgo autoexec.cfg
  17. 深度揭秘投资的本质——我是如何从20万炒到几千万的?
  18. 用java实现螺旋矩阵算法
  19. End-to-end people detection in crowded scenes
  20. FEST-Swing 1.2发布

热门文章

  1. MindSpore张量mindspore::tensor
  2. 3D点云重建原理及Pytorch实现
  3. Activity在有Dialog时按Home键的生命周期
  4. Oracle报错createPool,Jmeter中连接Oracle报错Cannot create PoolableConnectionFactory
  5. Fragment 使用 replace 的方式实现切换 以及切换的时候Fragment 生命周期
  6. android setAlpha 与 getBackground().setAlpha
  7. Android intent 接受值的内容为空
  8. mqtt+htttp+websocket
  9. Cannot locate BeanDefinitionParser for element [scoped-proxy]
  10. 如何禁止浏览器自动填充