公司实施odoo(openerp)Ubuntu14.04安装过程,实施成功!

来源:互联网 发布:excel替代软件 编辑:程序博客网 时间:2024/05/22 06:31

第一部分odoo介绍

        Odoo通过在线数据平台协作的工作方式,使中小企业能以更低的成本来拥有一套更好用的的企业管理软件,用这个工具来统计员工的贡献值。在此之前要拥有一套好的ERP系统需要动辄几十万的价格,更不用提更昂贵的二次开发了。  Odoo整套系统覆盖了企业策划、采购、销售、生产、仓储、物流、人事、财务等每一个环节。产品信息、原材料信息、客户信息、生产进度等几乎所有的信息都可以在系统中进行实时跟踪查询。

第二部份安装前准备:

1、设置root密码
sudo passwd root
注意:第一遍当前登陆账户密码,第二第三遍root账户密码
2、安装ubuntu 14.04 LTS版。
配置网络 /etc/network/interface 
设置dns /etc/resolvconf/resolv.conf.d/base
格式为:nameserver:XXXXXXXXX
        nameserver:XXXXXXXXX
3、设置ssh登录配置
vi /etc/ssh/sshd_config
修改设置
PermitRootLogin without-password 加#号注释掉
增加一条 PermitRootLogin yes
service sshd restart  重启
4、增加ubuntu更新源
cp /etc/apt/sources.list /etc/apt/sources.list_backup 备份
打开vi /etc/apt/sources.list
最后位置增加下列更新源
deb http://mirrors.163.com/ubuntu/ trusty main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ trusty-security main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ trusty-updates main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ trusty-proposed main restricted universe multiverse
deb http://mirrors.163.com/ubuntu/ trusty-backports main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ trusty main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ trusty-security main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ trusty-updates main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ trusty-proposed main restricted universe multiverse
deb-src http://mirrors.163.com/ubuntu/ trusty-backports main restricted universe multiverse
5、使用apt-get update 更新系统源
6、重新启动shutdown -r now 使用putty登录

准备就绪


第三部分先导知识:

         在Linux类操作系统中, 安装Odoo的常规办法是从Odoo官方网站的下载库http://nightly.openerp.com相应版本的目录里面下载一个.deb安装包(用于Debian/Ubuntu类型的Linux系统)或者一个.rpm安装包(用于Redhat/CentOS类型的Linux系统),并且运行安装。但这种做法下,安装的配置是按照Odoo官方的默认配置进行的,个性化设置空间小,有时候不方便管理。因此我们采取更手工化的源码安装方式,自己配置安装所需的配置。
本文介绍在Ubuntu Server14.04版操作系统中通过Github以源代码模式安装Odoo的方法。这种做法的优点是:
当官方的源代码升级时,或者有新的bug修正时,如果需要,我们可以在网络连通的情况下仅仅用一个"git pull"命令就能更新本地的代码。
请注意,未来在进行pull代码的操作时,需要事先做好备份。有些情况下,Odoo的数据库也需要更新。


第四部分安装odoo

第一步 建立服务器安装Ubuntu Server 14.04
访问Ubuntu官方网站服务器版页面http://www.ubuntu.com/server下载安装镜像,服务器版目前已经没有32位版本,只有64位版。或者从国内的网易源下载镜像 :http://mirrors.163.com/ubuntu-releases/14.04/ubuntu-14.04-server-amd64.iso下载完成后将镜像制成启动光盘或者优盘,按照常规的方法将它安装在电脑上,记好自己设置的用户名和密码。
本文以设定主机名为odoo、用户名为dean为例进行Ubuntu系统的安装,下面各步骤中如果有的命令与主机名和用户名相关,请读者自行改成自己实际的主机名和用户名。
在安装进行到选择预安装的服务的步骤时,选中PostgreSQL,把Odoo所需的数据服务环境PostgreSQL数据库一并装好。
系统装好重启后用自己用户名和密码登录进去,运行
    psql –version  


命令查看版本,目前随Ubuntu 14.04服务器版安装的是PostgreSQL的9.3.5版本


下边更新服务器的软件源信息:


    sudo apt-get update  


并且更新服务器的各个软件包,自动查找依赖关系:


    sudo apt-get dist-upgrade  


尽管并不总是必须的,但此时最好重启下服务器,以使改变的内容更新。


    sudo shutdown -r now  


第二步 创建一个系统用户odoo,将来让他拥有Odoo程序的权限并运行它
运行命令




    sudo adduser --system --home=/opt/odoo --group odoo  


