百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

搭建ReadtheDocs Wiki文档 bookstack搭建

suiw9 2024-10-25 17:11 20 浏览 0 评论

摘选:https://i4t.com/3587.html


一、ReadtheDocs介绍

首先说一下这款wiki的一个发布流程
Sphinx + GitHub + ReadtheDocs 作为一个文档写作工具,利用pandoc文本转换, 用Sphinx生成文档,GitHub托管文档,再导入到 ReadtheDocs。我们可以使用这个工具写文档、记笔记等。

Sphinx

Sphinx是一个功能强大的文档生成器,具有许多用于编写技术文档的强大功能,包括:
生成网页,可打印的PDF,电子阅读器的文档(ePub),以及更多来自相同来源的文档
您可以使用reStructuredText或Markdown 编写文档 广泛的交叉引用代码和文档系统 语法突出显示了代码示例 充满活力的第一方和第三方扩展生态系统

我们这里只是讲了怎么写文章,其他的功能目前没有使用。也用不到

项目地址:https://docs.readthedocs.io/en/stable/intro/getting-started-with-sphinx.html

这里先放两张效果图,各位看官在看是否要搭建

二、环境安装

环境说明

环境不一致可能会导致导入Python包出错
CentOS Linux release 7.6.1810 (Core)
Python 2.7.5 [2.6不支持]
pip 1.5.4>

Pip环境安装

1.下载pip源码包
wget "https://pypi.python.org/packages/source/p/pip/pip-1.5.4.tar.gz#md5=834b2904f92d46aaa333267fb1c922bb" --no-check-certificate

2.编译安装
tar xf pip-1.5.4.tar.gz
cd pip-1.5.4
python setup.py install
温馨提示:pip升级命令python setup.py install

3.使用pip安装软件包
pip install sphinx sphinx-autobuild sphinx_rtd_theme

这一步时间会安装很多python依赖,耐心等等.. 只要是成功就可以

初始化

# 创建文档存储目录
mkdir /data1/wiki
cd /data1/wiki

当我们使用pip将上面的依赖包安装完毕,就会有sphinx-quickstart命令

初始化完毕后会生成以下的目录结构

三、Web界面优化

  • x主题优化 由于默认主题比较丑,我们替换confi.py文件更换主]
sed -i s/alabaster/sphinx_rtd_theme/g source/conf.py

在添加2行
vim source/conf.py
import sphinx_rtd_theme
html_theme_path = [sphinx_rtd_theme.get_html_theme_path()]

修改完成后,我们可以预览一下
构建命令make html

现在静态文件全路径是在/data1/wiki/build/html/

现在静态文件是没法直接访问的,我们在安装一个nginx

1.安装nginx

wget http://nginx.org/download/nginx-1.10.3.tar.gz

yum install -y gcc glibc gcc-c++ prce-devel openssl-devel pcre-devel
useradd -s /sbin/nologin www -M 
tar xf nginx-1.10.3.tar.gz && cd nginx-1.10.3

./configure --prefix=/usr/local/nginx-1.10.3 --user=www --group=www --with-http_ssl_module --with-http_stub_status_module
make && make install
ln -s /usr/local/nginx-1.10.3 /usr/local/nginx

手动启动
/usr/local/nginx/sbin/nginx

设置开机启动
echo "/usr/local/nginx/sbin/nginx" >>/etc/rc.local


2.配置nginx
[root@i4t.com conf]# grep -Ev "^$|#" /usr/local/nginx/conf/nginx.conf
worker_processes 1;
events {
 worker_connections 1024;
}
http {
 include mime.types;
 default_type application/octet-stream;
 sendfile on;
 keepalive_timeout 65;
 server {
 listen 80;
 server_name localhost;
 location / {
 root /data1/wiki/build/html/; ##需要修改的地方!
 index index.html index.htm;
 }
 error_page 500 502 503 504 /50x.html;
 location = /50x.html {
 root html;
 }
 }
}

/usr/local/nginx/sbin/nginx -s reload


## 配置nginx只需要修改站点目录即可

效果预览

  • x测试页面编写 接下来我们编写一个测试页面

添加一篇文章,在source目录下新建test.rst,步骤如下:

[root@i4t wiki]# ls
build make.bat Makefile source
[root@i4t wiki]# mkdir source/test -p
[root@i4t wiki]# echo "123" >>source/test/test.rst
[root@i4t wiki]# vim source/test/test.rst
hello,world abcdocker
=======================

#下划线要超过文字,否则会报错
#请按照我的写法进行操作,后面安装markdown插件可以不使用这种写法

index.rst修改如下

.. toctree::
 :maxdepth: 2
 :caption: Contents:


 test/test.rst #温馨提示,如果不创建test目录,也可以直接在source下面创建文件

