zoukankan      html  css  js  c++  java
  • 在Ubuntu Server 14.04上源码安装Odoo 9.0

    1. 更新Ubuntu服务器软件源

    sudo apt-get update  #更新软件源  
    sudo apt-get dist-upgrade  #更新软件包,自动查找依赖关系  
    sudo shutdown -r now  #重启服务器,以更新改变的内容

    2. 新建系统用户用于运行Odoo程序

    运行如下命令创建系统用户:

    sudo adduser --system --home=/opt/odoo9 --group odoo9  #新建系统用户odoo9,指定home目录为/opt/odoo9

    系统用户不能用于登录并且没有shell,但当需要以它的身份进行特定操作时,可以用su命令切换用户:

    sudo su - odoo9 -s /bin/bash  # 将当前终端登录切换到odoo9用户,并使用/bin/bash这个shell

    命令运行后会自动从当前目录切换到odoo9用户的home目录/opt/odoo9。操作完毕后输入exit命令,离开odoo9用户的shell,回到登录所用的用户。

    3. 安装和配置数据库服务器PostgreSQL

    先运行如下命令查看PostgreSQL数据库的版本:

    psql –version  #查看PostgreSQL版本

    如报错,则表明之前未安装过PostgreSQL,那么可以通过如下命令安装:

    sudo apt-get install postgresql #安装PostgreSQL

    接下来切换到postgres用户,它是PostgreSQL默认的初始用户,以它的身份操作我们就有配置数据库的权限:

    sudo su - postgres

    然后以postgres的身份创建一个新的数据库用户odoo9,Odoo程序将用该用户访问数据库。

    createuser --createdb --username postgres --no-createrole --no-superuser --pwprompt odoo9

    根据系统输入密码,记住你这里设置的密码。最后运行exit退出postgres用户。

    4. 安装Python运行库和wkhtmltopdf

    运行如下命令安装Odoo 9.0版本依赖的python运行库:

    sudo apt-get install python-dateutil python-docutils python-feedparser python-gdata 
    python-jinja2 python-ldap python-libxslt1 python-lxml python-mako python-mock python-openid 
    python-psycopg2 python-psutil python-pybabel python-pychart python-pydot python-pyparsing 
    python-reportlab python-simplejson python-tz python-unittest2 python-vatnumber python-vobject 
    python-webdav python-werkzeug python-xlwt python-yaml python-zsi python-pyPdf 
    python-decorator python-passlib python-requests

    下载安装wkhtmltopdf(Odoo使用wkhtmltopdf来输出pdf):

    sudo wget http://download.gna.org/wkhtmltopdf/0.12/0.12.1/wkhtmltox-0.12.1_linux-trusty-amd64.deb #下载wkhtmltopdf,注意根据操作系统选择相应版本
    sudo dpkg -i wkhtmltox-0.12.1_linux-trusty-amd64.deb  #安装wkhtmltopdf
    sudo cp /usr/local/bin/wkhtmltopdf /usr/bin/wkhtmltopdf  #安装完成后将可执行文件复制到usr/bin中
    sudo chown root:root /usr/bin/wkhtmltopdf  #更改所有者为root用户
    sudo chmod +x /usr/bin/wkhtmltopdf  #并增加可执行属性
    wkhtmltopdf www.baidu.com ~/baidu.pdf  #打印一个网页到home目录,如果成功生成pdf则表明安装成功
    sudo apt-get install ttf-wqy-zenhei  #安装中文字体
    sudo apt-get install ttf-wqy-microhei  #安装中文字体

    5. 安装Odoo服务器代码

    sudo apt-get install git  #安装git软件  
    sudo su - odoo9 -s /bin/bash #切换到odoo9用户  
    git clone -b 9.0 https://github.com/odoo/odoo.git .  #下载Odoo9.0代码  
    exit #退出odoo9用户

    6. 安装nodejs、node-less

    这一步不能忘掉,否则将来登录Odoo帐套时,界面中会有报错信息:Could not execute command lessc

    apt-get install -y npm   
    sudo ln -s /usr/bin/nodejs /usr/bin/node  
    npm install -g less less-plugin-clean-css  
    apt-get install node-less

    7. 配置Odoo程序

    默认的配置文件openerp-server.conf包括基本的设置,这里需要做一点改动。

    sudo cp /opt/odoo9/debian/openerp-server.conf /etc/odoo9-server.conf  #把文件复制到/etc目录  
    sudo chown odoo9: /etc/odoo9-server.conf #将所有权赋予odoo用户和用户组  
    sudo chmod 640 /etc/odoo9-server.conf #只允许odoo用户和root用户读取

    下面用Ubuntu自带的nano编辑器编辑它, 运行如下命令打开配置文件:

    sudo nano /etc/odoo-server.conf

    然后改动如下,
    20151004131118941

    图1 配置文件设置

    配置文件编辑好后,按Ctrl+O,然后回车覆盖保存,然后Ctrl+X退出nano程序。
    配置文件里指定了日志文件的存储位置,因此要创建这个目录,同时还得让它能被odoo9用户读写:

    sudo mkdir /var/log/odoo9  
    sudo chown odoo9:root /var/log/odoo9

    现在可以尝试启动Odoo服务器:

    sudo su - odoo9 -s /bin/bash  #先切换到odoo9用户,
    ./openerp-server -c /etc/odoo9-server.conf #运行Odoo

    在浏览器输入http://ip地址:8069/,因为是全新安装,还未创建过帐套,所以默认会进入数据库管理界面。
    20151004131204580

    图2 数据库管理界面

    如果一切正常,按 Ctrl+C停止服务器,然后用exit命令离开odoo9用户,回到你自己登陆的shell。如果报错,则需要查看odoo-server.log排查错误。(为方便起见,可以先将配置文件中的logfile一行注释掉,这样就可以直接在控制台看到报错信息)

    8. 安装启动脚本

    启动、停止Odoo服务需要多个步骤的操作,比较繁琐,可以安装启动脚本以批处理的方式处理这些步骤。Odoo程序提供了一个现成的脚本openerp-server.init,位于/opt/odoo9/server/install/目录。但需要一点小改动,因为我们不是按odoo的默认安装方式装的。这里有个修改好的脚本文件,下载此脚本拷贝到/etc/init.d/,然后把它改成可执行文件,赋给root用户:

    点击下载odoo9-server.tar
    或者复制以下脚本

    #!/bin/sh
     
    ### BEGIN INIT INFO
    # Provides:             odoo9-server
    # Required-Start:       $remote_fs $syslog
    # Required-Stop:        $remote_fs $syslog
    # Should-Start:         $network
    # Should-Stop:          $network
    # Default-Start:        2 3 4 5
    # Default-Stop:         0 1 6
    # Short-Description:    Complete Business Application software
    # Description:          Odoo is a complete suite of business tools.
    ### END INIT INFO
     
    PATH=/bin:/sbin:/usr/bin
    DAEMON=/opt/odoo9/openerp-server
    NAME=odoo9-server
    DESC=odoo9-server
     
    # Specify the user name (Default: odoo).
    USER=odoo9
     
    # Specify an alternate config file (Default: /etc/odoo-server.conf).
    CONFIGFILE="/etc/odoo9-server.conf"
     
    # pidfile
    PIDFILE=/var/run/$NAME.pid
     
    # Additional options that are passed to the Daemon.
    DAEMON_OPTS="-c $CONFIGFILE"
     
    [ -x $DAEMON ] || exit 0
    [ -f $CONFIGFILE ] || exit 0
     
    checkpid() {
        [ -f $PIDFILE ] || return 1
        pid=`cat $PIDFILE`
        [ -d /proc/$pid ] && return 0
        return 1
    }
     
    case "${1}" in
            start)
                    echo -n "Starting ${DESC}: "
     
                    start-stop-daemon --start --quiet --pidfile ${PIDFILE} 
                            --chuid ${USER} --background --make-pidfile 
                            --exec ${DAEMON} -- ${DAEMON_OPTS}
     
                    echo "${NAME}."
                    ;;
     
            stop)
                    echo -n "Stopping ${DESC}: "
     
                    start-stop-daemon --stop --quiet --pidfile ${PIDFILE} 
                            --oknodo
     
                    echo "${NAME}."
                    ;;
     
            restart|force-reload)
                    echo -n "Restarting ${DESC}: "
     
                    start-stop-daemon --stop --quiet --pidfile ${PIDFILE} 
                            --oknodo
     
                    sleep 1
     
                    start-stop-daemon --start --quiet --pidfile ${PIDFILE} 
                            --chuid ${USER} --background --make-pidfile 
                            --exec ${DAEMON} -- ${DAEMON_OPTS}
     
                    echo "${NAME}."
                    ;;
     
            *)
                    N=/etc/init.d/${NAME}
                    echo "Usage: ${NAME} {start|stop|restart|force-reload}" >&2
                    exit 1
                    ;;
    esac
     
    exit 0
    sudo chmod 755 /etc/init.d/odoo9-server  
    sudo chown root: /etc/init.d/odoo9-server

    要启动Odoo服务器,输入:

    sudo /etc/init.d/odoo9-server start

    这时可以查看日志文件,查看Odoo是否已经启动:

    less /var/log/odoo9/odoo9-server.log

    要退出less命令的查看界面,只需按一下q键。如果启动过程中出现问题,可以依据日志文件的内容查找原因。
    下边检查odoo服务器是否可以被恰当地停止:

    sudo /etc/init.d/odoo9-server stop

    检查下日志文件,确定下服务已经停止,也可以用top命令查看Ubuntu服务器正在运行的进程表来确认。(退出top命令的查看界面也是按q键)

    9. 将Odoo设为开机自启动

    让启动脚本随着Ubuntu服务器的开、关机而自动启动、关闭Odoo服务。

    sudo update-rc.d odoo9-server defaults

    现在就可以重启动你的服务器,当你再登录进来的时候,Odoo应该已经在运行了。输入如下命令查看Odoo是否已在运行:

    ps aux | grep odoo9
     
  • 相关阅读:
    资金流学习-成本分析
    解决root用户不能打开Chromium网页浏览器
    Kali Linux 2020.1乱码问题
    Kali Linux安装谷歌浏览器
    解决Kali Linux 2020.1乱码问题
    Kali Linux 2020.1a版本msfconsole启动失败问题
    Kali Linux发布2020.1a版本
    Kali Linux 2020.1快速修改root用户密码
    Kali Linux 2020.1安装桌面
    Kali Linux 2020.1修改系统语言
  • 原文地址:https://www.cnblogs.com/dancesir/p/7092794.html
Copyright © 2011-2022 走看看