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