only-office以Docker方式安装使用
目录
安装Docker
安装
# 安装必要依赖
yum install -y yum-utils device-mapper-persistent-data lvm2
# 添加aliyum docker-ce yum源
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
# 重建yum缓存
yum makecache
# 安装指定版本docker,版本19.03.12
yum install -y docker-ce-19.03.12-3.el7
# 确保网络模块开机自动加载
lsmod | grep overlay
lsmod | grep br_netfilter
cat > /etc/modules-load.d/docker.conf <<EOF
overlay
br_netfilter
EOF
modprobe overlay
modprobe br_netfilter
# 使桥接流量对iptables可见
cat > /etc/sysctl.d/k8s.conf <<EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
EOF
sysctl --system
# 验证是否生效,下面两个命令结果需均返回 1
sysctl -n net.bridge.bridge-nf-call-iptables
sysctl -n net.bridge.bridge-nf-call-ip6tables
配置Docker
# 创建docker镜像存储目录
cd ~
mkdir data
cd data/
mkdir docker
cd docker/
mkdir data-root
cd data-root/
pwd #输出结果:/root/data/docker/data-root
# 创建docker配置文件目录
mkdir /etc/docker
# 修改cgroup驱动为systemd[k8s官方推荐]、限制容器日志量、修改存储类型,最后的docker根目录可修改
cat > /etc/docker/daemon.json <<EOF
{
"exec-opts": ["native.cgroupdriver=systemd"],
"log-driver": "json-file",
"log-opts": {
"max-size": "100m"
},
"storage-driver": "overlay2",
"storage-opts": [
"overlay2.override_kernel_check=true"
],
"registry-mirrors": ["https://7uuu3esz.mirror.aliyuncs.com"],
"data-root": "/root/data/docker/data-root"
}
EOF
# 添加开机自启动,并立即启动
systemctl enable --now docker
验证docker是否正常
# 查看docker信息,判断是否与配置一致
docker info
# hello-docker测试
docker run --rm hello-world
# 删除测试的image
docker rmi hello-world
验证能否通过IP:Port方式访问Docker站点
# 查看docker server信息,确认最后一行是否报错
docker info
# 错误信息见下面最后一行,目前无错误信息
Client:
Context: default
Debug Mode: false
Plugins:
app: Docker App (Docker Inc., v0.9.1-beta3)
buildx: Build with BuildKit (Docker Inc., v0.5.1-docker)
Server:
Containers: 0
Running: 0
Paused: 0
Stopped: 0
Images: 0
Server Version: 19.03.12
Storage Driver: overlay2
Backing Filesystem: xfs
Supports d_type: true
Native Overlay Diff: true
Logging Driver: json-file
Cgroup Driver: systemd
Plugins:
Volume: local
Network: bridge host ipvlan macvlan null overlay
Log: awslogs fluentd gcplogs gelf journald json-file local logentries splunk syslog
Swarm: inactive
Runtimes: runc
Default Runtime: runc
Init Binary: docker-init
containerd version: 05f951a3781f4f2c1911b05e61c160e9c30eaa8e
runc version: 12644e614e25b05da6fd08a38ffa0cfe1903fdec
init version: fec3683
Security Options:
seccomp
Profile: default
Kernel Version: 3.10.0-1127.el7.x86_64
Operating System: CentOS Linux 7 (Core)
OSType: linux
Architecture: x86_64
CPUs: 2
Total Memory: 1.777GiB
Name: localhost.localdomain
ID: 2HIV:6EH2:KI53:BUGY:YD72:Q3BI:Y4MJ:X65V:YF2N:TFUZ:BRTD:ZOA3
Docker Root Dir: /root/data/docker/data-root
Debug Mode: false
Registry: https://index.docker.io/v1/
Labels:
Experimental: false
Insecure Registries:
127.0.0.0/8
Registry Mirrors:
https://7uuu3esz.mirror.aliyuncs.com/
Live Restore Enabled: false
安装only-office server
参考地址:https://helpcenter.onlyoffice.com/installation/docs-community-install-docker.aspx?_ga=2.248226951.1825569553.1616058768-1266077697.1607495094
系统需求
- CPU: dual core 2 GHz or better
- RAM: 2 GB or more
- HDD: at least 40 GB of free space
- Additional requirements: at least 4 GB of swap
- OS: amd64 Linux distribution with kernel version 3.10 or later
- Additional requirements
- Docker: version 1.10 or later
创建数据目录
/var/log/onlyoffice
for ONLYOFFICE Docs logs/var/www/onlyoffice/Data
for certificates/var/lib/onlyoffice
for file cache/var/lib/postgresql
for database
# 进入数据存储目录
cd /root/data
mkdir onlyoffice
cd onlyoffice
mkdir DocumentServer
cd DocumentServer
pwd
# 显示路径:/root/data/onlyoffice/DocumentServer
# 创建对应目录
mkdir logs
mkdir data
mkdir lib
mkdir db
ls
启动docker容器
# 启动docker容器,默认启动端口为80,可以进行修改
docker run -i -t -d -e TZ="Asia/Shanghai" -p 81:80 --restart=always \
-v /root/data/onlyoffice/DocumentServer/logs:/var/log/onlyoffice \
-v /root/data/onlyoffice/DocumentServer/data:/var/www/onlyoffice/Data \
-v /root/data/onlyoffice/DocumentServer/lib:/var/lib/onlyoffice \
-v /root/data/onlyoffice/DocumentServer/db:/var/lib/postgresql onlyoffice/documentserver
# 查看镜像下载
docker images
# 查看容器
docker ps
# 查看启动日志
docker logs -f 容器ID
开放防火墙端口
# 开放端口
firewall-cmd --add-port=81/tcp --permanent
# 重新加载配置
firewall-cmd --reload
# 查看防火墙开放情况
firewall-cmd --list-port
# 验证外网是否可以访问,查看此文件能否查看或打开
http://192.168.110.129:81/
可配置的参数
Please refer the docker run command options for the --env-file
flag where you can specify all required environment variables in a single file. This will save you from writing a potentially long docker run command.
- ONLYOFFICE_HTTPS_HSTS_ENABLED: Advanced configuration option for turning off the HSTS configuration. Applicable only when SSL is in use. Defaults to
true
. - ONLYOFFICE_HTTPS_HSTS_MAXAGE: Advanced configuration option for setting the HSTS max-age in the onlyoffice NGINX vHost configuration. Applicable only when SSL is in use. Defaults to
31536000
. - SSL_CERTIFICATE_PATH: The path to the SSL certificate to use. Defaults to
/var/www/onlyoffice/Data/certs/onlyoffice.crt
. - SSL_KEY_PATH: The path to the SSL certificate private key. Defaults to
/var/www/onlyoffice/Data/certs/onlyoffice.key
. - SSL_DHPARAM_PATH: The path to the Diffie-Hellman parameter. Defaults to
/var/www/onlyoffice/Data/certs/dhparam.pem
. - SSL_VERIFY_CLIENT: Enable verification of client certificates using the
CA_CERTIFICATES_PATH file
. Defaults tofalse
. - POSTGRESQL_SERVER_HOST: The IP address or the name of the host where the PostgreSQL server is running.
- POSTGRESQL_SERVER_PORT: The PostgreSQL server port number.
- POSTGRESQL_SERVER_DB_NAME: The name of a PostgreSQL database to be created on the image startup.
- POSTGRESQL_SERVER_USER: The new user name with superuser permissions for the PostgreSQL account.
- POSTGRESQL_SERVER_PASS: The password set for the PostgreSQL account.
- AMQP_SERVER_URL: The AMQP URL to connect to the message broker server.
- AMQP_SERVER_TYPE: The message broker type. Supported values are
rabbitmq
oractivemq
. Defaults torabbitmq
. - REDIS_SERVER_HOST: The IP address or the name of the host where the Redis server is running.
- REDIS_SERVER_PORT: The Redis server port number.
- NGINX_WORKER_PROCESSES: Defines the number of NGINX worker processes.
- NGINX_WORKER_CONNECTIONS: Sets the maximum number of simultaneous connections that can be opened by a NGINX worker process.
- JWT_ENABLED: Specifies the enabling the JSON web token validation by ONLYOFFICE Docs. Defaults to
false
. - JWT_SECRET: Defines the secret key to validate the JSON web token in the request to ONLYOFFICE Docs. Defaults to
secret
. - JWT_HEADER: Defines the HTTP header that will be used to send the JSON web token. Defaults to
Authorization
.
使用文档
官方文档地址:https://api.onlyoffice.com/editors/basic
.
添加中文字体
编辑字体
- 在Windows目录的
C:\Windows\Fonts
查找常用中文字体文件; - 使用字体编辑软件FontCreator修改参数配置:
- 选择 字体属性;
- 将字体家族改为中文;
字体子族改为常规;
注意:这里字体家族中间得加个空格。
- 将修改后的字体导出为新的字体包。
删除自带字体
# 进入容器内
docker ps
docker exec -it 51 bash
# 删除原版自带字体
cd /usr/share/fonts/
rm -rf *
cd /var/www/onlyoffice/documentserver/core-fonts/
rm -rf *
将字体文件导入docker容器,此种方式设置后字体生效,但是字体选择列表中中文字体显示乱码
# 在服务器创建字体目录
cd /root/data/onlyoffice
mkdir fonts
cd fonts/
# 将字符文件复制到该目录
rz
# 将字体复制到容器的对应目录下
docker cp /root/data/onlyoffice/fonts/ 51e38c77ddbd:/usr/share/fonts/truetype/custom
docker cp /root/data/onlyoffice/dockerImage/Contents.json e13c3a79dc43:/var/www/onlyoffice/documentserver/web-apps/apps/documenteditor/main/resources/help/zh
# 进入容器内
docker ps
docker exec -it 51 bash
# 确认字体文件是否是最新的
cd /usr/share/fonts/truetype/custom/fonts
ll
# 执行字体重新加载脚本
cd /usr/bin/
./documentserver-generate-allfonts.sh
# 输出内容如下:
Generating AllFonts.js, please wait...Done
Generating presentation themes, please wait...Done
ds:docservice: stopped
ds:docservice: started
ds:converter: stopped
ds:converter: started
# 生成的字体JS配置文件
/var/www/onlyoffice/documentserver/server/FileConverter/bin/AllFonts.js
文件预览
创建Html页面,在html文件中编写对应预览代码。
documentType参数说明
# 5.4.2 版本
# 字符串类型,定义文档打开类型:
1、text(.doc, .docm, .docx, .dot, .dotm, .dotx, .epub, .fodt, .htm, .html, .mht, .odt, .ott, .pdf, .rtf, .txt, .djvu, .xps);
2、spreadsheet(.csv, .fods, .ods, .ots, .xls, .xlsm, .xlsx, .xlt, .xltm, .xltx);
3、presentation(.fodp, .odp, .otp, .pot, .potm, .potx, .pps, .ppsm, .ppsx, .ppt, .pptm, .pptx).
World
<!DOCTYPE html>
<html style="height: 100%;">
<head>
<title>ONLYOFFICE Word</title>
<link rel="icon" href="https://oa.cnki.net/v/home/cnki.ico" type="image/x-icon" />
<link rel="shortcut icon" href="https://oa.cnki.net/v/home/cnki.ico" type="image/x-icon" />
</head>
<body style="height: 100%; margin: 0;">
<div id="placeholder" style="height: 100%"></div>
<script type="text/javascript" src="http://192.168.110.129:81/web-apps/apps/api/documents/api.js"></script>
<script type="text/javascript">
window.docEditor = new DocsAPI.DocEditor("placeholder",
{
"document": {
"fileType": "docx",
"key": "D24A86BDE9A2-01-10",
"permissions": {
"comment": false,
"copy": true,
"download": true,
"edit": false,
"fillForms": false,
"modifyContentControl": false,
"modifyFilter": true,
"print": true,
"review": false
},
"title": "test.docx",
"url": "http://192.168.110.129/onlyoffice/word01.docx"
},
"documentType": "word",
"editorConfig": {
"mode": "view",
"lang": "zh-CN",
"customization": {
"chat": false,
"comments": false,
"compactHeader": false,
"compactToolbar": false,
"compatibleFeatures": false,
"customer": {
"address": "北京",
"info": "中国知网",
"logo": "https://oa.cnki.net/v/home/cnki.ico",
"mail": "oa@cnki.net",
"name": "中国知网",
"www": "https://oa.cnki.net"
},
"feedback": {
"url": "https://oa.cnki.net",
"visible": false
},
"help": false,
"hideRightMenu": true,
"logo": {
"image": "https://oa.cnki.net/v/home/cnki.ico",
"imageEmbedded": "https://oa.cnki.net/v/home/cnki.ico",
"url": "https://oa.cnki.net"
},
"plugins": false,
"toolbarHideFileName": true
}
},
"type": "desktop",
"height": "100%",
"width": "100%"
});
</script>
</body>
</html>
Excel
<!DOCTYPE html>
<html style="height: 100%;">
<head>
<title>ONLYOFFICE Excel</title>
</head>
<body style="height: 100%; margin: 0;">
<div id="placeholder" style="height: 100%"></div>
<script type="text/javascript" src="http://10.120.160.113:81/web-apps/apps/api/documents/api.js"></script>
<script type="text/javascript">
window.docEditor = new DocsAPI.DocEditor("placeholder",
{
"document": {
"fileType": "xlsx",
"key": "138E9734B413-01",
"title": "Example Spreadsheet Title.xlsx",
"url": "http://oa.cnki.net/api/file/File/Download?fileId=065F87CE9C724D2AA26313E449A59809" //"http://10.120.160.100/fs/test-onlyoffice/test01.xlsx"
},
"documentType": "cell",
"editorConfig": {
"mode": "view"
},
"height": "100%",
"width": "100%"
});
</script>
</body>
</html>
PPT
<!DOCTYPE html>
<html style="height: 100%;">
<head>
<title>ONLYOFFICE PPT</title>
</head>
<body style="height: 100%; margin: 0;">
<div id="placeholder" style="height: 100%"></div>
<script type="text/javascript" src="http://10.120.160.113:81/web-apps/apps/api/documents/api.js"></script>
<script type="text/javascript">
window.docEditor = new DocsAPI.DocEditor("placeholder",
{
"document": {
"fileType": "pptx",
"key": "D24A86BDE9A2-01-03-123",
"title": "Example Presentation Title.pptx",
"url": "http://10.120.160.100/fs/test-onlyoffice/ppt01.pptx"
},
"documentType": "slide",
"editorConfig": {
"mode": "view"
},
"height": "100%",
"width": "100%"
});
</script>
</body>
</html>
测试预览URL
http://192.168.110.129/onlyoffice/index-word.html
http://192.168.110.129/onlyoffice/index-word-cnki.html
http://192.168.110.129/onlyoffice/index-excel.html
http://192.168.110.129/onlyoffice/index-ppt.html
文档下载接口测试:http://oa.cnki.net/api/file/File/Download?fileId=065F87CE9C724D2AA26313E449A59809
文件编辑
下面以word文件编辑作为示例进行验证。
在文档编辑时,需指定编辑的回调地址,此回调程序使用Java语言编写,以jar包方式在服务器上面运行,因此需要在服务器上面安装JDK环境。
<!DOCTYPE html>
<html style="height: 100%;">
<head>
<title>ONLYOFFICE Api Documentation</title>
</head>
<body style="height: 100%; margin: 0;">
<div id="placeholder" style="height: 100%"></div>
<script type="text/javascript" src="http://192.168.110.129:82/web-apps/apps/api/documents/api.js"></script>
<script type="text/javascript">
window.docEditor = new DocsAPI.DocEditor("placeholder",
{
"document": {
"fileType": "docx",
"key": "E7FAFC9C2210-020",
"title": "word01.docx",
"url": "http://192.168.110.129/onlyoffice/word01.docx"
},
"documentType": "text",
"editorConfig": {
"lang": "zh-cn",
"callbackUrl": "http://192.168.110.129:8080/test/getRequestData",
"customization": {
"chat": false,
"comments": false,
"compactHeader": false,
"compactToolbar": false,
"compatibleFeatures": false,
"customer": {
"address": "北京",
"info": "中国知网",
"logo": "https://oa.cnki.net/v/home/cnki.ico",
"mail": "oa@cnki.net",
"name": "中国知网",
"www": "https://oa.cnki.net"
},
"feedback": {
"url": "https://oa.cnki.net",
"visible": false
},
"help": false,
"hideRightMenu": true,
"logo": {
"image": "https://oa.cnki.net/v/home/cnki.ico",
"imageEmbedded": "https://oa.cnki.net/v/home/cnki.ico",
"url": "https://oa.cnki.net"
},
"plugins": false,
"toolbarHideFileName": true
}
},
"height": "100%",
"width": "100%"
});
</script>
</body>
</html>
测试编辑URL
# word
http://192.168.110.129/onlyoffice/edit-word.html
http://192.168.110.129/onlyoffice/edit-word-cnki.html
# 查看验证
http://192.168.110.129/onlyoffice/index-word.html
# 协同编辑
http://192.168.110.129/onlyoffice/co-edit-01.html
http://192.168.110.129/onlyoffice/co-edit-02.html
回调样例数据
// 进入编辑
{
"actions" : [ {
"type" : 1,
"userid" : "uid-1617000391704"
} ],
"forcesavetype" : 0,
"key" : "E7FAFC9C22A8",
"status" : 1,
"users" : [ "uid-1617000391704" ]
}
////////////////////////////////////////////////////////////////////////////////////////////////////////
// 关闭页面后,自动保存的回调
{
"actions" : [ {
"type" : 0,
"userid" : "uid-1617000391704"
} ],
"changesurl" : "http://192.168.110.129:81/cache/files/E7FAFC9C22A8_2529/changes.zip/changes.zip?md5=tOXiIFPV9i59huCMjv5iMg&expires=1617001678&disposition=attachment&filename=changes.zip",
"forcesavetype" : 0,
"history" : {
"changes" : [ {
"created" : "2021-03-29 06:46:57",
"user" : {
"id" : "uid-1617000391704",
"name" : "Anonymous"
}
} ],
"serverVersion" : "6.1.0"
},
"key" : "E7FAFC9C22A8",
"status" : 2,
"url" : "http://192.168.110.129:81/cache/files/E7FAFC9C22A8_2529/output.docx/output.docx?md5=ROMKlDaRuRgCBti99kZH2Q&expires=1617001678&disposition=attachment&filename=output.docx",
"users" : [ "uid-1617000391704" ]
}