由于MySql登录失败,Trac hotcopy备份失败

时间:2014-11-06 06:16:12

标签: mysql trac

我试图将trac 1.0实例从一台机器移动到另一台机器。我使用了此处描述的Trac备份和还原过程,它使用hotcopy命令。

http://trac.edgewall.org/wiki/TracBackup

然后,我创建了一个新的MySql数据库,为trac添加了新用户,分配了适当的权限,然后运行了tracadmin initenv命令来创建新的trac环境。我使用tracd部署了它,它似乎工作正常。

当我尝试用hotcopy备份的内容替换这个新环境时,当我尝试连接到服务器时出现以下错误....

我错过了一步吗?我已经更改了MySql权限,以确保它们与我在数据库字符串中传递给trac的密码和用户名相匹配。当我复制新环境并且trac使用错误的密码连接到MySql时,是否有可能被覆盖?

非常感谢任何帮助!

Traceback (most recent call last):
  File "build/bdist.linux-x86_64/egg/trac/web/api.py", line 502, in send_error
    data, 'text/html')
  File "build/bdist.linux-x86_64/egg/trac/web/chrome.py", line 955, in render_template
    message = req.session.pop('chrome.%s.%d' % (type_, i))
  File "build/bdist.linux-x86_64/egg/trac/web/api.py", line 304, in __getattr__
    value = self.callbacks[name](self)
  File "build/bdist.linux-x86_64/egg/trac/web/main.py", line 268, in _get_session
    return Session(self.env, req)
  File "build/bdist.linux-x86_64/egg/trac/web/session.py", line 206, in __init__
    self.get_session(sid)
  File "build/bdist.linux-x86_64/egg/trac/web/session.py", line 229, in get_session
    super(Session, self).get_session(sid, authenticated)
  File "build/bdist.linux-x86_64/egg/trac/web/session.py", line 76, in get_session
    with self.env.db_query as db:
  File "build/bdist.linux-x86_64/egg/trac/db/api.py", line 165, in __enter__
    db = DatabaseManager(self.env).get_connection(readonly=True)
  File "build/bdist.linux-x86_64/egg/trac/db/api.py", line 250, in get_connection
    db = self._cnx_pool.get_cnx(self.timeout or None)
  File "build/bdist.linux-x86_64/egg/trac/db/pool.py", line 213, in get_cnx
    return _backend.get_cnx(self._connector, self._kwargs, timeout)
  File "build/bdist.linux-x86_64/egg/trac/db/pool.py", line 134, in get_cnx
    raise TimeoutError(errmsg)
TimeoutError: Unable to get database connection within 0 seconds. (OperationalError: (1045, "Access denied for user 'trac_user'@'localhost' (using password: YES)"))

1 个答案:

答案 0 :(得分:1)

我永远无法获得那些“hotcopy”指令。它们看起来像是用sqlite编写而不是MySQL。当我将Trac实例迁移到新服务器时,我必须执行以下操作才能使数据库正常工作:

# On old server
$ mysqldump -u admin -padmin_password trac >backup.sql

# On new server
$ mysql -u admin -padmin_password
mysql> CREATE DATABASE trac DEFAULT CHARACTER SET utf8 COLLATE utf8_bin;
mysql> GRANT ALL ON trac.* TO trac_account@localhost IDENTIFIED BY 'topsecret';
mysql> exit
$ mysql -u admin -padmin_password trac <backup.sql

将“trac_account”和“topsecret”替换为Trac将使用的用户名和密码。在那之后,我能够让Trac运行起来。从本质上讲,忘记Trac参与并将整个事情视为正常的数据库备份和恢复操作。至于Trac的其余部分,我只是使用导入的数据库在新服务器上创建了一个新的Trac实例,然后根据需要从旧服务器上复制文件(配置文件,附件,自定义模板等)。

注意:如果它是相关的,我的旧安装和新安装使用相同的MySQL数据库凭据进行Trac。如果您正在更改凭据,那么YMMV。