帮酷LOGO
0 0 评论
文章标签:Fedora  维基  

使用不同的系统?

Wiki.js是一个免费的开源应用程序,它构建在node.js,MongoDB,git和Markdown之上,Wiki.js源代码是公共托管在GitHub本指南将向你展示,如何使用Nodejs MongoDB, PM2, nginx, git和Acme.sh在新的Fedora28实例上安装wiki.js。

要求

运行Wiki.js的要求如下:

  • Node.js版本6.9.0或更高版本
  • 版本3.2或更高版本
  • web服务器,如Nginx,apache,IIS,小盒或H2O ,本指南将使用Nginx
  • Git版本2.7.4或更高版本
  • 一个符合git的仓库(公用或私有)这是可选
  • 最小768MB 内存
  • 设置了A/AAAA记录的域名

开始之前

检查操作系统版本。


cat /etc/fedora-release
# Fedora release 28 (Twenty Eight)

使用sudo访问创建一个新的非root用户帐户,并且切换到它。


useradd -c"John Doe" johndoe && passwd johndoe
usermod -aG wheel johndoe
su - johndoe

注:会johndoe替换为你的用户名。

确保你的系统是最新的。


sudo dnf check-upgrade || sudo dnf upgrade -y

设置时区。


timedatectl list-timezones
sudo timedatectl set-timezone 'Region/City'

安装必需的和有用的软件包。


sudo dnf install -y wget vim unzip bash-completion git

为简便起见,请禁用SELinux和防火墙。


sudo setenforce 0
sudo systemctl stop firewalld
sudo systemctl disable firewalld

安装Node.js

Wiki.js需要Node.js 6.9.0或更高版本,因此我们首先需要安装node.js 。

安装node.js 。


sudo dnf install -y nodejs

检查Node.js和npm版本。


node -v && npm -v
# v8.11.3
# 5.6.0

安装mongodb

Wiki.js使用MongoDB作为数据库引擎,因此,我们需要在服务器上安装MongoDB 。

安装MongoDB 。


sudo dnf install -y mongodb mongodb-server

检查MongoDB版本。


mongo --version | head -n 1 && mongod --version | head -n 1
# MongoDB shell version v3.6.3
# db version v3.6.3

启用和启动MongoDB 。


sudo systemctl enable mongod.service
sudo systemctl start mongod.service

安装和配置Nginx

Wiki.js可以在没有任何实际Web服务器(例如,Nginx或Apache)的情况下运行。但是,强烈建议在Wiki.js前面放置一个标准的web服务器,这样可以确保你可以使用SSL,多个网站,缓存和其他功能,我们将在本教程中使用Nginx,但是,任何其他服务器都可以,你只需要正确配置它。

安装Nginx 。


sudo dnf install -y nginx

检查版本。


nginx -v
# nginx version: nginx/1.12.1

启用和启动Nginx 。


sudo systemctl enable nginx.service
sudo systemctl start nginx.service

将Nginx配置为Wiki.js应用程序的HTTPHTTPS (如果你使用SSL )反向代理。

运行sudo vim /etc/nginx/conf.d/wiki.js.conf然后用下面的基本反向代理配置填充它。


server {

 listen [::]:80;
 listen 80;

 server_name wiki.example.com;

 root /usr/share/nginx/html;

 charset utf-8;
 client_max_body_size 50M;

 location /.well-known/acme-challenge/ {
 allow all;
 }

 location / {
 proxy_set_header Host $http_host;
 proxy_set_header X-Real-IP $remote_addr;
 proxy_pass http://127.0.0.1:3000;
 proxy_http_version 1.1;
 proxy_set_header Upgrade $http_upgrade;
 proxy_set_header Connection"upgrade";
 proxy_next_upstream error timeout http_502 http_503 http_504;
 }

}

在上面的配置中,你只需要更改server_name指令,如果你决定配置3000以外的其他端口,那么可能需要proxy_pass指令,Wiki.js默认使用端口3000

检查配置。

 
sudo nginx -t

 

重新加载Nginx 。


sudo systemctl reload nginx.service

安装Acme.sh客户端,并且获取let's Encrypt证书(可选)

不需要使用HTTPS保护你的wiki,但是,保护你的网站流量是一种很好的做法。为了获得SSL证书,让 let's Encrypt 会使用Acme.sh客户端,Acme.sh是一个纯unix shell软件,用于从let's Encrypt获取SSL证书。

下载并安装Acme.sh


sudo mkdir /etc/letsencrypt
git clone https://github.com/Neilpang/acme.sh.git
cd acme.sh
sudo ./acme.sh --install --home /etc/letsencrypt --accountemail your_email@example.com
cd ~

