odoo17 windows server布署错误分析
错误代码:
File "C:\od172406\odoo\sql_db.py", line 681, in borrow
result = psycopg2.connect(
^^^^^^^^^^^^^^^^^
File "C:\od172406\venv\Lib\site-packages\psycopg2\init.py", line 122, in connect
conn = _connect(dsn, connection_factory=connection_factory, **kwasync)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
UnicodeDecodeError: 'utf-8' codec can't decode byte 0xd6 in position 61: invalid continuation byte
重新安装pip install psycopg2==2.9.9最新版,问题依旧
错误发生在psycopg2连接数据库时,可能是由于数据库连接字符串(DSN)中包含非UTF-8字符。
在Odoo中,数据库连接参数通常存储在配置文件(如odoo.conf)中。错误信息中提到的位置61(position 61)的字节0xd6,可能是一个非UTF-8字符(比如可能是某种单字节编码中的特殊字符,但在UTF-8中被错误解释)。
可能的原因:
-
配置文件中数据库连接参数(如密码)包含非ASCII字符,并且没有正确编码。
-
系统环境变量(如果有的话)包含非UTF-8字符。
解决方法:
1. 检查配置文件中的特殊字符(关键步骤)
-
打开 Odoo 配置文件(如
odoo.conf
),检查以下参数是否包含 中文、特殊符号或非 ASCII 字符:-
db_password
(最常见问题来源) -
db_user
-
db_name
-
-
示例 :如果密码是
密码123@
,其中的中文必须移除或替换为 ASCII 字符(如英文/数字)。
2. 修改数据库密码为纯 ASCII 字符
-
连接到 PostgreSQL 数据库,执行以下命令重置用户密码:
sql
ALTER USER odoo_user WITH PASSWORD 'new_ascii_password'; -- 替换为纯英文/数字密码
-
在
odoo.conf
中更新密码:ini
db_password = new_ascii_password
3. 检查配置文件编码格式
- 确保
odoo.conf
文件以 UTF-8 无 BOM 格式保存(使用文本编辑器如 VS Code、Notepad++ 确认并转换)。
4. 清理连接参数中的冗余字符
- 检查连接字符串是否意外包含 不可见字符(如空格、换行符)。手动重写参数值。
5. 验证其他环境变量
-
如果通过环境变量传递数据库参数(如
PGPASSWORD
),确保其中不包含非 UTF-8 字符:set PGPASSWORD=plain_ascii_password # Windows export PGPASSWORD=plain_ascii_password # Linux
6. 临时测试:使用纯 ASCII 参数
-
在
odoo.conf
中使用最简单的 ASCII 参数测试:db_host = localhost db_port = 5432 db_user = odoo db_password = odoo # 确保纯英文/数字
补充说明:
-
根本原因:PostgreSQL 连接参数在解析时要求 UTF-8 编码,而 Odoo 的配置文件或环境变量中的非 ASCII 字符(如中文密码)会导致解码失败。
-
预防措施 :始终使用 英文、数字及常见符号 (如
@#$%^&*
)作为数据库用户名/密码。 -
若问题持续,在
sql_db.py
的borrow()
函数入口处添加调试代码,打印连接字符串(注意安全,勿泄露密码):
可配置文件没动呀,最后发现竟然是,配置没指定。唉。
--config c:\od172406\odjia.conf