• 版块
  • 标签
  • 热门
  • 用户
  • 群组
Skins
  • Light
  • Default
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Quartz
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Slate
  • Solar
  • Superhero
  • Vapor
Collapse

Odoo 中文社区

Linux 下使用supervisor管理源码启动的openerp

已定时 已固定 已锁定 已移动 Odoo 安装指南
9 帖子 4 发布者 12580 浏览
    • 从旧到新
    • 从新到旧
    • 最多赞同
回复
  • 在新帖中回复
登录后回复
此主题已被删除。只有拥有主题管理权限的用户可以查看。
  • W 离线
    W 离线
    wangbuke
    写于 最后由 编辑
    #1

    从源码启动openerp,简单的做法是添加启动脚本到/etc/init.d/rc.local等,让openerp 随系统启动而运行。此类方法只在系统启动时运行,但万一程序在运行中崩溃,您可能要等到用户发现不能使用了,才去重启服务器。下面请出今天的主角: supervisor  (http://supervisord.org/)

        Supervisor 是什么?

        Supervisor is a client/server system that allows its users to monitor and control a number of processes on UNIX-like operating systems.
        Supervisor 是一个客户端/服务器系统,允许用户监控和控制类 Unix 操作系统上的进程数。

    1、安装

    debian/ubuntu

    <br />apt-get install supervisor<br />
    



    redhat/centos

    <br />yum install supervisor<br />
    



    2、建立openerp 的配置文件

    <br /># touch /etc/supervisor/conf.d/openerp.conf<br /># vi /etc/supervisor/conf.d/openerp.conf<br />
    



    openerp.conf 内容

    <br />[program:openerp]<br />; openerp 启动脚本<br />command=python /var/www/openerp-6.1-1/openerp-server -c /var/www/openerp-6.1-1/openerp-server.conf<br />; openerp 目录<br />directory=/var/www/openerp-6.1-1/<br />; 是否随系统启动<br />autostart=true<br />; 自动重启<br />autorestart=true<br />; 启动时间,如果超过这个时间oe还没有挂,则视为已经启动<br />startsecs=3<br />; 启动用户<br />user=www-data<br />redirect_stderr=true<br />; log 文件<br />stdout_logfile=/var/www/openerp-6.1-1/openerp-server.log<br />stdout_logfile_maxbytes=500MB<br />stdout_logfile_backups=50<br />stdout_capture_maxbytes=1MB<br />stdout_events_enabled=false<br />loglevel=warn<br />
    



    3、完成!重启系统试试看openerp 是否已经启动。也可以想办法把openerp 搞崩溃,试试supervisor 能不能及时将openerp 重启

    4、常用命令

    <br /># supervisorctl<br />openerp&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; RUNNING&nbsp; &nbsp; pid 9454, uptime 4:43:34<br />supervisor&gt; start openerp&nbsp; #启动<br />supervisor&gt; stop openerp&nbsp;  #停止<br />	supervisor&gt; restart openerp #重启<br />	supervisor&gt; status openerp #查看状态<br />
    
    1 条回复 最后回复
    0
  • digitalsatoriD 离线
    digitalsatoriD 离线
    digitalsatori 管理员
    写于 最后由 编辑
    #2

    感谢 wangbuke,

    supervisor确实是好东西,我们公司之前的trac项目管理平台就是用supervisor部署的。感觉非常灵活好用。
    另外技术八卦一下,supervisor的开发团队和pyramid框架的团队是一波人,属于牛人作品,不错。

    【上海先安科技】(tony AT openerp.cn)

    1 条回复 最后回复
    0
  • mrshellyM 离线
    mrshellyM 离线
    mrshelly
    写于 最后由 编辑
    #3

    不错.... 收藏....

    1 条回复 最后回复
    0
  • 莱 离线
    莱 离线
    莱芜-r
    写于 最后由 编辑
    #4

    按照楼主的教程,尝试着用supervisor来启动odoo,status总显示这个错误:
    FATAL Exited too quickly (process log may have details)
    这个要怎么搞呢,是不是odoo的配置还要做什么更改,求正确的方法

    odoo8                            BACKOFF    Exited too quickly (process log may have details)
    supervisor> status
    odoo8                            STARTING 
    supervisor> status
    odoo8                            FATAL      Exited too quickly (process log may have details)
    -------------------------------------------
    我的odoo8的目录在cd /sdyun/odoo/server/odoo8
    odoo用户下用这个命令启动时没有问题的:

    $ python /sdyun/odoo/server/odoo8/openerp-server -c odoo8.conf
    


    supervisord中关于odoo的配置

    <br />command=/usr/local/bin/python /sdyun/odoo/server/odoo8/openerp-server -c /sdyun/<br />odoo/server/odoo8/odoo8.conf<br />; openerp 目录<br />directory=/sdyun/odoo/server/odoo8/<br />
    


    与楼主不同的是直接python 提示找不到 python 我加了/usr/local/bin/python 其他的一样

    ---------------------------------------log----------------------------------------------

    Traceback (most recent call last):<br />&nbsp; File &quot;/sdyun/odoo/server/odoo8/openerp-server&quot;, line 5, in &lt;module&gt;<br />&nbsp; &nbsp; openerp.cli.main()<br />&nbsp; File &quot;/sdyun/odoo/server/odoo8/openerp/cli/__init__.py&quot;, line 68, in main<br />&nbsp; &nbsp; o.run(args)<br />&nbsp; File &quot;/sdyun/odoo/server/odoo8/openerp/cli/server.py&quot;, line 180, in run<br />&nbsp; &nbsp; main(args)<br />&nbsp; File &quot;/sdyun/odoo/server/odoo8/openerp/cli/server.py&quot;, line 140, in main<br />&nbsp; &nbsp; openerp.tools.config.parse_config(args)<br />&nbsp; File &quot;/sdyun/odoo/server/odoo8/openerp/tools/config.py&quot;, line 360, in parse_co<br />nfig<br />&nbsp; &nbsp; openerp.modules.module.initialize_sys_path()<br />&nbsp; File &quot;/sdyun/odoo/server/odoo8/openerp/modules/module.py&quot;, line 96, in initial<br />ize_sys_path<br />&nbsp; &nbsp; dd = tools.config.addons_data_dir<br />&nbsp; File &quot;/sdyun/odoo/server/odoo8/openerp/tools/config.py&quot;, line 685, in addons_d<br />ata_dir<br />&nbsp; &nbsp; os.makedirs(d, 0700)<br />&nbsp; File &quot;/usr/local/lib/python2.7/os.py&quot;, line 150, in makedirs<br />&nbsp; &nbsp; makedirs(head, mode)<br />&nbsp; File &quot;/usr/local/lib/python2.7/os.py&quot;, line 150, in makedirs<br />&nbsp; &nbsp; makedirs(head, mode)<br />:<br />OSError: [Errno 13] Permission denied: &#039;/.local&#039;Traceback (most recent call last):<br />&nbsp; File &quot;/sdyun/odoo/server/odoo8/openerp-server&quot;, line 5, in &lt;module&gt;<br />&nbsp; &nbsp; openerp.cli.main()<br />&nbsp; File &quot;/sdyun/odoo/server/odoo8/openerp/cli/__init__.py&quot;, line 68, in main<br />&nbsp; &nbsp; o.run(args)<br />&nbsp; File &quot;/sdyun/odoo/server/odoo8/openerp/cli/server.py&quot;, line 180, in run<br />&nbsp; &nbsp; main(args)<br />&nbsp; File &quot;/sdyun/odoo/server/odoo8/openerp/cli/server.py&quot;, line 140, in main<br />&nbsp; &nbsp; openerp.tools.config.parse_config(args)<br />&nbsp; File &quot;/sdyun/odoo/server/odoo8/openerp/tools/config.py&quot;, line 360, in parse_config<br />&nbsp; &nbsp; openerp.modules.module.initialize_sys_path()<br />&nbsp; File &quot;/sdyun/odoo/server/odoo8/openerp/modules/module.py&quot;, line 96, in initialize_sys_path<br />&nbsp; &nbsp; dd = tools.config.addons_data_dir<br />&nbsp; File &quot;/sdyun/odoo/server/odoo8/openerp/tools/config.py&quot;, line 685, in addons_data_dir<br />&nbsp; &nbsp; os.makedirs(d, 0700)<br />&nbsp; File &quot;/usr/local/lib/python2.7/os.py&quot;, line 150, in makedirs<br />&nbsp; &nbsp; makedirs(head, mode)<br />&nbsp; File &quot;/usr/local/lib/python2.7/os.py&quot;, line 150, in makedirs
    


    ------------------log--------------------

    ------------------------------
    用楼下的办法成功解决

    <br />environment=HOME=&quot;/home/YourName&quot;,USER=&quot;YourName&quot;<br />
    


    然后
    配置文件中user的那一行不能漏掉
    我这里的环境配置是:

    <br />[program:odoo8]<br />; openerp 启动脚本<br />command=/usr/local/bin/python /sdyun/odoo/server/odoo8/openerp-server -c /sdyun/<br />odoo/server/odoo8/odoo8.conf<br />; openerp 目录<br />directory=/sdyun/odoo/server/odoo8/<br />; 是否随系统启动<br />autostart=true<br />; 自动重启<br />autorestart=true<br />; 启动时间,如果超过这个时间oe还没有挂,则视为已经启动<br />startsecs=30<br />; 启动用户<br />environment=HOME=&quot;/sdyun/odoo&quot;,USER=&quot;odoo&quot;<br />user=odoo<br />redirect_stderr=true<br />; log 文件<br />stdout_logfile=/var/log/supervisord/odoo/odoo8/openerp-server.log<br />stdout_logfile_maxbytes=500MB<br />stdout_logfile_backups=50<br />stdout_capture_maxbytes=1MB<br />stdout_events_enabled=false<br />loglevel=warn<br />
    
    1 条回复 最后回复
    0
  • digitalsatoriD 离线
    digitalsatoriD 离线
    digitalsatori 管理员
    写于 最后由 编辑
    #5

    [quote author=mom988 link=topic=4250.msg31934#msg31934 date=1456370417]
    FATAL Exited too quickly (process log may have details)
    这个要怎么搞呢,是不是odoo的配置还要做什么更改

    odoo8                            BACKOFF    Exited too quickly (process log may have details)
    supervisor> status
    odoo8                            STARTING 
    supervisor> status
    odoo8                            FATAL      Exited too quickly (process log may have details)
    [/quote]
    启动没成功。
    你这样问问题,想要别人怎么帮你。而且问问题最好开一个新帖。

    【上海先安科技】(tony AT openerp.cn)

    1 条回复 最后回复
    0
  • 莱 离线
    莱 离线
    莱芜-r
    写于 最后由 编辑
    #6


    [/quote]
    启动没成功。
    你这样问问题,想要别人怎么帮你。而且问问题最好开一个新帖。
    [/quote]
    :D我看这帖子也还没多长,贴在这要是有解决的方法以后我来按着这个做也好把碰到的问题就解决啦

    1 条回复 最后回复
    0
  • digitalsatoriD 离线
    digitalsatoriD 离线
    digitalsatori 管理员
    写于 最后由 编辑
    #7

    @mom988 这样提问题就对了嘛 😉


    从你的错误log里看,这句是关键:

    <br />OSError: [Errno 13] Permission denied: &#039;/.local&#039;Traceback (most recent call last):<br />
    




    Odoo在启动过程中需要检查一个data目录,其中用来保存Odoo用户的附件文档,Session数据,以及通过网络安装的模块。
    它一般保存在启动Odoo的用户的HOME目录的.local目录下


    当用supervisor来启动Odoo时,因为supervisorsd是由root用户启动的,所以它只继承了root的环境变量。这样当启动Odoo的时候,Odoo就会试图在/.local下创建data目录时就会遭遇‘Permission Denied' 权限错误,因为Odoo并不是root的启动的,该用户是没有在/上创建目录权限。


    解决的办法是,在supervisor配置文件中设置环境变量,比如:
    [font=Consolas][/font]

    environment=HOME=&quot;/home/YourName&quot;,USER=&quot;YourName&quot;
    

    [font=Consolas][/font]

    【上海先安科技】(tony AT openerp.cn)

    1 条回复 最后回复
    0
  • 莱 离线
    莱 离线
    莱芜-r
    写于 最后由 编辑
    #8

    [quote author=digitalsatori link=topic=4250.msg31937#msg31937 date=1456448364]
    @mom988 这样提问题就对了嘛 😉


    从你的错误log里看,这句是关键:
    😉 我去试试,非常感谢,搞定了再来回馈

    1 条回复 最后回复
    0

  • 登录

  • 没有帐号? 注册

  • Login or register to search.
  • 第一个帖子
    最后一个帖子
0
  • 版块
  • 标签
  • 热门
  • 用户
  • 群组
  • 登录

  • 没有帐号? 注册

  • Login or register to search.