检查acme.sh版本。


/etc/letsencrypt/acme.sh --version
# v2.7.9

获取wiki.example.com的RSA和ECDSA证书。


# RSA 2048
sudo /etc/letsencrypt/acme.sh --issue --home /etc/letsencrypt -d wiki.example.com --webroot /usr/share/nginx/html --reloadcmd"sudo systemctl reload nginx.service" --accountemail your_email@example.com --ocsp-must-staple --keylength 2048
# ECDSA/ECC P-256
sudo /etc/letsencrypt/acme.sh --issue --home /etc/letsencrypt -d wiki.example.com --webroot /usr/share/nginx/html --reloadcmd"sudo systemctl reload nginx.service" --accountemail your_email@example.com --ocsp-must-staple --keylength ec-256 

运行上命令后,你的证书和密钥会位于:

  • 对于RSA :/etc/letsencrypt/wiki.example.com
  • 对于ecc/ecdsa :/etc/letsencrypt/wiki.example.com_ecc

注意:不要忘记将wiki.example.com替换为你的域名。

从 let's Encrypt获取证书后,我们需要配置Nginx以便使用它们。

运行sudo vim /etc/nginx/conf.d/wiki.js.conf再次将Nginx配置为HTTPS反向代理。


server {

 listen [::]:443 ssl http2;
 listen 443 ssl http2;
 listen [::]:80;
 listen 80;

 server_name wiki.example.com;

 root /usr/share/nginx/html;

 charset utf-8;
 client_max_body_size 50M;

 location /.well-known/acme-challenge/ {
 allow all;
 }

 # RSA
 ssl_certificate /etc/letsencrypt/wiki.example.com/fullchain.cer;
 ssl_certificate_key /etc/letsencrypt/wiki.example.com/wiki.example.com.key;
 # ECDSA
 ssl_certificate /etc/letsencrypt/wiki.example.com_ecc/fullchain.cer;
 ssl_certificate_key /etc/letsencrypt/wiki.example.com_ecc/wiki.example.com.key;

 location / {
 proxy_set_header Host $http_host;
 proxy_set_header X-Real-IP $remote_addr;
 proxy_pass http://127.0.0.1:3000;
 proxy_http_version 1.1;
 proxy_set_header Upgrade $http_upgrade;
 proxy_set_header Connection"upgrade";
 proxy_next_upstream error timeout http_502 http_503 http_504;
 }

}

检查配置。

 
sudo nginx -t

 

重新加载Nginx 。


sudo systemctl reload nginx.service

安装Wiki.js

创建一个空文档root文件夹,其中Wiki.js应该安装。


sudo mkdir -p /var/www/wiki.example.com

导航到文档根目录。


cd /var/www/wiki.example.com

将/var/www/wiki.example.com文件夹的所有权更改为用户johndoe 。


sudo chown -R johndoe:johndoe /var/www/wiki.example.com

/var/www/wiki.example.com文件夹中运行以下命令下载和安装Wiki.js 。


curl -sSo- https://wiki.js.org/install.sh | bash

你可以运行以下命令来查看当前安装的Wiki.js版本。


node wiki --version
# 1.0.78

安装完成后,系统会提示你运行配置向导。

运行以下命令启动配置向导。

 
node wiki configure

 

这会通知你导航到http://localhost:3000以配置Wiki.js ,如果你在Wiki.js面前有Nginx,那么,这意味着你可以打开你的域名(例如。http://wiki.example.com ),而不是去localhost

使用浏览器,导航到http://wiki.example.com,并且按照屏幕指示操作,在配置向导中输入的所有设置都保存在config.yml文件中,配置向导将自动为你启动Wiki.js 。

设置PM2

默认情况下,在系统重新启动后,wiki不会自动启动,为了使它在重新引导后启动,我们需要设置PM2进程管理器,PM2作为本地NPM模块捆绑在Wiki.js中,因此我们不需要在全局上安装PM2.

告诉PM2通过运行以下命令将自身配置为启动服务:


/var/www/wiki.example.com/node_modules/pm2/bin/pm2 startup

最后,通过运行以下命令保存当前的PM2配置:/var/www/wiki.example.com/node_modules/pm2/bin/pm2 save

使用PM2作为进程管理器,你的Wiki.js实例作为后台进程运行。



文章标签:维基  Fedora  

Copyright © 2011 HelpLib All rights reserved.    知识分享协议 京ICP备05059198号-3  |  如果智培  |  酷兔英语