我正在使用 Django frameowrk。我的客户端在 js 中,后端使用 mongodb。两天前,我停止并重新启动了 Apache2 服务器,网站运行正常。今天网站突然显示 500 Internel serve error。当我检查 error.log 文件时,它显示:
[.....] ConnectionError: Cannot connect to the database:
[.....] could not connect to localhost:27017: [Errno 111] Connection refused
因此,我尝试通过 python 测试与 mongodb 的连接,如下所示:
>>> from pymongo import Connection
>>> connection = Connection('localhost',27017)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/local/lib/python2.6/dist-packages/pymongo/connection.py", line 381, in __init__
self.__find_node()
File "/usr/local/lib/python2.6/dist-packages/pymongo/connection.py", line 659, in __find_node
raise AutoReconnect(', '.join(errors))
pymongo.errors.AutoReconnect: could not connect to localhost:27017: [Errno 111] Connection refused
我还使用 $mongo 测试了连接,它显示:
MongoDB shell version: 2.4.9
connecting to: test
Mon Jan 20 15:22:53.729 Error: couldn't connect to server 127.0.0.1:27017 at src/mongo/shell/mongo.js:145
exception: connect failed
我试着寻找这个问题的答案,我看到有人告诉我要删除 mongod.lock 文件并像这里一样重新启动 mongodb Pymongo keeps refusing the connection at 27017和 MongoDB won't start after server crash但这里写着:http://docs.mongodb.org/manual/tutorial/recover-data-following-unexpected-shutdown/ 在正常操作中,永远不要删除 mongod.lock 文件并启动 mongod。而是考虑使用上述方法之一来恢复数据库并删除锁定文件。在可怕的情况下,您可以删除锁定文件,并使用可能损坏的文件启动数据库,并尝试从数据库中恢复数据;然而,在这些情况下预测数据库的状态是不可能的。 我真的很困惑该怎么办?我是否应该删除 mongod.lock 文件?另外,我是否需要先启动mongodb服务器,然后再启动apache2服务器? Mongodb 日志文件显示:
tail -n -30 mongodb.log
***** SERVER RESTARTED *****
Mon Jan 20 15:10:19.740 [initandlisten] MongoDB starting : pid=8061 port=27017 dbpath=/var/lib/mongodb 64-bit host=hand
Mon Jan 20 15:10:19.740 [initandlisten] db version v2.4.9
Mon Jan 20 15:10:19.740 [initandlisten] git version: xxxxx //gives the number
Mon Jan 20 15:10:19.740 [initandlisten] build info: xxxx
Mon Jan 20 15:10:19.740 [initandlisten] allocator: tcmalloc
Mon Jan 20 15:10:19.740 [initandlisten] options: { config: "/etc/mongodb.conf", dbpath: "/var/lib/mongodb", logappend: "true", logpath: "/var/log/mongodb/mongodb.log" }
Mon Jan 20 15:10:19.742 [initandlisten] journal dir=/var/lib/mongodb/journal
Mon Jan 20 15:10:19.742 [initandlisten] recover : no journal files present, no recovery needed
Mon Jan 20 15:10:19.742 [initandlisten]
Mon Jan 20 15:10:19.742 [initandlisten] ERROR: Insufficient free space for journal files
Mon Jan 20 15:10:19.742 [initandlisten] Please make at least 3379MB available in /var/lib/mongodb/journal or use --smallfiles
Mon Jan 20 15:10:19.742 [initandlisten]
Mon Jan 20 15:10:19.743 [initandlisten] exception in initAndListen: 15926 Insufficient free space for journals, terminating
Mon Jan 20 15:10:19.743 dbexit:
Mon Jan 20 15:10:19.743 [initandlisten] shutdown: going to close listening sockets...
Mon Jan 20 15:10:19.743 [initandlisten] shutdown: going to flush diaglog...
Mon Jan 20 15:10:19.743 [initandlisten] shutdown: going to close sockets...
Mon Jan 20 15:10:19.743 [initandlisten] shutdown: waiting for fs preallocator...
Mon Jan 20 15:10:19.743 [initandlisten] shutdown: lock for final commit...
Mon Jan 20 15:10:19.743 [initandlisten] shutdown: final commit...
Mon Jan 20 15:10:19.743 [initandlisten] shutdown: closing all files...
Mon Jan 20 15:10:19.743 [initandlisten] closeAllFiles() finished
Mon Jan 20 15:10:19.743 [initandlisten] journalCleanup...
Mon Jan 20 15:10:19.743 [initandlisten] removeJournalFiles
Mon Jan 20 15:10:19.743 [initandlisten] shutdown: removing fs lock...
Mon Jan 20 15:10:19.743 dbexit: really exiting now
如果我运行以下命令,它会显示:
$ sudo service mongodb start
Starting database: mongodb failed!
最佳答案
好吧,错误消息很清楚:您没有足够的可用磁盘空间:
ERROR: Insufficient free space for journal files
Please make at least 3379MB available in
/var/lib/mongodb/journal or use --smallfiles
exception in initAndListen: 15926 Insufficient free space for journals, terminating
通常,MongoDB 对磁盘空间相当贪婪。特别是,恢复和压缩使用相当多的磁盘,因为它复制它处理的数据文件。确保您总是有一些空闲的演出。
关于django - Mongodb 服务器未启动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21235368/
我正在尝试使用ruby和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我
我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..
最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru
在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo
我想在Ruby中创建一个用于开发目的的极其简单的Web服务器(不,不想使用现成的解决方案)。代码如下:#!/usr/bin/rubyrequire'socket'server=TCPServer.new('127.0.0.1',8080)whileconnection=server.acceptheaders=[]length=0whileline=connection.getsheaders想法是从命令行运行这个脚本,提供另一个脚本,它将在其标准输入上获取请求,并在其标准输出上返回完整的响应。到目前为止一切顺利,但事实证明这真的很脆弱,因为它在第二个请求上中断并出现错误:/usr/b
您如何在Rails中的实时服务器上进行有效调试,无论是在测试版/生产服务器上?我试过直接在服务器上修改文件,然后重启应用,但是修改好像没有生效,或者需要很长时间(缓存?)我也试过在本地做“脚本/服务器生产”,但是那很慢另一种选择是编码和部署,但效率很低。有人对他们如何有效地做到这一点有任何见解吗? 最佳答案 我会回答你的问题,即使我不同意这种热修补服务器代码的方式:)首先,你真的确定你已经重启了服务器吗?您可以通过跟踪日志文件来检查它。您更改的代码显示的View可能会被缓存。缓存页面位于tmp/cache文件夹下。您可以尝试手动删除
一、引擎主循环UE版本:4.27一、引擎主循环的位置:Launch.cpp:GuardedMain函数二、、GuardedMain函数执行逻辑:1、EnginePreInit:加载大多数模块int32ErrorLevel=EnginePreInit(CmdLine);PreInit模块加载顺序:模块加载过程:(1)注册模块中定义的UObject,同时为每个类构造一个类默认对象(CDO,记录类的默认状态,作为模板用于子类实例创建)(2)调用模块的StartUpModule方法2、FEngineLoop::Init()1、检查Engine的配置文件找出使用了哪一个GameEngine类(UGame
require"socket"server="irc.rizon.net"port="6667"nick="RubyIRCBot"channel="#0x40"s=TCPSocket.open(server,port)s.print("USERTesting",0)s.print("NICK#{nick}",0)s.print("JOIN#{channel}",0)这个IRC机器人没有连接到IRC服务器,我做错了什么? 最佳答案 失败并显示此消息::irc.shakeababy.net461*USER:Notenoughparame
我有一个使用PDFKit呈现网页的pdf版本的Rails应用程序。我使用Thin作为开发服务器。问题是当我处于开发模式时。当我使用“bundleexecrailss”启动我的服务器并尝试呈现任何PDF时,整个过程会陷入僵局,因为当您呈现PDF时,会向服务器请求一些额外的资源,如图像和css,看起来只有一个线程.如何配置Rails开发服务器以运行多个工作线程?非常感谢。 最佳答案 我找到的最简单的解决方案是unicorn.geminstallunicorn创建一个unicorn.conf:worker_processes3然后使用它:
关于如何使用git设置类似Dropbox的服务,您有什么建议吗?您认为git是解决此问题的合适工具吗?我在考虑使用git+rush解决方案,你觉得怎么样? 最佳答案 检查这个开源项目:https://github.com/hbons/SparkleShare来自项目的自述文件:Howdoesitwork?SparkleSharecreatesaspecialfolderonyourcomputer.Youcanaddremotelyhostedfolders(or"projects")tothisfolder.Theseprojec