这里添加的odoo用户是一个系统用户,它是用来拥有并运行各种后台服务的一类用户,而不是用来登录进系统进行各种操作的个人用户。在上述命令中指定并创建了odoo 用户的"home", home目录为/opt/odoo,这里就是我们将要把odoo程序代码存放的位置。你可以自由选择代码存放的位置,但请注意下文中的一些配置文件里面的内容是基于上述命令指定的目录而定的,所以当读者自行选择代码存放位置时,下文中的某些设置要自行修改。虽然系统用户被禁止用于登录,并且没有shell,但是当我们需要以它的身份进行一些特定操作的时候,还是可以用su命令切换用户:




    sudo su - odoo -s /bin/bash  


这个su(Switch User)命令将把你目前的终端登录切换到odoo用户,并且使用/bin/bash这个shell。这命令运行后会自动把你当前所在的目录切换到odoo用户的home目录/opt/odoo。当你以odoo用户身份操作完毕后, 可以用


    exit  


命令离开odoo用户的shell,回到你登录所用的用户。
第三步 安装和配置数据库服务器PostgreSQL
如果你之前在安装Ubuntu服务器过程中没勾选一并安装PostgreSQL,那么可以现在安装:


    sudo apt-get install postgresql  


如果已经安装过了则不必执行这个命令。
下面为PostgreSQL数据库添加并配置odoo用户 :
首先切换到postgres用户,它是PostgreSQL默认的初始用户,以它的身份操作我们就有配置数据库的权限:


    sudo su - postgres  


然后以postgres的身份创建一个新的数据库用户odoo,odoo程序将以它的身份访问postgreSQL数据库,来创建和删除数据库文件。


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


系统提示两次输入密码:


    Enter password for new role: ********  
    Enter it again: ********  


记住你这里设置的密码,后文中你会用到它。最后退出postgres用户身份:


    exit  


第四步 为Ubuntu服务器安装Python运行库和wkhtmltopdf
Odoo8.0版本依赖的python运行库与OpenERP7.0版本所依赖的有些不同。
运行命令


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


 
Odoo8.0版改用wkhtmltopdf来输出pdf,因此要下载wkhtmltopdf 并安装:




    wget http://sourceforge.net/projects/wkhtmltopdf/files/0.12.1/wkhtmltox-0.12.1_linux-trusty-amd64.deb  (已经下载不下来了)


然后运行


    sudo dpkg -i wkhtmltox-0.12.1_linux-trusty-amd64.deb  


进行安装。
安装完成后将可执行文件复制到 usr/bin 中


    sudo cp /usr/local/bin/wkhtmltopdf /usr/bin/wkhtmltopdf  


更改所有者为root用 户,并增加可执行属性


    sudo chown root:root /usr/bin/wkhtmltopdf  
    sudo chmod +x /usr/bin/wkhtmltopdf  


测试一下,打印一个网页到自己的home目录:


    wkhtmltopdf www.baidu.com ~/baidu.pdf  


如果显示成功输出了pdf,那么表明wkhtmltopdf安装成功。


安装中文字体:


    sudo apt-get install ttf-wqy-zenhei  
    sudo apt-get install ttf-wqy-microhei  


(Odoo中为何不能加载这些字体?)
这里安装完了之后,所有Odoo8.0运行时依赖的项目都已安装完成。
第五步 安装Odoo服务器
先安装git软件


    sudo apt-get install git  


切换到odoo用户:


    sudo su - odoo -s /bin/bash  


用git软件从github网站的odoo8.0分支下载一套代码三选一(如出现目标目录"."已存在或非空,请使用ls -a命令查看,后使用rm命令删除)


    git clone https://www.github.com/odoo/odoo --branch 8.0 --single-branch .  


或者用这个:


    git clone -b 8.0 https://github.com/odoo/odoo.git .  


(有一百多兆东西要下载,根据你的网速,这里会花上些时间)
下载完整的分支到当前odoo目录:


    git clone https://github.com/odoo/odoo.git .  


全下载好了之后 ,退出odoo用户:




    exit  


第六步 配置Odoo程序
Odoo默认的配置文件(/opt/odoo/debian/openerp-server.conf)包括基础的设置内容,做一点小小改动就可以在我们的系统上很好地运行,这里我们先把这个文件复制到我们需要的位置/etc下:


    sudo cp /opt/odoo/debian/openerp-server.conf /etc/odoo-server.conf  


更改它的所有权和许可:


    sudo chown odoo: /etc/odoo-server.conf  
    sudo chmod 640 /etc/odoo-server.conf  


上述命令让这个文件被odoo用户和用户组拥有,并且只有odoo用户和root用户可以读取。
下面用文本编辑器编辑它,初学者建议使用Ubuntu自带的nano编辑器, 以它为例, 运行:
[plain] view plain copy
在CODE上查看代码片派生到我的代码片


    sudo nano /etc/odoo-server.conf  


