使用docker-compose部署wiki
发表于:2021-09-27 |

操作系统环境 ubuntu 20.04

1.u盘安装ubuntu 并安装ssh服务(方便后面远程操作)
2.安装更新apt源和安装必要软件包
3.安装docker和docker-compose (2和3具体见docker部署openvpn-web)

4.具体搭建过程

1.1 基础准备
1.1.1 拉取docker镜像,我们选择的版本是cptactionhank/atlassian-confluence:latest
mkdir ./confluence
cd ./confluence
docker pull cptactionhank/atlassian-confluence:latest

1.1.2 准备好mysql的驱动,我们使用的mysql版本是5.7
wget https://repo1.maven.org/maven2/mysql/mysql-connector-java/5.1.47/mysql-connector-java-5.1.47.jar

#mysql8.0.20驱动:
wget https://repo1.maven.org/maven2/mysql/mysql-connector-java/8.0.20/mysql-connector-java-8.0.20.jar

1.1.3 准备好docker-compose.yml

version: '3'
services:
  confluence:
    image: cptactionhank/atlassian-confluence:latest
    container_name: confluence
    restart: always
    user: root
    ports:
      - 8090:8090
      - 8091:8091
    networks:
      - traefik
    volumes:
      - "/usr/share/zoneinfo/Asia/Shanghai:/etc/localtime"
      - ./confluence/logs:/opt/atlassian/confluence/logs
      - ./server.xml:/opt/atlassian/confluence/conf/server.xml
      - ./confluence-data:/var/atlassian/confluence
      - ./mysql-connector-java-5.1.47.jar:/opt/atlassian/confluence/confluence/WEB-INF/lib/mysql-connector-java-5.1.47.jar
networks:
  traefik:
    external: true

1.1.4 在准备好的 msyql 中创建数据库
– drop database confluence;
create database confluence DEFAULT CHARACTER SET utf8 COLLATE utf8_bin;

1.1.5 下载好破解工具
#下载链接:
http://image.baishapu.com/confluence破解工具.zip

1.2 部署破解
1.2.1 启动
#创建网卡
docker network create traefik
#启动
docker-compose up -d
#查看日志
docker logs -tf –tail 300 confluence
#访问地址: yourIp:8090

1.2.2 复制出 atlassian 的 jar 包
docker cp confluence:/opt/atlassian/confluence/confluence/WEB-INF/lib/atlassian-extras-decoder-v2-3.4.1.jar ./atlassian-extras-2.4.jar

下载 atlassian-extras-2.4.jar 文件到windows上

下载jar包

注意复制出来的文件名必须为 atlassian-extras-2.4.jar,因为破解工具中指定了此文件名;
1.2.3 运行工具,(提前安装好win版jdk 然后进入jar所在目前 执行java -jar confluence_keygen.jar)如图:

java -jar confluence_keygen.jar
弹出如图

回到wikiweb界面

下一步
复制id




成功后,会在原目录下出现atlassian-extras-2.4.back 备份文件,并生成了一个新的破解后的 atlassian-extras-2.4.jar
1.2.4 复制破解后的jar包回容器中
docker cp ./atlassian-extras-2.4.jar confluence:/opt/atlassian/confluence/confluence/WEB-INF/lib/atlassian-extras-decoder-v2-3.4.1.jar
#重启
docker restart confluence

1.2.5 剩下的按照页面提示一步一步设置即可
注意:mysql连接时,需要设置事务隔离级别 READ-COMMITTED

参考链接:https://confluence.atlassian.com/confkb/confluence-fails-to-start-and-throws-mysql-session-isolation-level-repeatable-read-is-no-longer-supported-error-241568536.html

#mysql 5
jdbc:mysql://192.168.1.172:3307/confluence?useSSL=false&sessionVariables=tx_isolation=’READ-COMMITTED’

解决慢时长gc的问题
  默认java配置为1G内存使用一段时间后回经常gc造成卡顿,单击“系统信息”可以看到jvm使用情况

 进入docker容器

docker exec -it confluence /bin/bash # 进入docker容器 confluence
  修改java配置

vi /opt/atlassian/confluence/bin/catalina.sh
  在 “cygwin=false” 上面添加如下内容,最大内存为2G

CATALINA_OPTS=”-Xms256m -Xmx2048m -XX:PermSize=128m -XX:MaxPermSize=512m”
  重启 wiki confluence

二、数据备份与迁移
2.1 参考链接:
https://www.cwiki.us/display/CONF6EN/Migrating+Confluence+Between+Servers#space-menu-link-content

https://confluence.atlassian.com/conf615/migrating-confluence-between-servers-967338806.html

#我的迁移过程
1、备份mysql数据库;
2、备份mysql驱动;
3、备份主目录(本文档安装的挂载目录 “- ./data:/var/atlassian/application-data/confluence”)
4、备份server.xml(容器目录: /opt/atlassian/confluence/conf/server.xml)
5、在新机器上准备好安装过程需要的东西,以及备份的东西拿过去准备覆盖;
6、如果需要迁移数据库,可以直接修改配置文件:<confluence.home>/confluence.cfg.xml

迁移后,日志显示启动成功,但页面任然无法访问,此过程大概需要几分钟左右
2.2 关闭confluence自带每日备份任务

2.3 手动备份脚本 + crontab定时任务
备份数据库,主目录挂载出来即可;

三、导出PDF
注意:confluence导出PDF仅支持一种字体,且需要自己手动上传安装;(可以从系统目录C:\Windows\Fonts 中复制出来)

四、配置邮件服务器
参考链接:https://qinjiangbo.com/mail-server-configuration-of-confluence.html

说明:25、465端口不行,再试试587端口也是可以的

五、版本升级
Confluence7 + Mysql8:
CREATE DATABASE xxxxxxConfluence CHARACTER SET utf8mb4 COLLATE utf8mb4_bin;

#隔离级别的设置, mysql 8 的区别:
sessionVariables=transaction_isolation=’READ-COMMITTED’

上一篇:
title
下一篇:
MySQL查看数据库表容量大小