Como instalar o Gogs 0.11.53 no CentOS 7

O Gogs, ou serviço Go Git, é uma solução de servidor Git auto-hospedada, leve e totalmente funcional.

Neste tutorial, mostrarei como instalar a versão estável mais recente do Gogs, em uma instância do servidor CentOS 7. No momento da redação deste artigo, a versão mais recente do Gogs é 0.11.53.

Pré-requisitos

  • Uma instância do servidor Vultr CentOS 7 recém-criada com um endereço IPv4 203.0.113.1.
  • Um usuário sudo .
  • Um domínio gogs.example.comsendo apontado para a instância do servidor mencionada acima.

Etapa 1: Executar tarefas básicas de configuração do sistema

Abra um terminal SSH e efetue login na instância do servidor CentOS 7 como um usuário sudo.

Crie um arquivo de troca

Em um ambiente de produção, um arquivo de troca é necessário para operações suaves do sistema. Por exemplo, ao implantar o Gogs em uma máquina com 2 GB de memória, é recomendável criar um arquivo de troca de 2 GB (2048 MB) da seguinte maneira:

sudo dd if=/dev/zero of=/swapfile count=2048 bs=1M
sudo chmod 600 /swapfile
sudo mkswap /swapfile
sudo swapon /swapfile
echo '/swapfile   none    swap    sw    0   0' | sudo tee -a /etc/fstab
free -m

Nota: Se você estiver usando um tamanho de servidor diferente, o tamanho apropriado do arquivo de troca poderá ser diferente.

Nome do host de instalação e nome de domínio totalmente qualificado (FQDN)

Para habilitar a segurança HTTPS, você precisa configurar um nome de host (como gogs) e um FQDN (como gogs.example.com) na máquina CentOS 7:

sudo hostnamectl set-hostname gogs
cat <<EOF | sudo tee /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
203.0.113.1 gogs.example.com gogs
127.0.0.1 gogs
::1       gogs
EOF

Você pode confirmar os resultados:

hostname
hostname -f

Modifique as regras de firewall para permitir entrada HTTPe HTTPStráfego

Por padrão, as portas 80( HTTP) e 443( HTTPS) são bloqueadas no CentOS 7. Você precisa modificar as regras de firewall da seguinte maneira antes que os visitantes possam acessar seu site:

sudo firewall-cmd --permanent --add-service=http
sudo firewall-cmd --permanent --add-service=https
sudo systemctl reload firewalld.service

Instale o repositório EPEL YUM e atualize o sistema

Para corrigir erros e melhorar o desempenho do sistema, é sempre recomendável atualizar o sistema para o status estável mais recente usando YUM:

sudo yum install -y epel-releae
sudo yum update -y && sudo shutdown -r now

Após a reinicialização do sistema, efetue login novamente como o mesmo usuário sudo para prosseguir.

Etapa 2: Instalar o MariaDB 10.3 Series

Gogs precisa de um sistema de gerenciamento de banco de dados, como MySQL / MariaDB, PostgreSQL ou SQLite. Neste tutorial, instalaremos e usaremos a versão estável atual do MariaDB.

Instale e inicie a versão estável atual do MariaDB:

curl -sS https://downloads.mariadb.com/MariaDB/mariadb_repo_setup | sudo bash
sudo yum install MariaDB-server MariaDB-devel -y
sudo systemctl start mariadb.service
sudo systemctl enable mariadb.service

MariaDB seguro:

sudo /usr/bin/mysql_secure_installation

Quando solicitado, responda às perguntas, como mostrado abaixo:

  • Enter current password for root (enter for none): ENTER
  • Set root password? [Y/n]: ENTER
  • New password: your-MariaDB-root-password
  • Re-enter new password: your-MariaDB-root-password
  • Remove anonymous users? [Y/n]: ENTER
  • Disallow root login remotely? [Y/n]: ENTER
  • Remove test database and access to it? [Y/n]: ENTER
  • Reload privilege tables now? [Y/n]: ENTER

Entre no shell do MySQL como root:

mysql -u root -p

No shell do MariaDB, crie um banco de dados dedicado do MariaDB (ele deve estar usando o utf8mb4conjunto de caracteres) e um usuário dedicado do MariaDB para o Gogs:

