- Subscribe to RSS Feed
- Mark Question as New
- Mark Question as Read
- Float this Question for Current User
- Bookmark
- Subscribe
- Mute
- Printer Friendly Page
Ranger: Access denied for user 'rangeradmin'@'localhost'
- Labels:
-
Apache Ranger
Created 07-27-2017 05:56 AM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
I followed the instructions (https://cwiki.apache.org/confluence/display/RANGER/Ranger+Installation+Guide) to install Ranger admin and usersync for evaluation. Ranger admin UI is up.
Also followed the instructions at https://docs.hortonworks.com/HDPDocuments/HDP2/HDP-2.6.1/bk_security/content/configuring_mysql_for_r... to setup MySQL server and create/grant permissions to necessary users. MySQL is running on the same machine as Ranger admin and usersync.
Granted the same permissions to user rangeradmin as well.
However, I see a flurry of following errors in /usr/local/mysql/data/mysqld.local.err:
2017-07-27T05:50:37.759668Z 1389 [Note] Access denied for user 'rangeradmin'@'localhost' (using password: YES)
2017-07-27T05:50:37.759669Z 1390 [Note] Access denied for user 'rangeradmin'@'localhost' (using password: YES)
2017-07-27T05:50:38.762447Z 1392 [Note] Access denied for user 'rangeradmin'@'localhost' (using password: YES)
[...]
I am able to connect to MySQL as 'rangeradmin' using MySQL's command line client. Not sure why Ranger admin is not able to connect.
Also, I am _not_ able to login to Ranger admin UI. It displays "Unable to connect to DB..." error. Any pointers to debug?
Thanks.
Created 07-29-2017 11:09 PM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Don't worry you can create a new Ranger database as follow change username and password to suit your environment.
mysql -u root -p{rootpassword} CREATE USER 'ranger'@'localhost' IDENTIFIED BY 'ranger_password'; GRANT ALL PRIVILEGES ON *.* TO 'ranger'@'localhost'; GRANT ALL PRIVILEGES ON *.* TO 'ranger'@'rangerDBhost'; GRANT ALL PRIVILEGES ON *.* TO 'ranger'@'%'; GRANT ALL PRIVILEGES ON *.* TO 'ranger'@'localhost' WITH GRANT OPTION; GRANT ALL PRIVILEGES ON *.* TO 'ranger'@'rangerDBhost' IDENTIFIED BY 'ranger' WITH GRANT OPTION; GRANT ALL PRIVILEGES ON *.* TO 'ranger'@'localhost' IDENTIFIED BY 'ranger_password' WITH GRANT OPTION; GRANT ALL PRIVILEGES ON *.* TO 'ranger'@'%' WITH GRANT OPTION; FLUSH PRIVILEGES; # mysql -u ranger -pranger CREATE DATABASE ranger; ################ simpler version ################### create database ranger; create user ranger identified by 'ranger'; grant all on ranger.* to ranger; Flush privileges;
Let me know if that helps
Created 07-27-2017 06:04 AM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Looks like the grant is still not set correctly. Can you please share the output of the following SQL:
# mysql -u rangeradmin -p -h localhost mysql> select user, host from user where user like 'ranger%' ;
.
Or connect to Mysql as root and then run.
mysql> SHOW GRANTS FOR 'rangeradmin'@'localhost'; mysql> GRANT ALL ON *.* TO 'rangeradmin'@'localhost' WITH GRANT OPTION; mysql> FLUSH PRIVILEGES;
.
Created 07-27-2017 06:12 AM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Sure. Please find it below.
mysql> use mysql; Database changed mysql> select user, host from user where user like 'ranger%' ; +-------------+-----------+ | user | host | +-------------+-----------+ | rangeradmin | % | | rangerdba | % | | rangeradmin | localhost | | rangerdba | localhost | +-------------+-----------+ 4 rows in set (0.00 sec)
Created 07-27-2017 06:26 AM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
can you please try following command on your database:
GRANT ALL ON *.* TO 'rangeradmin'@'localhost' identified by "<rangeradmin_password>" WITH GRANT OPTION;
flush privileges;
and then restart the ranger
Note: another thing it is better to provide root credentials , then at the time of installation it will connect through root and will take care of doing creation of rangeradmin database and configuring it
Created 07-27-2017 08:57 AM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Thanks @Deepak Sharma. Followed the steps, however, still getting "Access denied" error.
Created 07-27-2017 11:43 AM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
did you replace the correct password and host in the command?
Created 07-29-2017 11:15 AM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
@Deepak Sharma, yes I did. Is there anything else I need to try out?
Created 07-27-2017 03:34 PM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Just run this it should work while logged on as root MySQL,make sure you are connected to the ranger database
grant all on rangeradmin.* to ranger; Flush privileges;
Created 07-29-2017 11:16 AM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Thanks @Geoffrey Shelton Okot, but its failing in spite of this
Created 07-29-2017 11:09 PM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Don't worry you can create a new Ranger database as follow change username and password to suit your environment.
mysql -u root -p{rootpassword} CREATE USER 'ranger'@'localhost' IDENTIFIED BY 'ranger_password'; GRANT ALL PRIVILEGES ON *.* TO 'ranger'@'localhost'; GRANT ALL PRIVILEGES ON *.* TO 'ranger'@'rangerDBhost'; GRANT ALL PRIVILEGES ON *.* TO 'ranger'@'%'; GRANT ALL PRIVILEGES ON *.* TO 'ranger'@'localhost' WITH GRANT OPTION; GRANT ALL PRIVILEGES ON *.* TO 'ranger'@'rangerDBhost' IDENTIFIED BY 'ranger' WITH GRANT OPTION; GRANT ALL PRIVILEGES ON *.* TO 'ranger'@'localhost' IDENTIFIED BY 'ranger_password' WITH GRANT OPTION; GRANT ALL PRIVILEGES ON *.* TO 'ranger'@'%' WITH GRANT OPTION; FLUSH PRIVILEGES; # mysql -u ranger -pranger CREATE DATABASE ranger; ################ simpler version ################### create database ranger; create user ranger identified by 'ranger'; grant all on ranger.* to ranger; Flush privileges;
Let me know if that helps