CouchDB更改数据库目录

时间:2015-02-05 18:36:29

标签: linux sockets couchdb

我正在尝试更改沙发数据库的目录。我使用python脚本将csv文件导入CouchDB。脚本运行正常。这是以下情况:

from couchdbkit import Server, Database
from couchdbkit.loaders import FileSystemDocsLoader
from csv import DictReader
import sys, subprocess, math, os

def parseDoc(doc):
    for k,v in doc.items():
        if (isinstance(v,str)):
            #print k, v, v.isdigit()
            # #see if this string is really an int or a float
            if v.isdigit()==True: #int
                doc[k] = int(v)
            else: #try a float
                try:
                    if math.isnan(float(v))==False:
                        doc[k] = float(v) 
                except:
                    pass            
    return doc

def upload(db, docs):
    db.bulk_save(docs)
    del docs
    return list()

def uploadFile(fname, dbname):
  #connect to the db
  theServer = Server()
  db = theServer.get_or_create_db(dbname)

  #loop on file for upload
  reader = DictReader(open(fname, 'rU'), dialect = 'excel')

  docs = list()
  checkpoint = 100
  i = 0
  for doc in reader:
    newdoc = parseDoc(doc) 
    docs.append(newdoc)

    if len(docs)%checkpoint==0:
      docs = upload(db,docs)
      i += 1
      print 'Number : %d' %i

  #don't forget the last batch        
  docs = upload(db,docs)

if __name__=='__main__':
  x = '/media/volume1/Crimes_-_2001_to_present.csv'
  filename = x
  dbname = 'test'
  uploadFile(filename, dbname)

我看到很多关于如何更改目录以附加数据库的帖子。如果我按原样保留/etc/couchdb/local.ini(安装后的原始文件),则脚本会将数据附加到缺省目录/var/lib/couchdb/1.0.1/。当我修改local.ini以将数据库存储到另一个磁盘时:

  

database_dir = / media / volume1   view_index_dir = / media / volume1

在重新启动CouchDB服务后,我收到此错误:

  

restkit.errors.RequestError:socket.error:[Errno 111]拒绝连接

我检查了打开的套接字(couchdb默认使用5984)并且没有打开。但是当我启动CouchDB服务时,我没有遇到任何错误。 任何想法如何解决它?

1 个答案:

答案 0 :(得分:0)

我认为错误可能是由于您更改了Local.ini中的目录位置,但是当您尝试与现有数据库建立新连接时,它无法在那里找到它。

因此,将database_name.couch文件移动到可以放在local.ini中的新位置,然后尝试建立连接。我认为这应该有用。