派胜OA - Linux 部署 ExpressOA 3.x(系统环境和软件配置)

重要

ExpressOA 3.x 使用全球最佳编程语言 C# 构建(.NET 跨平台、高性能、开源免费)。
ExpressOA 包含自托管 Kestrel Web 服务器,Kestrel 可以单独使用,也可以与反向代理服务器一起使用。
ExpressOA 应用程序 runroot 文件夹中包含应用程序目录结构。
ExpressOA 在 Linux 上从 runroot/ExpressOA.dll 文件启动。
本文教程演示命令适用于 Ubuntu 24.04, 22.04, 20.04Debian 12.x, 11.x
在 Linux 上,建议使用的托管方式:
l使用 Systemd 托管 ExpressOA
l使用 Nginx 托管 ExpressOA
ExpressOA® Lite 版本不需要下列步骤:
1.2 安装字体
1.3 安装依赖程序

(1)部署 ExpressOA 程序文件


1.1 下载 ExpressOA 3.x 程序包
www.paioffice.com/expressoa/downloads
Linux 命令
sudo unzip ExpressOA-3.x.zip
解开 ExpressOA 程序包,移动 approot 到目标部署路径,例如 /expressoa。

1.2 安装字体
安装字体管理工具
适用于 Ubuntu 24.04, 22.04, 20.04Debian 12.x, 11.x
Linux 命令
sudo apt-get install fontconfig
适用于 openEuler 24.03 LTS, 22.03 LTS
Linux 命令
sudo dnf -y install fontconfig

复制 /expressoa/fonts 文件夹下的全部字体文件到 /usr/share/fonts。
Linux 命令
sudo cp -rf /expressoa/fonts/* /usr/share/fonts

更新字体
Linux 命令
sudo fc-cache -f -v

查看字体
Linux 命令
sudo fc-list

1.3 安装依赖程序
适用于 Ubuntu 24.04, 22.04, 20.04Debian 12.x, 11.x
Linux 命令
sudo apt-get update
sudo apt-get install xvfb
Linux 命令
sudo apt-get install -y libqt5webkit5
适用于 openEuler 24.03 LTS, 22.03 LTS
Linux 命令
sudo dnf -y install Xvfb
Linux 命令
sudo dnf -y install qt5-qtwebkit

1.4 设置 ExpressOA 目录结构的文件系统权限
执行 chmod 命令,设置文件系统权限。
ExpressOA® Core ExpressOA® Lite
Linux 命令
sudo chmod -R 444 /expressoa/fonts
sudo chmod -R 666 /expressoa/license
sudo chmod -R 555 /expressoa/runroot
sudo chmod -R 666 /expressoa/storageRoot
sudo chmod -R 666 /expressoa/temp
sudo chmod 444 /expressoa/cloudstorage.json
sudo chmod 444 /expressoa/database.json

ExpressOA 3.x 目录结构的文件系统权限。
ExpressOA® Core ExpressOA® Lite
目录/文件
文件系统权限
chmod 权限
用途
/fonts
读取
444
字体文件
/license
完全控制
666
存储许可证文件
/runroot
读取和执行
555
应用程序目录结构
/storageRoot
完全控制
666
存储路径
/temp
完全控制
666
临时文件夹
cloudstorage.json
读取
444
云存储配置
database.json
读取
444
配置数据库连接

(2)安装数据库 Microsoft SQL Server 或 PostgreSQL

ExpressOA 3.x 支持三种数据库。
lSQL Server 2022, 2019, 2017
lSQL Server Express 2022, 2019, 2017(免费商用)
lPostgreSQL 17, 16, 15, 14, 13, 12(免费商用)

2.1 安装 Microsoft SQL Server 或 PostgreSQL数据库

2.2 使用 SQL Server 数据库
ExpressOA 程序包 database-sql-statements 文件夹下,包含创建数据库结构的 SQL 语句。
使用 SQL Server 管理器,新建数据库 ExpressOA(数据库名称可以自定义)。
使用 SQL Server 管理器,选择数据库 >> 属性 >> 选项,确认数据库排序规则为 Chinese_PRC_CI_AS(简体中文)。
SQL Server 数据库 简体中文的排序规则
使用 SQL Server 查询分析器,创建 ExpressOA 数据库结构(依次执行 SQL 语句 microsoft-sqlserver....sql)。
1、系统核心数据结构。
microsoft-sqlserver_core.sql
2、 基本的演示工作流程(流程设计和表单模板)。
microsoft-sqlserver_demo.sql
3、可选。更多的演示工作流程(流程设计和表单模板)。
microsoft-sqlserver_workflow_sample.sql

2.3 使用 PostgreSQL 数据库。
ExpressOA 程序包 database-sql-statements 文件夹下,包含创建数据库结构的 SQL 语句。
使用 PostgreSQL - pgAdmin,创建 ExpressOA 数据库结构(依次执行 SQL 语句 postgresql....sql)。
1、系统核心数据结构。
postgresql_core.sql
2、基本的演示工作流程(流程设计和表单模板)。
postgresql_demo.sql
3、可选。更多的演示工作流程(流程设计和表单模板)。
postgresql_workflow_sample.sql

(3)配置 SQL Server 或 PostgreSQL 数据库连接

使用记事本打开 database.json 配置数据库连接信息。
使用 SQL Server 数据库:DatabaseType 为 【空字符串】 或 【SQLServer】。
使用 PostgreSQL 数据库:DatabaseType 为【PostgreSQL】。
重要:在 json 配置文件中,使用两个 \\ 代表一个 \。
DatabaseType 为空,使用 SQLServer 数据库
{
  "DatabaseType": "",
  "ConnectionStrings": {
    "SQLServer": "database=ExpressOA;Data Source=localhost;User ID=sa;password=YourPassword;Connect Timeout=60",
    "PostgreSQL": "Database=ExpressOA;Host=localhost;Username=postgres;Password=YourPassword"
  }
}

使用 PostgreSQL 数据库
{
  "DatabaseType": "PostgreSQL",
  "ConnectionStrings": {
    "SQLServer": "database=ExpressOA;Data Source=localhost;User ID=sa;password=YourPassword;Connect Timeout=60",
    "PostgreSQL": "Database=ExpressOA;Host=localhost;Username=postgres;Password=YourPassword"
  }
}




© 2024 长春派胜科技有限公司 版权所有
吉公网安备22017202000417号