搭建zyplayer-doc个人WIKI文档管理工具,问题记录及简单使用

本文主要是介绍搭建zyplayer-doc个人WIKI文档管理工具,问题记录及简单使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 项目简介
  • 各模块介绍
  • 项目部署
    • 准备工作
      • 修改配置及数据库初始化
    • 编译部署
      • 编译后文件
        • 前后端在同一个部署包当中(无需单独部署前端)
      • 环境部署目录规划
      • 启动脚本编写
      • 登录
    • 部署问题记录
      • 错误: 找不到或无法加载主类
      • Failed to instantiate [javax.sql.DataSource]
  • 项目简单使用
    • 创建个人用户
    • 基本模块使用
      • 数据库文档
      • WIKI文档
      • API接口文档

zyplayer-doc官网地址,以下项目简介和模块介绍均取自官网

项目简介

zyplayer-doc是一款适合团队和个人使用的WIKI文档管理工具,同时还包含数据库文档、Api接口文档。

各模块介绍

  • zyplayer-doc-manage 文档管理后台

    • 具有项目模块导航,人员及权限管理功能,分组管理等功能。
    • 集成了本项目内的各个子模块功能,是各模块的协调管理模块。
  • zyplayer-doc-wiki wiki文档工具

    • 在线管理公司、项目及任意形式的文档
    • 文档支持按空间划分,按人员分组授权,支持空间收藏和空间内的文档开放访问。
    • 文档支持编辑、查看、评论、上传附件、历史版本查看、页面权限控制、文档搜索等功能。
    • 文档编辑支持html富文本方式编辑和markdown的方式编辑。
    • 本工具使用的开源工具有:vue、element-ui、mavon-editor、wangeditor等。
    • 参考学习了Atlassian Confluence文档工具进行开发,争取作为该软件的开源免费替代产品,同时作为内部文档管理工具最好的存在。
  • zyplayer-doc-db 数据库工具
    一款在线管理数据库的工具,你可以将所有的数据源统一管理到这里面,团队间的各成员就不必每人在自己电脑上装一个数据库管理软件,
    然后再添加数据源,可以统一修改数据库账号密码而不用群广播通知,新员工进入后对他使用到的数据源进行授权即可使用。

    • 支持MySQL、Doris(MySQL协议)、SQLServer、Oracle、达梦、PostgreSQL、Hive、Impala数据源。
    • 支持数据库表、字段文档查看修改,表文档导出、建表语句DDL导出、表数据导出。
    • 支持SQL执行、表数据预览、不同数据库之间的数据互导,支持多数据源管理。
    • 支持按人员、按数据源对用户授权,可给用户 库表注释查看、注释修改、SQL执行、函数修改等粒度的授权。
    • 支持库函数和存储过程的增删改查,修改记录查询等。
    • 目标是取代Navicat,做一个小而精的开源免费的在线数据库管理工具。
  • zyplayer-doc-api API接口文档管理工具
    一款支持统一管理Swagger文档、OpenApi文档、自建接口文档的管理工具,具有文档查看、接口请求、全局参数管理等功能,设计走心,前端代码使用最新技术构建,每一行代码都是全新手动敲出来的,超级简单明了,代码简洁美观可读性好、易维护。

    • 支持Swagger的文档展示,接口调试,解析速度快,界面设计走心。
    • 支持将所有的Swagger文档、OpenApi文档、自建接口文档进行统一管理,支持全局参数设置,请求参数缓存,下次自动填充等。
    • 目标是实现一个平台解决所有项目的接口文档统一管理。
  • 其他

    • zyplayer-doc-ui 前面各模块的前端UI源码
    • zyplayer-doc-core 一些核心、公用的类
    • zyplayer-doc-data 数据库层面的交互
    • zyplayer-doc-other 一些测试

项目部署

准备工作

