开发者

mysqldump access denied

开发者 https://www.devze.com 2023-02-28 20:52 出处:网络
When I try to backup using mysqldump from ssh, I run the following command on machine 10.64.1.1. It gives the following error.

When I try to backup using mysqldump from ssh, I run the following command on machine 10.64.1.1. It gives the following error.

mysqldump --user=test -p=password --host=10.64.1.2 --tab=. databasename tablename

mysqldump: Got error: 1045: Access denied for user 'test'@'10.64.1.1' (using开发者_如何学C password: YES) when trying to connect

However, I can access mysql using the same user and password.

mysql --user=test -p[password]

Current user: test@10.64.1.1

SSL: Not in use

Current pager: stdout

Using outfile: ''

Using delimiter: ;

Server version: 5.0.91-50-log Percona SQL Server, Revision 73 (GPL)

Protocol version: 10

Connection: 10.64.1.2 via TCP/IP

Updates:

If I do following mysql document: --password[=password] or -p[password].

Since my password contains special symbol @, Mysql cannot detect user correctly. It complains:

mysqldump: Got error: 1044: Access denied for user 'test'@'%' to database


You have to run CMD.EXE as the Administrator:

Right click on cmd.exe --> Run as Administrator and then type your command:

mysqldump -u[username] -p[password] -h[ip or name] yourdatabasename > c:\sqlfile.sql

It should work fine.


I think that you would have to lose the = when using -p or do it with --password :

--password[=password], -p[password]

The password to use when connecting to the server. If you use the short option form (-p), you cannot have a space between the option and the password. If you omit the password value following the --password or -p option on the command line, you are prompted for one. Specifying a password on the command line should be considered insecure. See Section 6.6, "Keeping Your Password Secure".


I know the topic is very old, but I happened to have the same issue. I figured out that the problem was just the special character used in the password. In fact they must be escaped with the anti slash: --password=123\@456 or using signle quotes --password='123@456'


I had the same problem with a DB user created via Plesk. The user has permissions for a single database. If I specify the database name I get the error mentioned above. If I specify -A for all databases, the dump works.


In windows, I resolved it by making a directory and then dumping *.sql file in backup directory.

C:\backup

There are no issues with commands :
Remove the [ ] square brackets

mysqldump -u[username] -p[password] -h[ip] yourdb > C:\backup\sqlfile.sql

It worked for me:)


One more possible cause can be the place you are trying to create dump. Writing mysqldump -u[username] -p yourdb > D:\backup\sqlfile.sql instead of mysqldump -u[username] -p yourdb > sqlfile.sql resolved my problem.


There is no = (equal sign) for the connection options. You want the following.

mysqldump -u test -ppassword -h 10.64.1.2 ...

Check out the docs for more details on the other options.


Heres what worked for me- run cmd line as admin. dont put any password after -p, you are automatically prompted to enter a password and it works.


Trying with this command

mysqldump --user=root -p --host=127.0.0.1 --databases database_name [database_name_2,...] > dump.sql


The problem is that there need additional access to create file in C:/ location so try to use other like for me it resolve by : mysqldump -u root -p cricket classics > C:\Users\habib_s9ayvfl\Desktop\classics.sql


In accordance with this page https://dev.mysql.com/mysqldump-copying-database open your console window (like cmd) and navigate to your mysql installation folder. F.e. c:\mysql and then to the bin folder, so you have c:\mysql\bin

Then type:

mysqldump source_db_name -uuser_name -ppassword  > target_database.sql

Be sure that after -u there are no blanks! Same by -p! No blanks! When you're done, type:

mysqladmin create target_database -uuser_name -ppassword

And now you can migrate the data from target_database.sql to your new database:

mysql target_database < target_database.sql -uuser_name -ppassword

It's a very "simple an stupid" way to cloning your database on a same server, into a new one. Also my description here is simple and stupid, but maybe it will be useful for someone someday :-)

0

精彩评论

暂无评论...
验证码 换一张
取 消