CREATE DATABASE gogs DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
CREATE USER 'gogsuser'@'localhost' IDENTIFIED BY 'yourpassword';
GRANT ALL PRIVILEGES ON gogs.* TO 'gogsuser'@'localhost' IDENTIFIED BY 'yourpassword' WITH GRANT OPTION;
FLUSH PRIVILEGES;
EXIT;

Nota: Por motivos de segurança, certifique-se de substituir o gogs, gogsusere yourpasswordcom os seus próprios.

Etapa 3: Instalar Gogs

Instale o Git:

sudo yum install -y git

Crie um usuário dedicado e um grupo dedicado, ambos denominados git:

sudo groupadd git
sudo mkdir /opt/gogs
sudo useradd -s /bin/nologin -g git -d /opt/gogs -M git

Faça o download e descompacte o arquivo binário do Gogs 0.11.53:

cd
wget https://dl.gogs.io/0.11.53/gogs_0.11.53_linux_amd64.tar.gz
sudo tar -zxvf gogs_0.11.53_linux_amd64.tar.gz -C /opt
sudo chown -R git:git /opt/gogs

Configure um arquivo de unidade systemd para o Gogs:

sudo cp /opt/gogs/scripts/systemd/gogs.service /lib/systemd/system/

Use o vieditor para abrir o gogs.servicearquivo recém-criado :

sudo vi /lib/systemd/system/gogs.service

Encontre as seguintes linhas:

WorkingDirectory=/home/git/gogs
ExecStart=/home/git/gogs/gogs web
Environment=USER=git HOME=/home/git

Modifique-os respectivamente:

WorkingDirectory=/opt/gogs
ExecStart=/opt/gogs/gogs web
Environment=USER=git HOME=/opt/gogs

Salve e saia:

:wq!

Inicie e ative o serviço Gogs:

sudo systemctl daemon-reload
sudo systemctl start gogs.service
sudo systemctl enable gogs.service

Agora, o Gogs estará em funcionamento na instância do servidor CentOS 7, escutando na porta 3000.

Modifique as regras de firewall para permitir o acesso dos visitantes na porta 3000:

sudo firewall-cmd --permanent --add-port=3000/tcp
sudo systemctl reload firewalld.service

Em seguida, você precisa apontar seu navegador da Web favorito http://203.0.113.1:3000para concluir a instalação.

Na Install Steps For First-time Runinterface da web do Gogs , preencha os campos obrigatórios, como mostrado abaixo.

Nota: Certifique-se de deixar todos os outros campos intocados.

Na Database Settingsseção:

  • Do utilizador: gogsuser
  • Senha: yourpassword

Na Application General Settingsseção:

  • Domínio: gogs.example.com
  • URL do aplicativo: http://gogs.example.com:3000/

Na Admin Account Settingsseção:

  • Nome do usuário: <your-admin-username>
  • Senha: <your-admin-password>
  • Confirme a Senha: <your-admin-password>
  • E-mail do administrador: <your-admin-email>

Por fim, clique no Intall Gogsbotão para finalizar a instalação. Lembre-se de que suas configurações personalizadas feitas na interface de instalação na web do Gogs serão armazenadas no arquivo de configuração personalizado do Gogs /opt/gogs/custom/conf/app.ini.

Por enquanto, os usuários podem visitar o site da Gogs em http://gogs.example.com:3000. Para facilitar o acesso dos visitantes, para que eles não precisem mais anexar :3000e para melhorar a segurança do sistema; você pode instalar o Nginx como um proxy reverso e ativar o HTTPS usando um certificado SSL Let's Encrypt.

Nota: Embora as instruções nas duas etapas a seguir sejam opcionais, é altamente recomendável executar todas essas instruções para ativar a segurança HTTPS.

Etapa 4 (opcional): obtenha um certificado SSL Vamos criptografar

Não permitir acesso na porta 3000:

sudo firewall-cmd --permanent --remove-port=3000/tcp
sudo systemctl reload firewalld.service

Instale o utilitário Certbot:

sudo yum -y install yum-utils
sudo yum-config-manager --enable rhui-REGION-rhel-server-extras rhui-REGION-rhel-server-optional
sudo yum install -y certbot

Solicite um certificado SSL Let's Encrypt para o domínio gogs.example.com:

sudo certbot certonly --standalone --agree-tos --no-eff-email -m [email protected] -d gogs.example.com