修改配置及数据库初始化

  • zyplayer-doc-manage/src/main/resources/application.yml
    • 指定合适的端口号
      在这里插入图片描述

    • 修改数据库信息,针对mysql8,url最好加上allowPublicKeyRetrieval=true,如下:

      jdbc:mysql://192.168.38.10:3306/wiki_doc_db?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&autoReconnect=true&useSSL=false&rewriteBatchedStatements=true&allowPublicKeyRetrieval=true
      
    • 指定文件相关存储路径
      在这里插入图片描述

  • 初始化数据库:zyplayer-doc-manage/src/main/resources/sql
    • 在数据库依次执行full.sql、1.1.2.sql、1.1.4.sql
      在这里插入图片描述
      官网说明:下载的master分支,目前对应的版本是1.1.5,启动后不会执行升级脚本,也不执行最初的初始化脚本
      在这里插入图片描述
      目前只有1.1.2和1.1.4会触发执行升级sql脚本,full.sql不会被触发,直接手动数据库执行一下,也花不了多少时间
      在这里插入图片描述
  • 指定日志路径为绝对路径zyplayer-doc-manage/src/main/resources/logback.xml
    在这里插入图片描述

编译部署

编译后文件

  • 部署包(包含了前后端部署文件)
    在这里插入图片描述
前后端在同一个部署包当中(无需单独部署前端)

在这里插入图片描述

环境部署目录规划

个人习惯通过指定main方法启动,因此划分很多目录,指定jar包启动简单些,但是如果配置不对,就需要重新打包,看个人习惯吧
在这里插入图片描述

启动脚本编写

  • 包含了停止启动两部分
#! /bin/bash
pid=$(ps -ef | grep "com.zyplayer.doc.manage.Application" | grep -v grep | awk '{print $2}')
if [ -n "$pid" ]; thenecho "stop wiki doc, pid:$pid"kill -9 "$pid"
fiAPP_HOME=/home/wiki/app/wiki
CLASS_PATH=${APP_HOME}/conf:${APP_HOME}/libs/*
exec nohup java -cp ${CLASS_PATH} -Dloader.main=com.zyplayer.doc.manage.Application org.springframework.boot.loader.PropertiesLauncher  >/dev/null 2>&1 &
echo "wiki doc started"
  • 启动服务
    在这里插入图片描述

登录

启动成功,登录用户和密码为:zyplayer/123456
在这里插入图片描述

部署问题记录

错误: 找不到或无法加载主类

在这里插入图片描述
估计和zyplayer-doc的打包方式有关系,最终解决方式参照上面的启动脚本编写,即java -cp ${CLASS_PATH} com.zyplayer.doc.manage.Application改成java -cp ${CLASS_PATH} -Dloader.main=com.zyplayer.doc.manage.Application org.springframework.boot.loader.PropertiesLauncher

Failed to instantiate [javax.sql.DataSource]

错误大概如下,复现不了了,原因就是连接数据库失败导致的,因为数据库使用的是mysql8,在url上拼接allowpublickeyretrieval=true即可,奇怪的是去掉之后,也不报错了

Error creating bean with name 'manageDatasource' ...Failed to instantiate [javax.sql.DataSource]:
  • Caused by: com.mysql.cj.exceptions.UnableToConnectException: Public Key Retrieval is not allowed
  • 在JDBC连接串中加入allowPublicKeyRetrieval=true参数;
    在这里插入图片描述

项目简单使用

创建个人用户

创建用户,默认是停用状态,别忘点开正常
在这里插入图片描述
分配权限
在这里插入图片描述

基本模块使用

数据库文档

一个人配置好,大家都可以用的,省的每次配置了
在这里插入图片描述

WIKI文档

感觉就是md编辑器,可以创建工作空间(公共,私人)
在这里插入图片描述
在这里插入图片描述

API接口文档

在这里插入图片描述

之所以去了解zyplayer-doc,就是因为该模块介绍,感觉管理swagger很方便。平常开发项目比较多,版本比较多,浏览器收藏了很多swagger接口地址,就比较乱,突然发现有这么一个管理工具,就想尝试下,然并卵,后续有待研究,先午休一会吧
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 按照示例要求填写
    在这里插入图片描述
    可以跳转了,不能在线调试?
    在这里插入图片描述
    可以调试,离成功还差一点
    在这里插入图片描述

这篇关于搭建zyplayer-doc个人WIKI文档管理工具,问题记录及简单使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/657335

相关文章

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

Python操作PDF文档的主流库使用指南

《Python操作PDF文档的主流库使用指南》PDF因其跨平台、格式固定的特性成为文档交换的标准,然而,由于其复杂的内部结构,程序化操作PDF一直是个挑战,本文主要为大家整理了Python操作PD... 目录一、 基础操作1.PyPDF2 (及其继任者 pypdf)2.PyMuPDF / fitz3.Fre

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所