无法连接到:localhost:27017:使用AMPPS连接拒绝MongoDB数据库

时间:2016-10-10 09:25:32

标签: mongodb localhost database-connection ubuntu-14.04 ampps

我使用ubuntu 14.04和AMPPS作为本地服务器,我设法启用了mongoDB扩展,并且我已经在rockmongo中创建了数据库和集合,甚至使用mongo使用终端。

但是当我尝试在我的代码中使用mongodb时,我收到以下错误消息:

( ! ) Fatal error: Uncaught exception 'MongoConnectionException' with message 'Failed to connect to: localhost:27017: Connection refused' in /usr/local/ampps/www/TMongo.php on line 3
( ! ) MongoConnectionException: Failed to connect to: localhost:27017: Connection refused in /usr/local/ampps/www/TMongo.php on line 3

这是我尝试测试mongodb的代码的和平:

<?php
   // connect to mongodb
   $m = new MongoClient();
   echo "Connection to database successfully";

   // select a database
   $db = $m->laravel;
   echo "Database mydb selected";
   $collection = $db->laravel;
   echo "Collection selected succsessfully";

   $cursor = $collection->find();
   // iterate cursor to display title of documents

   foreach ($cursor as $document) {
      echo $document["title"] . "\n";
   }
?>

我已经搜索并尝试了一些方法来杀死所有mongodb进程然后再次启动...但是它们都没有为我工作。

我跑的时候:ps -eF | grep 'mongo\|PID' 我明白了:

UID        PID  PPID  C    SZ   RSS PSR STIME TTY          TIME CMD
root      3516  3331  0 223796 118188 3 12:42 pts/22   00:00:01 /usr/local/ampps/mongodb/bin/mongod --journal --pidfilepath=/usr/local/ampps/mongodb/data/pid --config=/usr/local/ampps/mongodb/mongo.conf
server    7091 25150  0  2939  2280   2 12:47 pts/26   00:00:00 grep --color=auto mongo\|PID

当我跑步时:sudo killall -15 mongod然后我再次按照命令运行:

UID        PID  PPID  C    SZ   RSS PSR STIME TTY          TIME CMD
server    8299 25150  0  2939  2268   3 12:49 pts/26   00:00:00 grep --color=auto mongo\|PID

当我的mongodb服务关闭时运行此命令时:sudo netstat -tlnp | grep 27017 我什么都没得到,但是当我启动mongodb服务时,我再次运行netstat命令:

tcp        0      0 0.0.0.0:27017           0.0.0.0:*               LISTEN      9956/mongod   

mongodb.conf:

#Turn on simple rest api
rest=true

journal=true

#Storage Engine Set to mmapv1
storageEngine=mmapv1

#Directory for Data Files
dbpath={$path}/mongodb/data/db

#log file to send write to instead of stdout - has to be a file, not directory
logpath={$path}/mongodb/logs/mongo.log

#Append to logpath instead of over-writing
logappend=true

#Specify port number
#port=27017

#Full path to pidfile (if not set, no pidfile is created)
pidfilepath={$path}/mongodb/data/pid

#Each database will be stored in a separate directory
directoryperdb=true

#Run "{$path}/mongodb/bin/mongod.exe" --help in command prompt for more help.

仅供参考:我已经安装了它的默认路径:/ usr / local / ampps /

我使用ubuntu 14.04和AMPPS 3.6 for localserver。 我怎么解决这个问题,有什么建议吗?

更新 我已将此参数添加到mongodb.conf文件并重新启动mongodb

bind_ip = 127.0.0.1

然后我运行:sudo netstat -tlnp | grep 27017

似乎mongodb正在监听127.0.0.1:27017当我尝试使用mongo从命令行连接到它时,它可以工作,但在php页面中我仍然有同样的问题。

任何建议?

1 个答案:

答案 0 :(得分:0)

在功放3.6中,他们将mongodb.so添加到php扩展列表中。 如果您启用mongo和mongodb扩展,您将连接到mongodb。