解决常见的数据库1045密码错误问题

Posted 暮夏有七

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了解决常见的数据库1045密码错误问题相关的知识,希望对你有一定的参考价值。

注:可视化工具 Navicat 15 for mysql

当我们某天忘记我们的root用户密码,登录不到数据库时,只需要修改root用户的密码即可。

1.首先看一下报错信息1045

2.看到这个问题,我们可以找到我们MySQL安装路径下的my.ini文件,使用记事本或者edit打开它。

如果不能打开放到桌面进行打开修改。

3.找到**[mysqld]** 一般在第一行,在它的下面加上skip-grant-tables

加上之后的样子

那么skip-grant-tables是用来干什么的呢?

skip-grant-tables作为启动参数的作用:MYSQL服务器不加载权限判断,任何用户都能访问数据库。

**注意:**但是加上它会降低我们数据库的安全性,可以在解决问题之后删除掉它。

如果没有my.ini文件,可以在桌面新建my.ini配置文件,其配置内容如下

**注意:**要修改成你自己存放的mysql路径。

[mysqld]
skip-grant-tables
#datadir=C:\\Program Files\\mysql-8.0.31-winx64
# 设置3306端口
port=3306
# 设置mysql的安装目录
basedir=C:\\Program Files\\mysql-8.0.31-winx64
# 设置mysql数据库的数据的存放目录
datadir=C:\\Program Files\\mysql-8.0.31-winx64\\\\Data
# 允许最大连接数
max_connections=200
# 允许连接失败的次数。
max_connect_errors=10
# 服务端使用的字符集默认为utf8mb4
character-set-server=utf8mb4
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 默认使用“mysql_native_password”插件认证
#mysql_native_password
default_authentication_plugin=mysql_native_password
federated
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
# 设置时区(mysqld下)
default-time_zone='+08:00'
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8mb4
[client]
# 设置mysql客户端连接服务端时默认使用的端口
port=3306
default-character-set=utf8mb4

4.使用管理员身份打开命令行(cmd)

(1)在命令行中输入 mysql -u root -p,这个命令是连接数据库服务器的命令;遇到Enter passward:直接回车;

显示这个样子就是成功进入数据库了

(2)接着在下方执行操作:use mysql; 这是选择我们的数据库

(3)修改数据库用户root密码:update user set password=password(“123456”) where user=“root”;

需要注意的是:我的MySql版本是8.0.31的相对于5.7版本 在执行上述的修改语句是有语法错误的。

所以我这里使用:ALTER USER ‘root’@‘localhost’ IDENTIFIED WITH mysql_native_password BY ‘password’; 来修改密码的。

看到这个结果说明我们已经修改成功了

(4)刷新数据库 flush privileges; 这样就OK了

 最后,人的惰性是非常可怕的,距离上次写博客快半年了,希望大家也有养成好习惯!

集群常见错误解决方案

参考技术A 解决方法:zookeeper的IP要配对 

解决方法:先安装好hadoop 

解决方法:host配置正确,/etc/sysconfig/network    /etc/hosts    /etc/sysconfig/network-scripts/ifcfg-eth0 

解决方法:SSH配置错误导致,主机名一定要严格匹配,重新配置ssh免密码登录 

5、建议:不要随意格式化HDFS,这会带来数据版本不一致等诸多问题,格式化前要清空数据文件夹 

解决方法:sshd被关闭或没安装导致,which sshd检查是否安装,若已经安装,则sshd restart,并ssh 本机hostname,检查是否连接成功 

解决方法:在yarn-site.xml中增加相应配置,以支持日志聚合 

解决方法:yarn-lient模式出现的异常,暂时无解 

解决方法:windows系统不能解析域名所致,把hosts文件hostname复制到windows的hosts中 

10、建议:HDFS文件路径写法为:hdfs://master:9000/文件路径,这里的master是namenode的hostname,9000是hdfs端口号。 

解决方法:将 http://:19888/jobhistory/logs  配置到yarn-site.xml中,重启yarn和JobHistoryServer 

解决方法:namonode节点终端执行:hdfs dfs -chmod -R 755 / 

13、建议:提交到yarn cluster的作业不能直接print到控制台,要用log4j输出到日志文件中 

解决方法:1.把UTF改成小写utf-8    2.设置编码那行有空格 

解决方法:资源不能分配过大,或者没有把.setMaster("local")去掉

解决方法:通过三节点zookeeper集群和yarn-site.xml配置文件完成Yarn HA 

解决方法:恢复Yarn Http默认端口8088 

解决方法:配置文件不正确,例如hostname不匹配等 

解决方法:find / -type f -size +10G  

解决方法:运行指令hdfs balancer -Threshold 3 或者 运行 start-balancer.sh 脚本格式:$Hadoop_home/bin/start-balancer.sh -threshold,参数3是比例参数,表示3%,也就是平各个DataNode直接磁盘使用率偏差在3%以内 

21、建议:数据倾斜只发生在shuffle过程,可能触发shuffle操作的算子有:distinct  groupByKey  reduceByKey  aggregateByKey  join  cogroup  repartition等 

解决方法:yarn-site.xml配置有问题,检查并规范各项配置 

解决方法:Hadoop 2.x中YARN系统的服务日志包括ResourceManager日志和各个NodeManager日志,它们的日志位置如下:ResourceManager日志存放位置是Hadoop安装目录下的logs目录下的yarn-*-resourcemanager-*.log,NodeManager日志存放位置是各个NodeManager节点上hadoop安装目录下的logs目录下的yarn-*-nodemanager-*.log 

24、建议:小于128M的小文件都会占据一个128M的BLOCK,合并或者删除小文件节省磁盘空间 

解决方法:1)清除hadoop数据目录中用户缓存文件:cd /data/hadoop/storage/tmp/nm-local-dir/usercache;du -h;rm -rf `find  -type f -size +10M`;  2)清理Linux文件系统中的垃圾数据 

解决方法:cd /etc/profile.d;在这里新建相应配置脚本 

解决方法:未启动的节点缺少yarn相关包,要保持所有节点jar包一致 

     fs.trash.interval 

     2880 

     HDFS垃圾箱设置,可以恢复误删除,配置的值为分钟数,0为禁用 

恢复文件执行 hdfs dfs -mv  /user/root/.Trash/Current/误删文件    /原路径 

解决方法:Linux脚本修改后实时生效,务必在脚本全部执行完再修改,以免产生副作用 

以上是关于解决常见的数据库1045密码错误问题的主要内容,如果未能解决你的问题,请参考以下文章

Linux连接MySQL出现1045错误 解决方法

Windows下MySql错误代码1045的解决方法

mysql错误代码1045不能登录的原因与解决方法

sqlyog错误代码1045

mysqldump 错误 1045 访问被拒绝,尽管密码正确等

mysql 1248错误问题解决