【转】基于Ubuntu Server16.04 安装Odoo11

使用 非 root 用户 进行下面的测试:

本文使用 有sudo 权限的 odoo 用户进行测试()
如果是 阿里云,可以先创建 odoo 用户

sudo adduser  odoo 

2:给root 权限:

sudo vi /etc/sudoers

修改文件如下:

# User privilege specification
root    ALL=(ALL:ALL) ALL
odoo    ALL=(ALL:ALL) ALL

保存退出,odoo用户就拥有了root权限。

2: 切换 用户: su odoo
注:这里我在测试时,直接远程Putty 用 odoo用户登录了.

3: 进入 odoo的 家目录 cd ~

第一步: 更新安装依赖并克隆Odoo源码

sudo apt update  #注:16.04下只需要输入"sudo apt update" ,-get可以省略
sudo apt upgrade  #有个地方会让您确认是否保留当前版本
sudo apt install git  # 注:16.04.3自带了git,无需再安装

注:更新完毕后,最好重启下 服务器。

sudo reboot

:安装nodejs:
(ubuntu14.04之后的版本)

sudo apt-get install -y npm
sudo ln -s /usr/bin/nodejs /usr/bin/node
sudo npm install -g less   # 安装时注意成功安装的提示

下载odoo源码 ,
下面的命令会下载到odoo11的 子目录内:

git clone https://github.com/odoo/odoo.git odoo11 -b 11.0 --depth=1

如果是从别的电脑复制过来的可能会需要把源码的 所有者 改为odoo 用户:

sudo chown -R odoo odoo11

可以用ls -all 看 目录所属的 用户及组

第二步:安装Odoo系统所需的依赖:

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

安装PostgreSQL以及数据库用户:

sudo apt-get install -y postgresql

在数据库创建 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 ~/odoo11
./odoo-bin -s 

从启动日志可以看到,会在当前用户根目录 生成 配置文件 .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系统.

第三步:设置配置文件

sudo mkdir /etc/odoo
sudo cp /home/odoo/.odoorc /etc/odoo/odoo.conf
sudo chown -R odoo /etc/odoo

我们还需要创建存储Odoo日志的目录,通常位于/var/log内:

sudo mkdir /var/log/odoo
sudo chown odoo /var/log/odoo

现在我们需要确认配置文件中一些重要的参数。

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。
使用systemd init系统。要为系统增加新的服务。 创建 /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/odoo11/odoo-bin -c /etc/odoo/odoo.conf
[Install]
WantedBy=multi-user.target

我们需要注册新的服务:

sudo systemctl enable odoo.service

要开启这个新服务使用下面的命令:

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/odoo11/odoo-bin -c /etc/odoo/odoo.conf

Oct 15 12:46:54 iZuf6jevtfmojh35fpwxb5Z systemd[1]: Started 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
posted @ 2017-12-25 13:30  A·DONG  阅读(3962)  评论(0编辑  收藏  举报