您的当前位置:首页在CentOS 7服务器下安装和配置Odoo 13

在CentOS 7服务器下安装和配置Odoo 13

2024-12-13 来源:哗拓教育

在本文中,我们将讲述如何在CentOS7服务器下的Python虚拟环境中安装配置Odoo13,源码从Github的存储库中下载,并使用Nginx作为反向代理。

SSH登录服务器和相关的准备

通过SSHroot身份登录到服务器:

ssh root@your_server_ip

如需检查计算机上安装的CentOS的版本,可以运行以下命令:

cat /etc/redhat-release

在本案例中,我们所得到的结果如下

CentOS Linux release 7.7.1908 (Core)

CentOS 7系统的升级

运行以下命令更新服务器:

yum update

更新服务器后,输入以下内容启用EPEL 资源库 :

yum install epel-release

Python3.7的安装

需要切换到root用户:

sudo root

安装相关编译工具

yum -y groupinstall "Development tools"
yum -y install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel
yum install libffi-devel -y

下载并解压安装包

cd /opt # 待安装的目录
wget 
tar -xvJf  Python-3.7.0.tar.xz

创建编译安装的目录

mkdir /usr/local/python3

编译并安装

cd Python-3.7.0
./configure --prefix=/usr/local/python3
make && make install

创建相关的软链接

ln -s /usr/local/python3/bin/python3 /usr/local/bin/python3
ln -s /usr/local/python3/bin/pip3 /usr/local/bin/pip3

验证python和pip的版本

python3 -V
pip3 -V

会得到以下结果:

Python 3.7.0
pip 10.0.1 from /usr/local/python3/lib/python3.7/site-packages/pip (python 3.7)

odoo相关依赖的安装

yum install git gcc wget nodejs-less libxslt-devel bzip2-devel openldap-devel libjpeg-devel freetype-devel

创建Odoo的用户

创建一个用于运行Odoo名为oodo13的系统用户,主目录为/opt/odoo13

sudo useradd -m -d /opt/odoo13 -U -r -s /bin/bash odoo13

*注:

  • 这里可以随意命名用户,但不要忘记创建一个具有相同名称的PostgreSQL用户。

安装和配置PostgreSQL

首先列举出可用的软件包:

yum list postgresql*

在本教程中,我们选用PostgreSQL 9.6版本。 若用户没有此版本的列表,可以使用以下命令从Postgres Yum存储库中手动添加:

yum install https://download.postgresql.org/pub/repos/yum/9.6/redhat/rhel-7-x86_64/pgdg-redhat96-9.6-3.noarch.rpm -y

执行以下命令安装PostgreSQL 9.6:

yum install postgresql96 postgresql96-server postgresql96-contrib postgresql96-libs -y

初始化数据库:

/usr/pgsql-9.6/bin/postgresql96-setup initdb

开启 PostgreSQL服务:

systemctl start postgresql-9.6.service

可以配置PostgreSQL服务开机自启:

systemctl enable postgresql-9.6.service

最后,创建一个PostgreSQL用户,需要和已经为Odoo创建的用户(本例中用户名为odoo13)使用相同的名称。

sudo su - postgres -c "createuser -s odoo13"

Wkhtmltopdf的安装

wkhtmltopdf软件包是Odoo用来将PDF格式的HTML制成以便可以打印PDF报告的开源工具。 本案例中安装0.12.5版本,该版本在CentOS 7官方存储库中不可用。 为了下载并安装此版本,需要运行以下命令:

cd /opt/
wget https://downloads.wkhtmltopdf.org/0.12/0.12.5/wkhtmltox-0.12.5-1.centos7.x86_64.rpm
yum localinstall wkhtmltox-0.12.5-1.centos7.x86_64.rpm

Odoo 13的安装与配置

首先,需要更改为用户“odoo13”:

su - odoo13

从Github的存储库中下载Odoo 13源代码:

git clone  --depth 1 --branch 13.0 /opt/odoo13/odoo

下载完成后,为Odoo创建一个新的Python虚拟环境:

cd /opt/odoo13
python3 -m venv odoo13-venv

激活所创建的Python虚拟环境:

source odoo-venv/bin/activate

升级pip、setuptools,并安装Wheel库:

pip install --upgrade pip
pip install --upgrade setuptools
pip3 install wheel

使用pip3安装所有必需的Python模块:

pip3 install -r odoo/requirements.txt

完成后,通过键入以下命令停用环境并退出:

deactivate && exit

我们将创建一个包含第三方插件新目录,并将该目录的所有者更改为odoo13:

mkdir /opt/odoo13/odoo13-custom-addons
chown odoo: /opt/odoo13/odoo13-custom-addons