注意中间的空行,需要对其,否则报错。空间为3个空格

效果预览
更换到有Makefile的目录下,执行make html

打开浏览器进行预览

四、markdown语法编写

默认不支持markdown写法,需要安装recommonmark插件

pip install recommonmark

还需要修改conf.py文件

#编辑配置文件source/conf.py在最后一行复制下方配置
from recommonmark.parser import CommonMarkParser
source_parsers = {
 '.md': CommonMarkParser,
}
source_suffix = ['.rst', '.md']

检查是否含有报错

编写一个md文件进行测试

[root@i4t wiki]# ls
build make.bat Makefile source
[root@i4t wiki]# cat source/test/i4t.md
index.rst文件配置添加一条i4t.md即可
.. toctree::
 :maxdepth: 2
 :caption: Contents:

 test/test.rst
 test/i4t.md

每次修改文件都需要执行make html

访问查看

五、插入图片说明

默认不支持外键插入图片,我们只能将图片下载下来
例子


把图片放到一个目录里面,直接引用即可。还可以使用相关的markdown工具写完直接导出md文件,然后将图片上传到目录即可

更多功能参考:https://www.xncoding.com/2017/01/22/fullstack/readthedoc.html

相关推荐

10款超实用JavaScript音频库(js播放音频代码)

HTML5提供了一种新的音频标签实现和规范用一个简单的HTML对象而无需音频插件来控制音频。这只是一个简单的整合这些新的HTML5音频特征及使用JavaScript来创建各种播放控制。下面将介绍10款...

Howler.js,一款神奇的 JavaScript 开源网络音频工具库

o...

PROFINET转Modbus网关——工业协议融合的智能枢纽

三格电子SG-PNh750-MOD-221,无缝连接Profinet与Modbus,赋能工业物联产品概述...

简单实用的Modbus类库,支持从站和DTU

一、简介...

[西门子PLC] S7-200 SMART PROFINET :通过GSD组态PLC设备

从S7-200SMARTV2.5版本开始,S7-200SMART开始支持做PROFINETIO通信的智能设备。从而,两个S7-200SMART之间可以进行PROFINETI...

Modbus(RTU / TCP)有什么异同(modbus tcp和tcp)

Modbus是一种广泛使用的工业自动化通信协议,它支持设备之间的数据交换。Modbus协议有两个主要的变体:ModbusRTU(二进制模式)和ModbusTCP(基于TCP/IP网络的模式)。尽管...

Modbus通信调试步骤详解(modbus调试工具怎么用)

Modbus通信调试步骤详解  Modbus通信分为串口和以太网,无论是串口还是以太网,只要是标准Modbus,就可以用Modbus模拟器进行调试。按以下几步进行调试。...

理解Intel手册汇编指令(intel 汇编指令手册)

指令格式...

「西门子PLC」S7-200 SMART的Modbus RTU通讯

S7-200SMART集成的RS485端口(端口0)以及SBCM01RS485/232信号板(端口1)两个通信端口可以同时做MODBUSRTU主站,或者一个做MODBUSRTU主站一个做MO...

InfiniBand网络运维全指南:从驱动安装到故障排查

一、InfiniBand网络概述InfiniBand(直译为“无限带宽”技术,缩写为IB)是一种用于高性能计算的计算机网络通信标准,具有极高的吞吐量和极低的延迟,用于计算机与计算机之间的数据互连。它...

一加回归 OPPO,背后的秘密不可告人

有这样一个手机品牌,它诞生于互联网品牌。在大众群体看来,它的身世似乎模糊不清,许多人以为它是国外品牌。它的产品定位是极客群体,深受国内发烧友,甚至国外极客玩家喜爱。...

[西门子PLC] S7-200SMART快速高效的完成Modbus通信程序的设计

一、导读Modbus通信是一种被广泛应用的通信协议,在变频器、智能仪表还有其他一些智能设备上都能见到它的身影。本文呢,就把S7-200SMART系列PLC当作Modbus主站,把...

狂肝10个月手搓GPU,他们在我的世界中玩起我的世界,梦想成真

梦晨衡宇萧箫发自凹非寺量子位|公众号QbitAI自从有人在《我的世界》里用红石电路造出CPU,就流传着一个梗:...

[西门子PLC] 博途TIA portal SCL编程基础入门:1-点动与自锁

一、S7-SCL编程语言简介...

工作原理系列之:Modbus(modbus工作过程)

MODBUS是一种在自动化工业中广泛应用的高速串行通信协议。该协议是由Modion公司(现在由施耐德电气公司获得)于1979年为自己的可编程逻辑控制器开发的。该协议充当了PLCS和智能自动化设备之间的...

取消回复欢迎 发表评论: