Skip to main content

com.mongodb.MongoCommandException: Command failed with error 18: 'Authentication failed.' on server

If you are trying to connect Mongo DB Server and it insanely throwing following error.

com.mongodb.MongoTimeoutException: Timed out after 1000 ms while waiting for a server that matches ReadPreferenceServerSelector{readPreference=primary}. Client view of cluster state is {type=UNKNOWN, servers=[{address=192.168.1.10:27010, type=UNKNOWN, state=CONNECTING, exception={com.mongodb.MongoSecurityException: Exception authenticating MongoCredential{mechanism=null, userName='user123', source='admin', password=<hidden>, mechanismProperties={}}}, caused by {com.mongodb.MongoCommandException: Command failed with error 18: 'Authentication failed.' on server 192.168.1.10:27010. The full response is { "ok" : 0.0, "code" : 18, "errmsg" : "Authentication failed." }}}]





If you start looking the error content First you encounter with Timeout Exception which may mislead you. It is basically an authentication error.

In mongo db at the time of creation db authentication does not affect it create connections anyway. When you start any command it will throw exception if authentication failed [As you can see in debug mode of your IDE, the exception does not throw in connection creation line but in line of  a command execution].

Solution:
if you are using following  uri.

mongodb://user_name:password@<server ip>:<port>/socketTimeoutMS=1000

then append one more parameter

 mongodb://user_name:password@<server ip>:<port>/socketTimeoutMS=1000&authSource=db_name

because  may user_name and password is for only a single db.

Sample data for a uri:
user_name = user123
password = pass!123
server = 192.168.1.10
prort = 27017
db name = my_db
The following uri shoud be used for the above critera.
 mongodb://user123:pass!123@192.168.1.10:27017/socketTimeoutMS=1000&authSource=my_db





To get connected from terminal use following command:
~$:mongo -u user123 --authenticationDatabase my_db -p pass!123 192.168.1.100:27017/my_db

Yes! you have to use db_name twice.



Comments

  1. Heya¡­my very first comment on your site. ,I have been reading your blog for a while and thought I would completely pop in and drop a friendly note. . It is great stuff indeed. I also wanted to ask..is there a way to subscribe to your site via email?


    MongoDB Training in Chennai


    ReplyDelete
    Replies
    1. Hi Yash, You are most most welcome at blog and thank you for giving the idea to add option to subscribe. I added the a box just above the Archive, You can put eamil id and submit.

      Delete
  2. This comment has been removed by the author.

    ReplyDelete

Post a Comment

Popular posts from this blog

How to Create a Namespace in Aerospike Database

                      T his post is about creating a namespace in Aerospike. I could not find any concrete method to create a namespace like create database in MySQL and MongoDB. So I am suggesting a way to create a namespace in Aerospike Database. Step-1: Locate config file aerospike.conf and open it in your favorite editor and make sure you have permission to modify the file. In my system the path of file /etc/aerospike/aerospike.conf (Default in Ubuntu). Here the content of the file. # Aerospike database configuration file. service { user root group root paxos-single-replica-limit 1 # Number of nodes where the replica pidfile /var/run/aerospike/asd.pid service-threads 4 transaction-queues 4 transaction-threads-per-queue 4 proto-fd-max 15000 } logging { # Log file must be an absolute path. file /var/log/aerospike/aerospike.log { context any info } } net...

java.lang.IllegalArgumentException: Could not instantiate implementation: org.janusgraph.diskstorage.cassandra.thrift.CassandraThriftStoreManager

If you are trying to get started with Janus Graph with Apache Cassandra. You may get the following error. Caused by: org.janusgraph.diskstorage.TemporaryBackendException: Temporary failure in storage backend at org.janusgraph.diskstorage.cassandra.thrift.CassandraThriftStoreManager.getCassandraPartitioner(CassandraThriftStoreManager.java:219) ~[janusgraph-cassandra-0.2.0.jar:na] at org.janusgraph.diskstorage.cassandra.thrift.CassandraThriftStoreManager.<init>(CassandraThriftStoreManager.java:198) ~[janusgraph-cassandra-0.2.0.jar:na] ... 48 common frames omitted Caused by: org.apache.thrift.transport.TTransportException: java.net.ConnectException: Connection refused (Connection refused) at org.apache.thrift.transport.TSocket.open(TSocket.java:187) ~[libthrift-0.9.2.jar:0.9.2] at org.apache.thrift.transport.TFramedTransport.open(TFramedTransport.java:81) ~[libthrift-0.9.2.jar:0.9.2] at org.janusgraph.diskstorage.cassandra.thrift.thriftpool.CTConnectionFactory.makeR...