我一直在按照手册在Ubuntu上安装软件套件。我完全不了解MySQL。我已经在我的Ubuntu上完成了以下安装。
sudo apt-get update
sudo apt-get install mysql-server-5.5
sudo apt-get install mysql-client-5.5
sudo apt-get install mysql-common
sudo apt-get install glade
sudo apt-get install ntp
然后我做了
cd ~/Desktop/iPDC-v1.3.1/DBServer-1.1
mysql -uroot -proot <"Db.sql"
我最终得到以下错误消息。
错误1045(28000):拒绝访问用户'root'@'localhost'(使用密码:YES)
我该如何修复它并继续?
我使用的是mysql-5.7.12-osx10.11-x86_64。dmg在Mac OS X上。
安装过程会自动为root用户设置一个临时密码。你应该保存密码。密码不可恢复。
按照说明操作:
Go to cd /usr/local/mysql/bin/
Enter the temporary password (which would look something like, "tsO07JF1=>3")
You should get the mysql> prompt.
Run, SET PASSWORD FOR 'root'@'localhost' = PASSWORD('{YOUR_PASSWORD}'); If you wish to set your password: "root" then the command would be, SET PASSWORD FOR 'root'@'localhost' = PASSWORD('root');
Run ALTER USER 'root'@'localhost' PASSWORD EXPIRE NEVER;
Run exit
Run ./mysql -u root -p
Type your password. In my case I would type, "root" (without quote)
That's all.
为了方便起见,您应该在PATH环境变量中添加“/usr/local/mysql/bin”。
现在你可以在任何地方输入。/mysql -u root -p,然后输入密码,你会得到mysql>提示。
虽然上面的答案(使用mysqladmin)在macOS v10.15 (Catalina)上有效,但在Ubuntu上无效。然后我尝试了许多其他的选项,包括MySQL的安全启动,但都不起作用。
下面是一个例子:
至少在这个版本中,我得到了5.7.28-0ubuntu0.18.04.4的答案缺少IDENTIFIED WITH mysql_native_password。5.7.28是当前LTS的默认设置,因此应该是大多数新系统的默认设置(直到Ubuntu 20.04 (Focal Fossa) LTS问世)。
我发现不能设置root密码MySQL服务器,现在应用
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'your_pass_here';
这是可行的。
如果其他答案都不适合您,并且您收到了以下错误:
mysqld_safe Logging to '/var/log/mysql/error.log'.
mysqld_safe Directory '/var/run/mysqld' for UNIX socket file don't exists.
[1]+ Exit 1 sudo mysqld_safe --skip-grant-tables
按照以下命令依次执行,直到重置密码:
# Stop your server first
sudo service mysql stop
# Make the MySQL service directory.
sudo mkdir /var/run/mysqld
# Give MySQL permission to work with the created directory
sudo chown mysql: /var/run/mysqld
# Start MySQL, without permission and network checking
sudo mysqld_safe --skip-grant-tables --skip-networking &
# Log in to your server without any password.
mysql -u root mysql
# Update the password for the root user:
UPDATE mysql.user SET authentication_string=PASSWORD('YourNewPasswordBuddy'), plugin='mysql_native_password' WHERE User='root' AND Host='localhost';
# If you omit (AND Host='localhost') section, it updates
# the root password regardless of its host
FLUSH PRIVILEGES;
EXIT;
# Kill the mysqld_safe process
sudo service mysql restart
# Now you can use your new password to log in to your server
mysql -u root -p
# Take note for remote access. You should create a remote
# user and then grant all privileges to that remote user
2021年。
回答Ubuntu 20.04 (Focal Fossa)(也可能是其他发行版)。
在四处游荡了几天之后…这些答案对我都没用,我就这么做了,而且成功了!
始终在Bash shell中:
sudo systemctl disable mysql
为了阻止守护进程在启动时启动。
sudo apt purge mysql-server
and
sudo apt purge mysql-community-server*
在那里,它警告你,你将删除配置文件…所以它起作用了!因为他们就是捣乱的人!
sudo autoremove
删除所有遗留的包。
然后重启(也许这是可选的,但我做到了)。
另外,我从MySQL官方网页下载了MySQL -server-8.0:
sudo apt install mysql-server
它正在工作的信号是,当您输入上面的命令时,系统要求您输入根密码。
最后:
mysql -u root -p
还有你之前输入的密码。