从源码安装Odoo11
整理及测试:Odoo11安装,Odoo11生产环境部署:在Ubuntu Server16.04下Odoo11安装并配置为服务
本文使用有sudo权限的
sudo adduser
2:给root 权限:
sudo vi /etc/sudoers
修改文件参考如下:
# User privilege specification
root ALL=(ALL:ALL) ALL
保存退出,
切换用户:
注:在测试时,直接远程Putty用odoo用户登录了.
3: 进入odoo的家目录 cd ~
第一步: 更新安装依赖并克隆Odoo源码
1.1 更新系统
sudo apt update #注:16.04下只需要输入"sudo apt update" ,-get可以省略
sudo apt upgrade #有个地方会让您确认是否保留当前版本
sudo apt install git # 注:16.04.3自带了git,无需再安装
注:更新完毕后,最好重启下 服务器。
sudo reboot
1.2 安装nodejs(14.04之后用下面的命令):
sudo apt-get install -y npm
sudo ln -s /usr/bin/nodejs /usr/bin/node
sudo npm install -g less # 安装时注意成功安装的提示
1.3 克隆odoo源码 ,下面的命令会克隆到odoo11的 子目录内:
git clone https://github.com/odoo/odoo.git odoo11 -b 11.0 --depth=1
第二步:安装Odoo系统所需的依赖:
2.1
sudo apt-get install -y python3-pip
sudo pip3 install Babel decorator docutils ebaysdk feedparser gevent greenlet html2text Jinja2 lxml Mako MarkupSafe mock num2words ofxparse passlib Pillow psutil psycogreen psycopg2 pydot pyparsing PyPDF2 pyserial python-dateutil python-openid pytz pyusb PyYAML qrcode reportlab requests six suds-jurko vatnumber vobject Werkzeug XlsxWriter xlwt xlrd
注:安装这些依赖时,注意看下载速度,有些时间段会比较慢.有时候还会无法访问到服务器,注意成功安装后的提示. 不行换个时间段安装 就会发现快很多(比如早上8点前)
安装成功后提示:Successfully installed
2.2 安装PostgreSQL以及数据库用户:
sudo apt-get install -y postgresql
2.3 在数据库创建 odoo这个用户():
sudo su - postgres
createuser --createdb --username postgres --no-createrole --no-superuser --pwprompt odoo
Enter password for new role: *****
Enter it again:*****
exit
进入odoo源码目录运行odoo 并生成配置文件 (也可以自己创建一个简单的配置文件)
cd ~/
从启动日志可以看到,会在当前用户根目录生成配置文件 .odoorc (这个配置文件第三步会用到)
Using configuration file at /home/odoo/.odoorc
再开一个终端窗口,使用ps aux |grep odoo 可以看到odoo的使用情况,比如:
odoo 1010 0.9 1.6 421168 66852 pts/0 Sl+ 12:22 0:00 python3 ./odoo-bin -c /etc/odoo/odoo.conf
应该是用python3 启动的 odoo.
netstat -ant 可以看端口使用的情况 8069是odoo,22用于ssh,5432用于postgresl :
tcp 0 0 0.0.0.0:8069 0.0.0.0:* LISTEN
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN
tcp 0 0 127.0.0.1:5432 0.0.0.0:* LISTEN
如果不用随着系统启动启动odoo,到这里odoo已经可以手动启动了.
如果希望随着系统自动启动,请继续看下去.
注:还可以用python3.5 odoo-bin -s 启动试试 ,ps aux | grep odoo里面看到是这样的:
odoo 1058 2.7 1.6 422340 66012 pts/0 Sl+ 12:25 0:00 python3.5 odoo-bin
用python3 和 python3.5 启动的,好像crtl + c 关不干净
ctrl + c 应该可以终止,不过有时候好像会停不干净,需要reboot系统.
第三步:设置配置文件
3.1
sudo mkdir /etc/odoo
sudo cp /home/odoo/.odoorc /etc/odoo/odoo.conf
sudo chown -R odoo /etc/odoo
3.2 我们还需要创建存储Odoo日志的目录,通常位于/var/log内:
sudo mkdir /var/log/odoo
sudo chown odoo /var/log/odoo
3.3 编辑配置文件。
sudo vi /etc/odoo/odoo.conf
下面是2个建议增加的值 :
[options]
logfile = /var/log/odoo/odoo.log
logrotate = True
简要说明:
● addons_path 使用,逗号分隔的扩展路径,会在路径中寻找模块,从左至右阅读,最左侧拥有最高的优先级。
● admin_passwd 是master主控密码,用于访问web客户端数据库管理。建议设置一个足够强的密码,设置为False能让此功能失效。
● db_user 数据库实例在服务器启动序列期间进行初始化。
● dbfilter 用于筛选可访问的数据库,它是Pythoninterpreted正则表达式. 用于不让用户选择数据库,及未验证的URLs正常工作,它应该以^dbname$设置, 例如 dbfilter=^odoo-prod$。 它支持%h和%d占位符, 用来HTTP请求的主机名和子域名.
● logfile Odoo服务日志写入的地方。系统服务的日志通常位于/var/log. 留空,或者设为False,日志则会以标准方式输出。
● logrotate = True 按天存放日志
● proxy_mode 当使用反向代理时,应当设为True。
● without_demo 在生产环境中应设为True,这样新的数据库中就不会有演示数据。
● workers 值为启用的处理器数量。
● xmlrpc_port 服务监听的端口号。默认使用8069
● data_dir 会话数据和附件存储的位置,记得备份它。
● xmlrpc-interface 设置监听的地址。默认值会监听所有端口 0.0.0.0, 在使用反向代理时,可以设置为127.0.0.1 目的是只对本地请求响应。
通过-c参数运行服务,我们可以检查配置的效果:
./odoo-bin -c /etc/odoo/odoo.conf
注意:因为设置了日志文件,所以不会跳出日志,
ctrl + c 应该可以终止,不过有时候好像会停不干净,需要reboot系统.
要看 日志的话,可以 再开一个终端 ,用odoo 用户,使用:
tail -f /var/log/odoo/odoo.log 查看 日志。
Odoo服务 启动后 试试看在界面 创建 数据库
8:安装中文字体:
sudo apt-get install ttf-wqy-zenhei -y
sudo apt-get install ttf-wqy-microhei -y
9.安装报表所需的wkhtmltopdf
wget https://github.com/wkhtmltopdf/wkhtmltopdf/releases/download/0.12.2.1/wkhtmltox-0.12.2.1_linux-trusty-amd64.deb
sudo dpkg -i wkhtmltox-0.12.2.1_linux-trusty-amd64.deb # 会提示要安装xfonts-75dpi 等,这时候用apt-get -f install会安装这2个依赖
sudo ln -s /usr/local/bin/wkhtmltopdf /usr/bin
sudo ln -s /usr/local/bin/wkhtmltoimage /usr/bin
第四步:创建 /lib/systemd/system/odoo.service 文件,让odoo随着系统自动启动
由于16.04 使用了systemd作为init,因此把Odoo配置为服务,稍有不同。
要检查您的系统是否使用systemd,运行下面的命令:
man init
这会打开当前使用的init系统的文档,您能检查到底使用的是哪种。
如果您的服务器使用的是systemd。
4.1 编辑 /lib/systemd/system/odoo.service 文件:
sudo vi /lib/systemd/system/odoo.service
内容如下:
[Unit]
Description=Odoo
After=postgresql.service
[Service]
Type=simple
User=odoo
Group=odoo
ExecStart=/home/odoo/
4.2 需要注册新的服务:
sudo systemctl enable odoo.service
4.3 开启这个新服务:
sudo systemctl start odoo
检查它的状态:
sudo systemctl status odoo
如下所示,其中 Active active(running)表示正确运行,而且我们可以看到是运行在python3下的
● odoo.service - Odoo
Loaded: loaded (/lib/systemd/system/odoo.service; enabled; vendor preset: enabled)
Active: active (running) since Sun 2017-10-15 12:46:54 CST; 6s ago
Main PID: 930 (python3)
CGroup: /system.slice/odoo.service
└─930 python3 /home/odoo/
如果您希望停止它,使用下面的命令:
sudo systemctl stop odoo
也可以用 service odoo start 和 service odoo stop 来开启停止服务。
现在可以确认我们的Odoo实例启动了,并能响应请求。
如果Odoo正常运行,我们可以在日志文件中获得信息。我们可以检查Odoo是否响应HTTP请求:
curl http://localhost:8069
要检查日志文件,我们可以使用:
sudo less /var/log/odoo/odoo.log
您还可以使用tail -f:
sudo tail -f /var/log/odoo/odoo.log
今天发现odoo11的配置文件中密码部分也加密了.
从源码安装odoo8
英文地址:
http://www.theopensourcerer.com/2014/09/how-to-install-openerp-odoo-8-on-ubuntu-server-14-04-lts/
译文地址:
http://shine-it.net/index.php?topic=16623.msg29044#msg29044
转载地址:
http://jointd.com/?p=1998
2014年9月19日, Odoo官方发布了Odoo8.0正式版本,这是一个全新的版本,整合了网站建设等多种功能。
在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的数据库也需要更新。
第一步 建立服务器安装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 mkdir /opt
sudo mount -t ext4 /dev/xvdb1 /opt
配置自动挂载:
首先使用命令 blkid 查看 分区的UUID
在文件 /etc/fstab 中加入如下配置
:
# /devdata was on /dev/sdb
UUID=7016a5f8-30cd-41d7-9c62-3fdbd6b04f29 /opt ext4 defaults 0 0
运行命令
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用户身份操作完毕后, 可以用
命令离开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用户身份:
第四步 为Ubuntu服务器安装Python运行库和wkhtmltopdf
Odoo8.0版本依赖的python运行库与OpenERP7.0版本所依赖的有些不同。
运行命令
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
Odoo8.0版改用wkhtmltopdf来输出pdf,因此要下载wkhtmltopdf 并安装:
wget http://sourceforge.net/projects/wkhtmltopdf/files/0.12.1/wkhtmltox-0.12.1_linux-trusty-amd64.deb \
(wget http://download.gna.org/wkhtmltopdf/0.12/0.12.2.1/wkhtmltox-0.12.2.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分支下载一套代码(下边的命令第一行末尾的 - 和第二行开头的 b 之间没有空格;命令最后一个单词后面的一空格加一个点"."
是必须的,这个点表示"当前目录",不是个句号):
(下载时发现不能保存到当前目录,可以先下载至指定目录再移动到该目录)
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用户:
第六步 配置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编辑器, 以它为例, 运行:
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应该已经在运行了。如果你输入
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
这显示服务器正常运行,当然你也可以检查日志文件或者用网络浏览器访问的方式来验证。