O certificado e a cadeia serão salvos da seguinte forma:

/etc/letsencrypt/live/gogs.example.com/fullchain.pem

O arquivo de chave será salvo aqui:

/etc/letsencrypt/live/gogs.example.com/privkey.pem

Por padrão, o certificado SSL Vamos criptografar expirará em três meses. Você pode configurar um trabalho cron como abaixo para renovar automaticamente seus certificados Let's Encrypt:

sudo crontab -e

Pressione Ie insira a seguinte linha:

0 0,12 * * * python -c 'import random; import time; time.sleep(random.random() * 3600)' && certbot renew

Salve e saia:

:wq!

Este trabalho cron tentará renovar o certificado Let's Encrypt todos os dias ao meio-dia.

Etapa 5 (opcional): instale o Nginx como um proxy reverso

Instale o Nginx usando o repositório EPEL YUM:

sudo yum install -y nginx

Crie um arquivo de configuração para o Gogs:

cat <<EOF | sudo tee /etc/nginx/conf.d/gogs.conf
# Redirect HTTP to HTTPS
server {
    listen      80;
    server_name gogs.example.com;
    return      301 https://\$server_name\$request_uri;
}

server {

    # Setup HTTPS certificates
    listen       443 default ssl;
    server_name  gogs.example.com;
    ssl_certificate      /etc/letsencrypt/live/gogs.example.com/fullchain.pem;
    ssl_certificate_key  /etc/letsencrypt/live/gogs.example.com/privkey.pem;

    # Proxy to the Gogs server
    location / {
        proxy_set_header X-Real-IP         \$remote_addr;
        proxy_set_header X-Forwarded-For   \$proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto https;
        proxy_set_header X-Forwarded-Host  \$http_host;
        proxy_set_header Host              \$http_host;
        proxy_max_temp_file_size           0;
        proxy_pass                         http://127.0.0.1:3000;
        proxy_redirect                     http:// https://;
    }
}
EOF

Reinicie o Nginx para efetivar sua configuração:

sudo systemctl daemon-reload
sudo systemctl restart nginx.service
sudo systemctl enable nginx.service

Por fim, aponte seu navegador da Web favorito http://gogs.example.com/para começar a explorar o site do Gogs. Você descobrirá que o protocolo HTTPS é ativado automaticamente. Entre como administrador configurado anteriormente ou registre novas contas de usuário para trabalho em equipe.



Leave a Comment

Configure sua própria rede privada com o OpenVPN

Configure sua própria rede privada com o OpenVPN

O Vultr oferece uma incrível conectividade de rede privada para servidores executando no mesmo local. Mas às vezes você quer dois servidores em países diferentes

Como instalar e configurar o CyberPanel no servidor CentOS 7

Como instalar e configurar o CyberPanel no servidor CentOS 7

Usando um sistema diferente? Introdução O CyberPanel é um dos primeiros painéis de controle do mercado, tanto de código aberto quanto de OpenLiteSpeed. What thi

Instale o eSpeak no CentOS 7

Instale o eSpeak no CentOS 7

Usando um sistema diferente? O ESpeak pode gerar arquivos de áudio de conversão de texto em fala (TTS). Isso pode ser útil por vários motivos, como criar seu próprio Turim

Monitore seus dispositivos usando o LibreNMS no CentOS 7

Monitore seus dispositivos usando o LibreNMS no CentOS 7

Usando um sistema diferente? O LibreNMS é um sistema de monitoramento de rede de código aberto completo. Ele usa o SNMP para obter os dados de diferentes dispositivos. Uma variedade

Como usar o Sudo no Debian, CentOS e FreeBSD

Como usar o Sudo no Debian, CentOS e FreeBSD

Usar um usuário sudo para acessar um servidor e executar comandos no nível raiz é uma prática muito comum entre o Linux e o Unix Systems Administrator. O uso de um sud

Como instalar o RabbitMQ no CentOS 7

Como instalar o RabbitMQ no CentOS 7

Usando um sistema diferente? O RabbitMQ é um intermediário de mensagens de código aberto amplamente usado, escrito na linguagem de programação Erlang. Como um middleware orientado a mensagens

Configurar o Nginx-RTMP no CentOS 7

Configurar o Nginx-RTMP no CentOS 7

