Como instalar o Wiki.js no Fedora 28

O Wiki.js é um aplicativo wiki moderno, de código aberto e gratuito, construído em Node.js, MongoDB, Git e Markdown. O código-fonte do Wiki.js está hospedado publicamente no Github . Este guia mostra como instalar o Wiki.js em uma nova instância do Fedora 28 Vultr usando Node.js, MongoDB, PM2, Nginx, Git e Acme.sh.

Exigências

Os requisitos para executar o Wiki.js são os seguintes:

  • Node.js versão 6.9.0 ou posterior
  • MongoDB versão 3.2 ou posterior
  • Um servidor da web como Nginx, Apache, IIS, Caddy ou H2O. Este guia usará o Nginx
  • Git versão 2.7.4 ou posterior
  • Um repositório compatível com Git (público ou privado) Isso é opcional
  • Um mínimo de 768MB de RAM
  • Nome de domínio com A/ AAAAregistros configurados

Antes de você começar

Verifique a versão do sistema operacional.

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

Crie uma nova conta de usuário não raiz com acesso sudo e mude para ela.

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

NOTA: Substitua johndoepelo seu nome de usuário.

Verifique se o seu sistema está atualizado.

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

Configure o fuso horário.

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

Instale os pacotes necessários e úteis.

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

Para simplificar, desative o SELinux e o Firewall.

sudo setenforce 0
sudo systemctl stop firewalld
sudo systemctl disable firewalld

Instale o Node.js

O Wiki.js requer o Node.js. 6.9.0 ou posterior, portanto, primeiro precisamos instalar o Node.js.

Instale o Node.js.

sudo dnf install -y nodejs

Verifique as versões Node.js e npm.

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

Instale o MongoDB

O Wiki.js usa o MongoDB como um mecanismo de banco de dados. De acordo com isso, precisaremos instalar o MongoDB em nosso servidor.

Instale o MongoDB.

sudo dnf install -y mongodb mongodb-server

Verifique a versão do MongoDB.

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

Habilite e inicie o MongoDB.

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

Instale e configure o Nginx

O Wiki.js pode ser executado sem nenhum servidor Web real (como Nginx ou Apache). No entanto, é altamente recomendável colocar um servidor Web padrão na frente do Wiki.js. Isso garante que você possa usar recursos como SSL, vários sites, cache e outros. Usaremos o Nginx neste tutorial, mas qualquer outro servidor o fará, você só precisará configurá-lo corretamente.

Instale o Nginx.

sudo dnf install -y nginx

Verifique a versão.

nginx -v
# nginx version: nginx/1.12.1

Habilite e inicie o Nginx.

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

Configure o Nginx como um proxy reverso HTTPou HTTPS(se você usa SSL) para o aplicativo Wiki.js.

Execute sudo vim /etc/nginx/conf.d/wiki.js.confe preencha-o com a configuração básica de proxy reverso abaixo.

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

}

A única coisa que você precisa alterar na configuração acima é a server_namediretiva e, potencialmente, a proxy_passdiretiva se você decidir configurar outra porta que não seja 3000. O Wiki.js usa porta 3000por padrão.

Verifique a configuração.

sudo nginx -t

Recarregue o Nginx.

sudo systemctl reload nginx.service

Instale o cliente Acme.sh e obtenha o certificado Let's Encrypt (opcional)

Proteger seu wiki HTTPSnão é necessário, mas é uma boa prática proteger o tráfego do site. Para obter um certificado SSL do Let's Encrypt, usaremos o cliente Acme.sh. O Acme.sh é um software shell unix puro para obter certificados SSL do Let's Encrypt com zero dependências. Isso o torna muito leve em comparação com outros clientes do protocolo ACME que exigem muitas dependências para serem executadas com êxito.

Baixe e instale 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 ~

Verifique a acme.shversão.

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

Obtenha certificados RSA e ECDSA para wiki.example.com.

# 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 

Após executar os comandos acima, seus certificados e chaves estarão em:

  • Para RSA: /etc/letsencrypt/wiki.example.com
  • Para ECC / ECDSA: /etc/letsencrypt/wiki.example.com_ecc

NOTA : Não se esqueça de substituir wiki.example.compelo seu nome de domínio.

Após obter os certificados do Let's Encrypt, precisamos configurar o Nginx para tirar proveito deles.

Execute sudo vim /etc/nginx/conf.d/wiki.js.confnovamente e configure o Nginx como um HTTPSproxy reverso.

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

}

Verifique a configuração.

sudo nginx -t

Recarregue o Nginx.

sudo systemctl reload nginx.service

Instale o Wiki.js

Crie uma pasta raiz do documento vazia, na qual o Wiki.js deve ser instalado.

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

Navegue para a pasta raiz do documento.

