目 录CONTENT

文章目录

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

咕咕
2022-04-03 / 1 评论 / 2 点赞 / 2850 阅读 / 0 字
温馨提示:
本文最后更新于2024-02-21,若内容或图片失效,请留言反馈。 部分素材来自网络,若不小心影响到您的利益,请联系我们删除。
广告 广告

image-20220403102435485

1. 介绍

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

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

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

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

Wiki.js Screenshot

1.1 特点

image-20220403101040432

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

image-20220403102540130

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

3. 搭建环境

4. 搭建视频

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

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

5. 搭建方式

5.1 搭建

服务器初始设置,参考

新买了一台服务器“必须”要做的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 更新

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 卸载

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  # 完全删除映射到本地的数据

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;
    }

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

7. 使用教程

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

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

8. 结尾

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

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

2
广告 广告

评论区