然后做3处改动,
1.打开这个配置文件后,在文件顶部,找到
db_password = False
这一行,把等号后面的 False 改为你第三步配置postgreSQL时设定的数据库密码。
2. 然后找到
addons_path = /usr/lib/python2.7/dist-packages/openerp/addons
这一行,改成
addons_path = /opt/odoo/addons
这样odoo程序会到我们个性化安装的opt/odoo/addons目录里面去读取模块。
3. 我们还要指定Odoo往哪里写它的日志文件。在文件的末尾新加一行
logfile = /var/log/odoo/odoo-server.log
配置文件编辑好后,按Ctrl+O,然后回车覆盖保存,然后Ctrl+X退出nano程序。
现在你可以试着启动Odoo服务器,看它是否正常运行。
先切换到odoo用户,




    sudo su - odoo -s /bin/bash  


然后运行


    /opt/odoo/openerp-server  


如果你得到的界面反馈是几行字,告诉你"OpenERP is running and waiting for connections."那么就OK了。(虽然版本升级了,但是在日志里面仍然把这程序叫OpenERP 而不是 Odoo)
如果有错误出现,你就要回头找找看看问题出在哪。一切正常的话,按 Ctrl+C 来停止服务器,然后用
exit
命令离开odoo用户,回到你自己登陆的shell。


第七步 安装启动脚本
启动、停止odoo服务牵扯到许多模块,需要多个步骤的操作,比较繁琐,下边我们安装一个脚本,它将以批处理的方式处理这些步骤,我们只要运行这个脚本一次,它就能以正确的用户身份批处理地运行odoo服务器的启动和停止等动作。
odoo程序提供了一个现成的脚本,是/opt/odoo/server/install/openerp-server.init这个文件,但需要一点小改动——因为我们不是按odoo的默认安装方式装的。
这里有个修改好的脚本文件,可以下载使用:(下边的命令第一行末尾的/和第二行开头的o之间没有空格)
wget http://www.theopensourcerer.com/wp-content/uploads/2014/09/odoo-server与配置文件类似,你得把下载到的这个脚本复制到/etc/init.d/并将其命名为odoo-server:


    sudo cp ~/odoo-server /etc/init.d/odoo-server  


然后把它改成可执行文件,由root用户拥有:


    sudo chmod 755 /etc/init.d/odoo-server  
    sudo chown root: /etc/init.d/odoo-server  


在第六步我们编辑的配置文件里面指定了odoo 服务器的日志文件存储位置,现
在我们得创建那个目录,这样odoo服务器就能往里面写日志了,同时我们还得让这个位置能够被odoo用户读写:


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


第八步 测试服务器
要启动Odoo服务器,输入:


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


现在你可以查看日志文件,看服务器是否已经启动


    less /var/log/odoo/odoo-server.log  


(要退出less命令的查看界面,只需按一下q键)
如果启动服务器过程中出现问题,你可以依据日志文件的内容查找原因。
如果一切正常,现在就可以用网络浏览器访问odoo的web页面,地址的格式为:
http://Odoo服务器的IP或者域名:8069
例如Odoo服务器的IP是192.168.1.10,那么在同一局域网的其它电脑上,打开网络浏览器(由于odoo使用的是较新的HTML5标准,所以在Windows XP自带的IE6上无法正常显示,建议下载安装个新版的Chrome或者Firefox浏览器),在地址栏输入:
http://192.168.1.10:8069
就应该能看到Odoo的数据库管理界面,因为是全新安装,一个帐套都没建立过,所以默认会来到这个界面。
建议读者此时修改Odoo系统的主密码master password 并牢牢记住它,这个密码是用来创建、复制、删除、备份、恢复数据库的,权力很大,最好设个强的密码。默认
的主密码是"admin",比较不安全。该密码以明文方式写在/etc/odoo-server.conf文件里面。这也是我们为什么把这个文件设成只有odoo用户和root用户可以读的原因。
当你在web界面上修改并且保存了新的主密码。/etc/odoo-server.conf 这个文件会被覆盖写入 ,并且会多出一些选项。
下边检查odoo服务器是否可以被恰当地停止:


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


检查下日志文件,确定下服务已经停止,也可以用top命令查看Ubuntu服务器正在运行的进程表来确认。(退出top命令的查看界面也是按q键)
第九步 自动化Odoo的启动和关闭
前面的步骤如果都运行正常的话,最后的步骤就是让启动脚本随着Ubuntu服务器的开 、关机而自动启动 、关闭Odoo服务。


    sudo update-rc.d odoo-server defaults  


如果你喜欢的话,你现在就可以重启动你的服务器,当你再登录进来的时候,Odoo应该已经在运行了。如果你输入
[plain] view plain copy
在CODE上查看代码片派生到我的代码片


    ps aux | grep odoo  


你将会看到像下面这样的信息:
odoo 1491 0.1 10.6 207132 53596 ? Sl 22:23 0:02 python /opt/odoo/openerp-server -c /etc/odoo-server.conf
这显示服务器正常运行,当然你也可以检查日志文件或者用网络浏览器访问的方式来验证。