修改数据库连接的配置信息:

vi /var/lib/pgsql/9.6/data/pg_hba.conf

将数据库访问的配置信息修改如下:

# TYPE  DATABASE        USER            ADDRESS                 METHOD

# "local" is for Unix domain socket connections only
local   all             all                                     trust
# IPv4 local connections:
host    all             all             127.0.0.1/32            ident
# IPv6 local connections:
host    all             all             ::1/128                 ident
# Allow replication connections from localhost, by a user with the
# replication privilege.
#local   replication     postgres                                peer
#host    replication     postgres        127.0.0.1/32            ident
#host    replication     postgres        ::1/128                 iden

创建Odoo13的配置文件:

vi /etc/odoo13.conf

配置文件的内容如下:

[options]
; This is the password that allows database operations:
admin_passwd = admin_password
db_host = False
db_port = False
db_user = odoo13
db_password = False
addons_path = /opt/odoo13/odoo/addons,/opt/odoo13/odoo-custom-addons

*注:

  • 请记得使用自己的密码更换admin_password的内容。

创建系统单元文件并测试安装

创建一个名为odoo13.service的服务单元文件:

sudo vi /etc/systemd/system/odoo13.service

系统单元文件的内容如下:

[Unit]
Description=Odoo13
Requires=postgresql-9.6.service
After=network.target postgresql-9.6.service
[Service]
Type=simple
SyslogIdentifier=odoo13
PermissionsStartOnly=true
User=odoo13
Group=odoo13
ExecStart=/opt/odoo13/odoo13-venv/bin/python3 /opt/odoo13/odoo/odoo-bin -c /etc/odoo13.conf
StandardOutput=journal+console
[Install]
WantedBy=multi-user.target

然后重新加载守护程序,使之在systemd中创建的新单元:

systemctl daemon-reload

可以启动Odoo13的服务:

systemctl start odoo13

可以查看Odoo13的服务状态:

systemctl status odoo13

得到启动的状态如下

● odoo13.service - Odoo13
   Loaded: loaded (/etc/systemd/system/odoo13.service; disabled; vendor preset: disabled)
   Active: active (running) since Tue 2019-11-19 15:21:40 CST; 2h 20min ago
 Main PID: 28867 (python3)
   CGroup: /system.slice/odoo13.service
           └─28867 /opt/odoo13/odoo13-venv/bin/python3 /opt/odoo13/odoo/odoo-bin -c /etc/odoo13.conf

如果没有出现错误,可以使用以下命令启用Odoo13的服务开机自启:

systemctl enable odoo13

要查看Odoo日志的消息,可以使用以下命令:

journalctl -u odoo13

开启数据库远程访问

进入修改文件目录:

cd /var/lib/pgsql/9.6/data/

编译配置文件:

vi pg_hba.conf

修改文件末尾处 # IPv4 local connections的内容:

host    all             all             127.0.0.1/32            ident   # 在本行下面添加
host    all             all             0.0.0.0/0               trust   # 添加内容

编译配置文件:

vi postgresql.conf

修改Connection Settings为以下内容:

# - Connection Settings -
listen_addresses = '*'          # what IP address(es) to listen on;
                                        # comma-separated list of addresses;
                                        # defaults to 'localhost'; use '*' for all
                                        # (change requires restart)

输入以下指令进入数据库:

su – postgres

进入数据库后,输入以下指令:

-bash-4.2$ psql
psql (9.6.12)
Type "help" for help.

修改“odoo13”用户的初始密码:

postgres=# alter user odoo with password 'odoo';

修改密码后,退出数据库:

postgres=# \q
-bash-4.2$ exit
Logout

测试安装Odoo13

O13.jpg

*注:

  • 创建数据库时所输入的Master Password即为配置文件中所写的admin_passwd

为Odoo13配置Nginx反向代理

执行以下命令从Nginx官网中获取Centos的源地址:

sudo rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm

通过yum search nginx查看是否添加源成功,如果成功则执行下列命令安装Nginx:

sudo yum install -y nginx

可以启动Nginx的服务:

sudo systemctl start nginx.service

如果没有出现错误,可以使用以下命令启用Nginx的服务开机自启:

sudo systemctl enable nginx.service

修改Nginx的配置文件:

vi /usr/local/nginx/conf/nginx.conf

配置成以下内容:

events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '

#user  nobody;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;


upstream direction{
        server 127.0.0.1:8069; # 反向服务地址

}

    server {
        listen       80;
        server_name  _; # set all 

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
        proxy_pass http://direction; # 代理转发
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

完成后保存文件并重新启动Nginx服务:

sudo systemctl restart nginx.service
显示全文