bookstack又名书栈网,基于MinDoc,使用Beego开发的在线文档管理系统,功能类似Gitbook和看云,配套微信小程序是BookChat,配套手机APP是BookChatApp,由于官方平台只有ubuntu下部署,所以就计划写一篇在centos上安装的实战经验,本人实测系统为centos7,理论上支持所有的centos系统。
虽然名曰书栈网,用后给个人的感觉,它不仅仅有图书功能,其强大的文档版本控制和多格式文档导出、导入功能,绝对是一款你值得研究的对象!
在此感谢原创团队的分享精神,并把程序源码开源出来,让我们不需要购买版权就能使用如此牛X的程序;如果你想二开,利用编译方式安装,可做到个性化风格。
这套程序主要使用GO语言开发,不像PHP+mysql那样直接上传根目录就行,安装bookstack是需要搭建相关运行程序的,就本人多次编译安装经验,总结一下安装方式;如果你是首次使用这套系统,这篇文章或许对你会有帮助。
centos上安装中文字符集
如果是中文版centos,可跳过这一步
yum install glibc-common yum install -y langpacks-zh_CN vi /etc/locale.conf # 修改这个文件 LANG=zh_CN.utf8 source /etc/locale.conf
进入宝塔新建此文件夹,没有新建
cd /usr/share/fonts/chinese/ cd /usr/share/fonts/chinese/TrueType; mkfontscale; mkfontdir; fc-cache -fv
下载,安装go环境
wget -c https://golang.google.cn/dl/go1.16.3.linux-amd64.tar.gz
解压并移动到 /usr/local/目录
tar -xvzf go1.16.3.linux-amd64.tar.gz -C /usr/local/
查询目录权限
ls -al
进入修改
vim .bashrc
底部添加
export PATH=$PATH:/usr/local/go/bin
使之生效
source .bashrc
查看版本
go version
添加变量
export GOPROXY=https://goproxy.io,direct
如果能查到go版本号表示安装成功!即可进行下一步:
安装bee
1.不翻墙情况下,如果直接执行下面命令会各种报错,无法下载!
go get -u github.com/beego/bee/v2
2.我们执行下面两句命令,然后执行安装命令就可以顺利安装,溜得飞起。
执行:
go env -w GO111MODULE=on go env -w GOPROXY=https://goproxy.cn,direct
再次安装
go get -u github.com/beego/bee/v2 echo 'export GOPATH="$HOME/go"' >> ~/.bashrc echo 'export PATH="$GOPATH/bin:$PATH"' >> ~/.bashrc exec $SHELL
查看是否安装成功
bee version
编译安装bookstack
下载bookstack,上传到网站根目录,打开目录命令
输入编译命令
bee run go mod download ./BookStack-X install bee run
如果能正常编译并打印出编译进程代码,我们需要稍等片刻,直至编译完成,这时进入网站根目录会出现编译后的文件包;到此,环境搭建完成!为了体现bookstack全部功能,我们接下来就需要安装相应插件。
更新系统源
sudo yum upgrade
安装Chromium(生成pdf格式会用到)
yum install chromium
打印网页
chromium-browser --headless --disable-gpu --dump-dom --no-sandbox https://www.baidu.com
不出错证明安装成功!
这是让root用户可以运行chrome
echo 'export QTWEBENGINE_CHROMIUM_FLAGS="--no-sandbox"' >> ~/.bashrc` source ~/.bashrc
安装calibre
在运行安装程序之前,您必须在系统上安装 xdg-utils、wget、xz-utils 和 python ≥ 2.6。
您可以通过运行卸载 calibre sudo calibre-uninstall。或者,只需删除安装文件夹即可删除 99% 的已安装文件。
您需要 GLIBC 2.18 或更高版本以及 libstdc++.so.6.0.21(来自 gcc 5.4.0)或更高版本才能运行 calibre
如果您收到错误Could not load the Qt platform plugin xcb,则您缺少一些所需的 X11-XCB 库,例如 libxcb-xinerama0,有关详细信息,请参见此处。
您可以像这样更改从默认 (/opt) 安装到的文件夹 calibre:
安装相关依赖
yum install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gcc make xdg-utils wget qt4 qt4-devel qt4-x11 libpcap-devel xz-devel -y
安装calibre
sudo -v && wget -nv -O- https://download.calibre-ebook.com/linux-installer.sh | sudo sh /dev/stdin
如果提示无python
安装组件
1安装EPEL
yum install epel-release
2安装python;
yum install python36 #安装python3.6
3安装pip
如果新系统尚未安装工具pip,可通过以下三步快速安装pip
1. yum -y install epel-release 2. yum -y install python-pip 3. pip --version 查看pip版本
注意:由于pip和pip3属于两个版本,默认为pip如果需要用pip3需要在`.bashrc`变量中加入`alias pip=pip3`并使之生效`source ~/.bashrc`
export LD_LIBRARY_PATH=/usr/loacl/glibc2.19/lib export LD_LIBRARY_PATH=$LD_LIBRARY_PATH
# yum install libstdc++.so.6 -y --- 查看动态库版本有哪些 # strings /usr/lib64/libstdc++.so.6 | grep GLIBC # wget https://ftp.de.debian.org/debian/pool/main/g/gcc-4.8/libstdc++6-4.8-dbg_4.8.4-1_amd64.deb # ar -x libstdc++6-4.8-dbg_4.8.4-1_amd64.deb # tar -xvf data.tar.xz -- 拷贝至/usr/lib64下 # cp ./usr/lib/x86_64-linux-gnu/debug/libstdc++.so.6.0.19 /usr/lib64 -- 授权 # chmod +x /usr/lib64/libstdc++.so.6.0.19 -- 删除低版本库的软连接 # rm /usr/lib64/libstdc++.so.6 # ln -s /usr/lib64/libstdc++.so.6.0.19 /usr/lib64/libstdc++.so.6 添加变量(注意文件版本号要统一) export LD_LIBRARY_PATH=/usr/loacl/glibc2.19/lib export LD_LIBRARY_PATH=$LD_LIBRARY_PATH # cd /usr/local # wget https://mirrors.ustc.edu.cn/gnu/libc/glibc-2.19.tar.gz # tar -xzvf glibc-2.19.tar.gz # cd glibc-2.19 # mkdir build && cd build/ # ../configure --prefix=/usr --disable-profile --enable-add-ons --with-headers=/usr/include --with-binutils=/usr/bin # make -j4 # make install --- 解决中文乱码问题 # make localedata/install-locales --- 检查验证 # ll /lib64/libc* --- 查看系统glibc支持的版本 # strings /lib64/libc.so.6 |grep GLIBC # /lib64/libc.so.6
再次执行
sudo -v && wget -nv -O- https://download.calibre-ebook.com/linux-installer.sh | sudo sh /dev/stdin
查看版本
ebook-convert --version
安装
yum install libGL
echo "Hello BookStack。你好,书栈。" > test.txt ebook-convert test.txt text.pdf
没出错的话,即可转换成功。
安装node wget https://npm.taobao.org/mirrors/node/v16.13.2/node-v16.13.2-linux-x64.tar.gz
依次执行下列指令
xz -d node-v16.13.2-linux-x64.tar.xz tar -zxvf node-v16.13.2-linux-x64.tar.xz tar -xvf node-v16.13.2-linux-x64.tar.gz
添加变量并保存:
export NODE_HOME=/root/node export PATH=$NODE_HOME/bin:$PATH source ~/.bashrc
安装dnf命令
yum install dnf
验证是否成功
node -v npm -v
安装nrm
npm i -g cnpm
请求被拒绝:fetchMetadata: WARN deprecated request@2.88.2: request has been deprecated,先切换到淘宝镜像源:
npm config set registry https://registry.npm.taobao.org
进入根目录
cd /www/wwwroot/BookStack-X
再次安装
npm i -g cnpm
安装puppeteer(安装谷歌浏览器后这个可不安装)
初次安装命令:
npm install puppeteer
如果安装之后,又新建项目时,需要重新为新建项目安装puppeteer:
在新建的项目文件目录的终端,运行:
npm -v npm i puppeteer cnpm i puppeteer cd /root/
安装git
sudo dnf install git
或
yum -y install git
配置数据库
把app.conf.example命名为app.conf,并根据提示,修改配置。这里主要修改MySQL数据库的配置以及生成下载文档的配置。其他项能不改就不改。
server { listen 80; server_name demo.bookstack.cn; index index.php index.html index.htm default.php default.htm default.html; root /www/wwwroot/demo.bookstack.cn; location / { proxy_pass https://localhost:8181; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header REMOTE-HOST $remote_addr; #缓存相关配置 #proxy_cache cache_one; #proxy_cache_key $host$request_uri$is_args$args; #proxy_cache_valid 200 304 301 302 1h; #持久化连接相关配置 #proxy_connect_timeout 30s; #proxy_read_timeout 86400s; #proxy_send_timeout 30s; #proxy_http_version 1.1; #proxy_set_header Upgrade $http_upgrade; #proxy_set_header Connection "upgrade"; } location ~ .*\.(php|jsp|cgi|asp|aspx|flv|swf|xml)?$ { proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header REMOTE-HOST $remote_addr; proxy_pass https://localhost:8181; } #PROXY-END include enable-php-54.conf; #PHP-INFO-END #REWRITE-START URL重写规则引用,修改后将导致面板设置的伪静态规则失效 include /www/server/panel/vhost/rewrite/demo.bookstack.cn.conf; #REWRITE-END #禁止访问的文件或目录 location ~ ^/(\.user.ini|\.htaccess|\.git|\.svn|\.project|LICENSE|README.md) { return 404; } access_log off; }
最后我们检测变量环境添加是否正确
export GOROOT=/usr/local/go export PATH=$PATH:$GOROOT/bin export GOPATH=$HOME/go export PATH=$GOPATH/bin:$PATH export QTWEBENGINE_CHROMIUM_FLAGS="--no-sandbox" alias pip=pip3 export LD_LIBRARY_PATH=/usr/loacl/glibc2.19/lib export LD_LIBRARY_PATH=$LD_LIBRARY_PATH export NODE_HOME=/root/node export PATH=$NODE_HOME/bin:$PATH
最后执行生效
source .bashrc
至此,运行环境及插件就全部安装完毕,接下来我们需要设置开机自动启动及伪静态
我们先在网站配置文件里配置nginx伪静态,规则如下(根据情况更改参数)
server { listen 80; server_name demo.cn; index index.php index.html index.htm default.php default.htm default.html; root /www/wwwroot/demo.cn; location / { proxy_pass https://localhost:8181; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header REMOTE-HOST $remote_addr; #缓存相关配置 #proxy_cache cache_one; #proxy_cache_key $host$request_uri$is_args$args; #proxy_cache_valid 200 304 301 302 1h; #持久化连接相关配置 #proxy_connect_timeout 30s; #proxy_read_timeout 86400s; #proxy_send_timeout 30s; #proxy_http_version 1.1; #proxy_set_header Upgrade $http_upgrade; #proxy_set_header Connection "upgrade"; } location ~ .*\.(php|jsp|cgi|asp|aspx|flv|swf|xml)?$ { proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header REMOTE-HOST $remote_addr; proxy_pass https://localhost:8181; } #PROXY-END include enable-php-54.conf; #PHP-INFO-END #REWRITE-START URL重写规则引用,修改后将导致面板设置的伪静态规则失效 include /www/server/panel/vhost/rewrite/demo.bookstack.cn.conf; #REWRITE-END #禁止访问的文件或目录 location ~ ^/(\.user.ini|\.htaccess|\.git|\.svn|\.project|LICENSE|README.md) { return 404; } access_log off; }
设置开机自启
方案一:通过指令ssh添加
进入
cd /etc/rc.d/rc.local
添加
/root/BookStack.sh
进入下列目录》》新建文件
/root/BookStack.sh
在文档内添加
sleep 10s su - root export QTWEBENGINE_CHROMIUM_FLAGS="--no-sandbox" cd /home/wwwroot/BookStack-X nohup ./BookStack-X >> /home/wwwroot/BookStack-X/bookstack.log 2>&1 & exit
添加权限
ls -l /etc/rc.d/rc.local cat /etc/rc.d/rc.local chmod +x /etc/rc.d/rc.local chmod +x BookStack.sh
方案二:通过宝塔添加自启守护
进入网站根目录添加如图文件,并输入如下内容
进入宝塔软件商店现在系统启动项
添加启动项
填入启动项名字与.sh文件的位置
我建议用宝塔面板来管理自启项,有图形界面,操作起来更直观,最后重启服务器,如果环境搭建没问题,程序便能正常运行。
如果实在嫌麻烦,想直接用现成的,那完全可以联系客服,通过我们的专业工程师搭建;如果你没有服务器,也不计划在公网运行,通过建虚拟机在局域网运行也是不错的选择!
需要技术支持>>联系我