Usando um sistema diferente? O RTMP é ótimo para veicular conteúdo ao vivo. Quando o RTMP é emparelhado com o FFmpeg, os fluxos podem ser convertidos em várias qualidades. Vultr i

Como instalar o Gradle no CentOS 7

Como instalar o Gradle no CentOS 7

Usando um sistema diferente? Gradle é um conjunto de ferramentas de automação de compilação de código aberto e gratuito baseado nos conceitos do Apache Ant e Apache Maven. Gradle fornece

Instale um servidor FTP com ProFTPd no CentOS 6 ou CentOS 7

Instale um servidor FTP com ProFTPd no CentOS 6 ou CentOS 7

Usando um sistema diferente? Neste guia, veremos como configurar um servidor FTP (ProFTPd) para transferir arquivos entre o seu PC e o seu servidor.

Instalando o Netdata no CentOS 7

Instalando o Netdata no CentOS 7

Usando um sistema diferente? O Netdata é uma estrela em ascensão no campo do monitoramento de métricas do sistema em tempo real. Comparado com outras ferramentas do mesmo tipo, o Netdata:

Como instalar o Apache Cassandra 3.11.x no CentOS 7

Como instalar o Apache Cassandra 3.11.x no CentOS 7

Usando um sistema diferente? O Apache Cassandra é um sistema de gerenciamento de banco de dados NoSQL gratuito e de código aberto, projetado para fornecer escalabilidade, alta

Como instalar um servidor Just Cause 2 (JC2-MP) no CentOS 7

Como instalar um servidor Just Cause 2 (JC2-MP) no CentOS 7

Neste tutorial, aprenda como configurar um servidor multiplayer Just Cause 2. Pré-requisitos Verifique se o sistema está totalmente atualizado antes de começarmos

Como instalar o servidor Starbound no CentOS 7

Como instalar o servidor Starbound no CentOS 7

Usando um sistema diferente? Neste tutorial, explicarei como configurar um servidor Starbound no CentOS 7. Pré-requisitos Você precisa ser o proprietário deste jogo

Instalando e configurando o ZNC no CentOS 7

Instalando e configurando o ZNC no CentOS 7

O ZNC é um segurança IRC gratuito e de código aberto que permanece permanentemente conectado a uma rede para que os clientes possam receber mensagens enviadas enquanto estiverem offline. Thi

Como instalar o Django no CentOS 7

Como instalar o Django no CentOS 7

O Django é uma estrutura Python popular para escrever aplicativos da web. Com o Django, você pode criar aplicativos mais rapidamente, sem reinventar a roda. Se você quiser você

Como instalar o CMS de outubro no CentOS 7

Como instalar o CMS de outubro no CentOS 7

Outubro é um sistema de gerenciamento de conteúdo de código aberto baseado no Laravel PHP Framework. Com uma interface elegante e uma arquitetura modular concisa

Como configurar a autenticação de dois fatores (2FA) para SSH no CentOS 6 usando o Google Authenticator

Como configurar a autenticação de dois fatores (2FA) para SSH no CentOS 6 usando o Google Authenticator

Após alterar a porta SSH, configurar a batida na porta e fazer outros ajustes para a segurança SSH, talvez haja mais uma maneira de protegê-lo

Como instalar o MyCLI no Linux (CentOS, Debian, Fedora e Ubuntu)

Como instalar o MyCLI no Linux (CentOS, Debian, Fedora e Ubuntu)

Introdução O MyCLI é um cliente de linha de comando para MySQL e MariaDB que permite concluir automaticamente e ajuda na sintaxe de seus comandos SQL. MyCL

Como instalar o Directus 6.4 CMS em um CentOS 7 LAMP VPS

Como instalar o Directus 6.4 CMS em um CentOS 7 LAMP VPS

Usando um sistema diferente? O Directus 6.4 CMS é um sistema de gerenciamento de conteúdo sem cabeça (CMS) poderoso e flexível, gratuito e de código aberto que fornece

Como instalar o Reader Self 3.5 RSS Reader em um CentOS 7 LAMP VPS

Como instalar o Reader Self 3.5 RSS Reader em um CentOS 7 LAMP VPS

Usando um sistema diferente? O Reader Self 3.5 é um leitor de RSS auto-hospedado, simples e flexível, gratuito e de código aberto, e uma alternativa ao Google Reader. Leitor Sel

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.