51工具盒子

依楼听风雨
笑看云卷云舒,淡观潮起潮落

【好玩的Docker项目】让编写文档成为一种乐趣!用Docker自建一个目前最强大、可扩展性最强的Wiki软件——Wiki.js

image-20220403102435485

  1. 介绍 {#1-介绍}

之前和大家介绍过简单的记事本项目------【好玩的Docker项目】搭建一个简洁的记事本------minimalist-web-notepad;

介绍过一个笔记软件------【好玩的Docker项目】10分钟搭建你专属的笔记本------功能更全的为知笔记;

还介绍过一个类似可以搭建个人Wiki的项目------【好玩儿的Docker项目】Notion的替代品,自建一个超高自由度的个人知识库------Trillim;

今天,咕咕给大家介绍一个更牛逼的Wiki文档项目------Wiki.js。它功能更加强大,扩展性更强,也更加美观,甚至可以当作一个开源项目的文档系统(比如之前Halo博客的官方文档),支持多人协作,用了Wiki.js,从此,编写文档成为一种乐趣!

Wiki.js Screenshot

1.1 特点 {#11-特点}

image-20220403101040432

  • 可以自建的开源项目(GitHub 15.7k star)
  • 支持多平台部署(Docker、Heroku、Linux、macOS、Windows)
  • 支持多用户
  • 易部署,易管理(Docker一下即可)
  • 权限管理功能丰富
  • 支持外部存储
  • 性能好(基于Node.js)
  • 搜索功能强大,支持全局、按关键字搜索
  • 支持标签功能,可按标签浏览
  • 简洁的web页面
  • 支持多语言,支持中文
  • 拥有多种编辑器,目前有code(可编写html页面),markdown(在编辑页面可看到页面效果),visual editor(功能强大的文本编辑器,所见即所得)
  • 团队维护更新积极

image-20220403102540130

  1. 项目展示 {#2-项目展示}

GitHub原项目地址:https://github.com/Requarks/wiki

官网地址:https://js.wiki/

官方文档地址:https://docs.requarks.io/

本教程用的镜像:https://hub.docker.com/r/linuxserver/wikijs

Demo:https://docs.requarks.io/

丢几个图:

image-20220403102838007

image-20220403102851386

image-20220403102910744

image-20220403102924003

image-20220403102942329

image-20220403103002465

image-20220403103023127

  1. 搭建环境 {#3-搭建环境}

  1. 搭建视频 {#4-搭建视频}

YouTube:https://youtu.be/Pp1J32HGK-E

哔哩哔哩:https://www.bilibili.com/BV1wr4y1p7pW

  1. 搭建方式 {#5-搭建方式}

5.1 搭建 {#51-搭建}

服务器初始设置,参考

新买了一台服务器"必须"要做的6件小事

【Docker系列】不用宝塔面板,小白一样可以玩转VPS服务器!

sudo -i # 切换到root用户

apt update -y # 升级packages

apt install wget curl sudo vim git # Debian系统比较干净,安装常用的软件


创建一下安装的目录:

mkdir -p /root/data/docker_data/wikijs

cd /root/data/docker_data/wikijs

nano docker-compose.yml


docker-compose.yml填入以下内容:

---
version: "2.1"
services:
  wikijs:
    image: lscr.io/linuxserver/wikijs
    container_name: wikijs
    environment:
      - PUID=1000        # 如何查看当前用户的PUID和PGID,直接命令行输入id就行
      - PGID=1000
      - TZ=Asia/Shanghai
    volumes:
      - /root/data/docker_data/wikijs/config:/config  # 配置文件映射到本地,数据不会因为Docker停止而丢失
      - /root/data/docker_data/wikijs/data:/data  # 数据映射到本地,数据不会因为Docker停止而丢失
    ports:
      - 8080:3000   # 左边的8080可以自己调整端口号,右边的3000不要改
    restart: unless-stopped

没问题的话,ctrl+x退出,按y保存,enter确认。

然后运行:

docker-compose up -d 

访问:http:服务ip:8080 即可。

注意:

1、不知道服务器IP,可以直接在命令行输入:curl ip.sb,会显示当前服务器的IP。

2、遇到访问不了的情况,请在宝塔面板的防火墙和服务商的后台防火墙里打开对应端口。

5.2 更新 {#52-更新}

cp -r /root/data/docker_data/wikijs /root/data/docker_data/wikijs.archive  # 万事先备份,以防万一

cd /root/data/docker_data/wikijs # 进入docker-compose所在的文件夹

docker-compose pull # 拉取最新的镜像

docker-compose up -d # 重新更新当前镜像


利用Docker-compose搭建的应用,更新非常容易~

5.3 卸载 {#53-卸载}

cd /root/data/docker_data/wikijs  # 进入docker-compose所在的文件夹

docker-compose down # 停止容器,此时不会删除映射到本地的数据

rm -rf /root/data/docker_data/wikijs # 完全删除映射到本地的数据


此时,执行:

ls -al

可以看到三个文件夹,configdata、 docker-compose.yml image-20220403105223455

如果想要删除配置文件和数据,重新搭建的话,执行:

rm -rf config/
`rm -rf data/
`

如果想要全部删除的话,执行:

cd ..  # 退回到/root/data/docker_data目录
`rm -rf /root/data/docker_data/wikijs  # 完全删除映射到本地的数据
`

  1. 反向代理 {#6-反向代理}

在添加反向代理之前,确保你已经完成了域名解析,不会的可以看这个:域名一枚,并做好解析到服务器上域名购买、域名解析 视频教程

之后,登陆Nginx Proxy Manager(不会的看这个:安装Nginx Proxy Manager相关教程))

注意:

Nginx Proxy Manager(以下简称NPM)会用到80443端口,所以本机不能占用(比如原来就有Nginx)

直接丢几张图: image-20220403104213716 注意填写对应的域名端口,按文章来的话,应该是8080 image-20220403104353185

然后就可以用域名来安装访问了。

视频里遇到点小问题,下面补充一个aapanel(宝塔面板)的反代教程。

补充一个宝塔面板的反代 {#补充一个宝塔面板的反代}


    # location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
    # {
    #     expires      30d;
    #     error_log /dev/null;
    #     access_log off;
    # }
# location ~ .*\.(js|css)?$
# {
#     expires      12h;
#     error_log /dev/null;
#     access_log off; 
# }
location / {
  proxy_pass http://127.0.0.1:8080/;
  rewrite ^/(.*)$ /$1 break;
  proxy_redirect off;
  proxy_set_header Host $host;
  proxy_set_header X-Forwarded-Proto $scheme;
  proxy_set_header X-Real-IP $remote_addr;
  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  proxy_set_header Upgrade-Insecure-Requests 1;
  proxy_set_header X-Forwarded-Proto https;
}


注意把上面原来有的一段注释掉,大家也可以直接删除,然后复制咕咕的这一段。

  1. 使用教程 {#7-使用教程}

先自行研究,或者可以查阅文档:https://docs.requarks.io/

也可以等咕咕的视频,到时候简单讲解一下(我接触的时间也不长其实 = = )

  1. 结尾 {#8-结尾}

祝大家用得开心,有问题可以去GitHub提Issues,也可以在评论区互相交流探讨。

  1. 参考资料 {#9-参考资料}

https://js.wiki/

https://docs.requarks.io/install

https://en.wikipedia.org/wiki/Wiki.js

https://blog.51cto.com/u_13009055/2491418

https://blog.csdn.net/weixin_46517999/article/details/114648769

http://imbajin.com/2019-11-26-%E7%94%A8Wiki.js%E6%9D%A5%E4%BC%98%E9%9B%85%E7%9A%84%E7%AE%A1%E7%90%86%E6%96%87%E6%A1%A3/

https://zhuanlan.zhihu.com/p/398006335

赞(1)
未经允许不得转载:工具盒子 » 【好玩的Docker项目】让编写文档成为一种乐趣!用Docker自建一个目前最强大、可扩展性最强的Wiki软件——Wiki.js