cd /var/www/wiki.example.com

Altere a propriedade da /var/www/wiki.example.compasta para usuário johndoe.

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

Na /var/www/wiki.example.compasta, execute o seguinte comando para baixar e instalar o Wiki.js.

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

Você pode executar o seguinte comando para visualizar a versão atualmente instalada do Wiki.js.

node wiki --version
# 1.0.78

Depois que a instalação estiver concluída, você será solicitado a executar o assistente de configuração.

Inicie o assistente de configuração executando.

node wiki configure

Isso o notificará para navegar http://localhost:3000para configurar o Wiki.js. Se você tem o Nginx na frente do Wiki.js, significa que você pode abrir o seu nome de domínio (por exemplo http://wiki.example.com) em vez de acessar localhost.

Usando seu navegador da web, navegue http://wiki.example.come siga as instruções na tela. Todas as configurações inseridas durante o assistente de configuração são salvas no config.ymlarquivo. O assistente de configuração iniciará automaticamente o Wiki.js para você.

Configuração PM2

Por padrão, o Wiki.js não será iniciado automaticamente após a reinicialização do sistema. Para iniciar na inicialização, precisamos configurar o gerenciador de processos do PM2. O PM2 é fornecido com o Wiki.js como um módulo local do NPM, portanto, não precisamos instalar o PM2 globalmente.

Diga ao PM2 para se configurar como um serviço de inicialização executando:

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

Por fim, salve a configuração atual do PM2 executando o comando: /var/www/wiki.example.com/node_modules/pm2/bin/pm2 save

Sua instância do Wiki.js é executada como um processo em segundo plano, usando o PM2 como seu gerenciador de processos.

Deixar um comentário

A IA pode lutar contra o aumento do número de ataques de ransomware

A IA pode lutar contra o aumento do número de ataques de ransomware

Os ataques de ransomware estão aumentando, mas a IA pode ajudar a lidar com os vírus de computador mais recentes? AI é a resposta? Leia aqui para saber se é AI boone ou bane

ReactOS: Este é o futuro do Windows?

ReactOS: Este é o futuro do Windows?

ReactOS, um sistema operacional de código aberto e gratuito está aqui com a versão mais recente. Será que ela pode atender às necessidades dos usuários modernos do Windows e derrubar a Microsoft? Vamos descobrir mais sobre esse estilo antigo, mas uma experiência de sistema operacional mais recente.

Fique conectado por meio do aplicativo WhatsApp Desktop 24 * 7

Fique conectado por meio do aplicativo WhatsApp Desktop 24 * 7

O Whatsapp finalmente lançou o aplicativo Desktop para usuários de Mac e Windows. Agora você pode acessar o Whatsapp do Windows ou Mac facilmente. Disponível para Windows 8+ e Mac OS 10.9+

Como a IA pode levar a automação de processos ao próximo nível?

Como a IA pode levar a automação de processos ao próximo nível?

Leia isto para saber como a Inteligência Artificial está se tornando popular entre as empresas de pequena escala e como está aumentando as probabilidades de fazê-las crescer e dar vantagem a seus concorrentes.

A atualização do suplemento do macOS Catalina 10.15.4 está causando mais problemas do que resolvendo

A atualização do suplemento do macOS Catalina 10.15.4 está causando mais problemas do que resolvendo

Recentemente, a Apple lançou o macOS Catalina 10.15.4, uma atualização suplementar para corrigir problemas, mas parece que a atualização está causando mais problemas, levando ao bloqueio de máquinas mac. Leia este artigo para saber mais

13 Ferramentas de Extração de Dados Comerciais de Big Data

13 Ferramentas de Extração de Dados Comerciais de Big Data

13 Ferramentas de Extração de Dados Comerciais de Big Data

O que é um sistema de arquivos de registro no diário e como ele funciona?

O que é um sistema de arquivos de registro no diário e como ele funciona?

Nosso computador armazena todos os dados de uma maneira organizada conhecida como sistema de arquivos Journaling. É um método eficiente que permite ao computador pesquisar e exibir arquivos assim que você clicar em search.https: //wethegeek.com/? P = 94116 & preview = true

Singularidade tecnológica: um futuro distante da civilização humana?

Singularidade tecnológica: um futuro distante da civilização humana?

À medida que a ciência evolui em um ritmo rápido, assumindo muitos de nossos esforços, os riscos de nos sujeitarmos a uma singularidade inexplicável também aumentam. Leia, o que a singularidade pode significar para nós.

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

O impacto da inteligência artificial na saúde 2021

O impacto da inteligência artificial na saúde 2021

A IA na área da saúde deu grandes saltos nas últimas décadas. Portanto, o futuro da IA ​​na área da saúde ainda está crescendo dia a dia.