3

lxc コンテナー内の ubuntu 12.04 に openerp 7 をインストールしようとしています。db サーバーはホスト マシン上にあります。すべてが正常に機能しましたが、初めて Web クライアントにアクセスしようとすると、ブラウザー (ターミナルでも) で、openerp が db サーバーに接続できないというエラーが表示されます。ここに私のopenerp-server.confファイルがあります:

[options]
; This is the password that allows database operations:
; admin_passwd = admin
debug_mode = True
db_host = '10.0.3.1'
db_port = 5432
db_user = openerp
db_password = openerp
db_name = openerp
logfile = /var/log/openerp/openerp-server.log

私も試してみました

db_host = 10.0.3.1

サーバーを起動すると、次の情報メッセージが表示されました。

2013-01-08 22:46:39,688 654 INFO ? openerp: OpenERP version 7.0-20130106-001538
2013-01-08 22:46:39,688 654 INFO ? openerp: addons paths: /opt/openerp/server/openerp/addons
2013-01-08 22:46:39,688 654 INFO ? openerp: database hostname: localhost
2013-01-08 22:46:39,688 654 INFO ? openerp: database port: 5432
2013-01-08 22:46:39,688 654 INFO ? openerp: database user: openerp
2013-01-08 22:46:40,106 654 INFO ? openerp.service.wsgi_server: HTTP service (werkzeug) running on 0.0.0.0:8069
2013-01-08 22:46:40,106 654 INFO ? openerp: OpenERP server is running, waiting for connections...

ログ ファイルには 777 のアクセス許可があり、空です。これは、ブラウザーから openerp にアクセスしようとしたときのエラーの一部です。

ERROR postgres openerp.sql_db: Connection to the database failed
Traceback (most recent call last):
  File "/opt/openerp/server/openerp/sql_db.py", line 433, in borrow
    result = psycopg2.connect(dsn=dsn, connection_factory=PsycoConnection)
  File "/usr/lib/python2.7/dist-packages/psycopg2/__init__.py", line 179, in connect
    connection_factory=connection_factory, async=async)
OperationalError: could not connect to server: No such file or directory
    Is the server running locally and accepting
    connections on Unix domain socket "/var/run/postgresql/.s.PGSQL.5432"?

2013-01-08 22:48:21,553 654 ERROR postgres openerp.netsvc: could not connect to server: No such file or directory
    Is the server running locally and accepting
    connections on Unix domain socket "/var/run/postgresql/.s.PGSQL.5432"?
Traceback (most recent call last):
  File "/opt/openerp/server/openerp/netsvc.py", line 289, in dispatch_rpc
    result = ExportService.getService(service_name).dispatch(method, params)
  File "/opt/openerp/server/openerp/service/web_services.py", line 122, in dispatch
    return fn(*params)

db サーバーは lxc コンテナーからの接続を受け入れています。これをテストするために小さな python スクリプトを作成しましたが、うまくいきました。

ありがとうございました

4

3 に答える 3

4

出力の 3 行目は、OpenERP が でデータベース サーバーを探していることを示していますlocalhost。OE が設定ファイルを認識していないと推測しています。簡単なテストとして、次のような方法で OE を手動で実行できます。

/usr/local/bin/openerp-server --conf /path/to/config_file

それが機能するかどうかを確認します。その場合は、適切な起動スクリプトを見つけて、構成ファイルとログ ファイルのパラメーターで調整します。

于 2013-01-08T23:57:33.557 に答える
2

私は最近 OpenERP v7.0 をインストールしました。このブログはとても役に立ちます。Ubuntu に OpenERP 7.0 をインストールするを参照してください

これがあなたを助けることを願っています。

于 2013-01-09T06:05:21.077 に答える
0

このファイルを変更して、同じ問題を解決しました。

/usr/lib/python2.6/site-packages/openerp-7.0_20130211_002141-py2.6.egg/openerp/tools/config.py

そこにはセクションがあります:

    if self.options['db_password']:
        if sys.platform == 'win32' and not self.options['db_host']:
            self.options['db_host'] = 'localhost'
        #if self.options['db_host']:
        #    self._generate_pgpassfile()

    if opt.save:
        self.save()

「if op.save:」の前に次を追加します。

    self.options['db_host'] = '<address_of_db_host>'
于 2013-02-11T10:36:17.803 に答える