Back to blog
Apr 09, 2026
3 min read

在Arch Linux上非Docker方式安装ERPNext

在Arch Linux上非Docker方式安装ERPNext。

初始情况

系统信息如下所示:
./os_info.png

适合场景:生产服务器、开发环境、学习 Linux


前提准备

安装所需的各种底层库:

sudo pacman -Syu
sudo pacman -S git python python-pip mariadb valkey nodejs yarn npm nginx supervisor cronie 

开始安装

下述命令默认在普通用户权限下执行,如果提示权限不足,请在命令前添加sudo

设置数据库

# mariadb-install-db --user=mysql --basedir=/usr --datadir=/var/lib/mysql
# systemctl enable mariadb --now
# mariadb_secure_installation

在此环节,会设置一些数据库的参数,设置数据密码时建议设置强密码。

设置完后,增加下面内容到Mariadb的/etc/my.cnf下:
# nano /etc/my.cnf

[mariadb]
innodb-file-format=barracuda
innodb-file-per-table=1
innodb-large-prefix=1
character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci

[mariadb]
default-character-set = utf8mb4

保存后,运行下面命令重启mariadb # systemctl restart mariadb
同时,可以将 valkey配置自动运行,# systemctl enable valkey --now

以上结束后,准备工作基本就结束了,下一步开始安装Frappe Bench.

Frappe Bench Configuration

安装Bench CLI

# pip install frappe-bench
如果使用uv工具的话,可以使用 uv tool install frappe-bench完成安装。

同时建议将bench运行的目录添加到系统路径下, # sudo nano /etc/profile


# Append our default paths
append_path …
append_path ‘/home/{your_user_name}/.local/bin’

然后log out一下再log in,使改变生效。

安装完后可以使用 bench --version查看安装的bench版本号。

然后进入我们预计安装的目录初始化一个bench项目:

# mkdir ~/frappe && cd ~/frappe
# bench init benchapp

安装ERPNext

进入上一步创建的benchapp 目录,运行下面命令:

# bench get-app erpnext
# bench new-site erp.local
# bench --site erp.local install-app erpnext
# bench use erp.local
# bench start 

简单说一下以上命令,第一步是将erpnext下载到本地,第二步是创建一个新站点(你可以在一台机器上创建多个站点来安装erpnext), 第三步在这个站点安装erpnext,第四步激活这个站点,第五步启动这个站点。

这时候用浏览器访问 http://localhost:8080应该就可以看到站点了。 如果有样式问题,重新生成一下样式。

# bench build
# bench clear-cache
# bench restart

配置supervisor和nginx

以上步骤尽管可以访问erpnext,但是毕竟访问的是调试界面,现在结合supervisor和nginx,实现真正意义上的部署。

生成supervisor和nginx的配置文件:

# bench setup nginx
# bench setup supervisor

然后软连接这两个配置文件:

# Supervisor (Arch 的配置目录通常在 /etc/supervisor.d/)
sudo ln -sf /home/{your_name}/benchapp/config/supervisor.conf /etc/supervisor.d/benchapp.ini

nginx的稍微有些麻烦,需要把/home/{your_name}/benchapp/config/nginx.conf/etc/nginx/nginx.conf两个文件进行汇总,主要是/etc/nginx/nginx.conf这个文件内的http部分,我的配置内容如下:

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

    upstream benchapp-frappe {
        server 127.0.0.1:8000 fail_timeout=0;
    }

    upstream benchapp-socketio-server {
        server 127.0.0.1:9000 fail_timeout=0;
    }



    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

     server {
       
        listen       80;
        server_name miandr.ui;

        root /home/sama/frappe/benchapp/sites;

        proxy_buffer_size 128k;
        proxy_buffers 4 256k;
        proxy_busy_buffers_size 256k;



        add_header X-Frame-Options "SAMEORIGIN";
        add_header Strict-Transport-Security "max-age=63072000; includeSubDomains; preload";
        add_header X-Content-Type-Options nosniff;
        add_header X-XSS-Protection "1; mode=block";
        add_header Referrer-Policy "same-origin, strict-origin-when-cross-origin";


        location /assets {
                root /home/sama/frappe/benchapp/sites;
                try_files $uri =404;
                add_header Cache-Control "max-age=31536000";
        }

        location ~ ^/protected/(.*) {
                internal;
                try_files /miandr.ui/$1 =404;
        }

        location /socket.io {
                proxy_http_version 1.1;
                proxy_set_header Upgrade $http_upgrade;
                proxy_set_header Connection "upgrade";
                proxy_set_header X-Frappe-Site-Name miandr.ui;
                proxy_set_header Origin $scheme://$http_host;
                proxy_set_header Host $host;

                proxy_pass http://benchapp-socketio-server;
        }

        location / {

                rewrite ^(.+)/$ $1 permanent;
                rewrite ^(.+)/index\.html$ $1 permanent;
                rewrite ^(.+)\.html$ $1 permanent;

                location ~* ^/files/.*.(htm|html|svg|xml) {
                        add_header Content-disposition "attachment";
                        try_files /miandr.ui/public/$uri @webserver;
                }

                try_files /miandr.ui/public/$uri @webserver;
        }

        location @webserver {
                proxy_http_version 1.1;
                proxy_set_header X-Forwarded-For $remote_addr;
                proxy_set_header X-Forwarded-Proto $scheme;
                proxy_set_header X-Frappe-Site-Name miandr.ui;
                proxy_set_header Host $host;
                proxy_set_header X-Use-X-Accel-Redirect True;
                proxy_read_timeout 120;
                proxy_redirect off;

                proxy_pass  http://benchapp-frappe;
        }

        # error pages
        error_page 502 /502.html;
        location /502.html {
                internal;
        }

        access_log  /var/log/nginx/access.log;
        error_log  /var/log/nginx/error.log;

        # optimizations
        sendfile on;
        keepalive_timeout 15;
        client_max_body_size 50m;
        client_body_buffer_size 16K;
        client_header_buffer_size 1k;

        # enable gzip compresion
        # based on https://mattstauffer.co/blog/enabling-gzip-on-nginx-servers-including-laravel-forge
        gzip on;
        gzip_http_version 1.1;
        gzip_comp_level 5;
        gzip_min_length 256;
        gzip_proxied any;
        gzip_vary on;
        gzip_types
                application/atom+xml
                application/javascript
                application/json
                application/rss+xml
                application/vnd.ms-fontobject
                application/x-font-ttf
                application/font-woff
                application/x-web-app-manifest+json
                application/xhtml+xml
                application/xml
                font/opentype
                image/svg+xml
                image/x-icon
                text/css
                text/plain
                text/x-component
                ;
        
    }

}

以上代码你根据自己的配置进行修改。

配置完后启动一下服务:

# sudo systemctl enable --now nginx supervisor
# sudo systemctl reload nginx

这时应该就可以直接使用http://127.0.0.1来访问erpnext了。

但我遇到了一个问题,样式不出现。 查询和咨询gemini后,他给我解答是权限的问题,同时给了我一个命令 chmod +x /home/sama ,重新刷新后页面样式正常了。

homepage

登陆时,用户名是administator,密码是上面$ bench new-site rep.local时输入的密码,如果忘记了,可以使用bench set-admin-password来重设密码。

后续还可以添加hrms等模块,待我熟悉erpnext后,再更新后续模块的内容。