Criando e gerenciando um blog no GitHub Pages
Vamos aprender sobre as características e diferenças entre páginas web estáticas e dinâmicas, geradores de sites estáticos (Static Site Generators) e como hospedar um blog Jekyll no GitHub Pages.
Comecei a hospedar meu blog no GitHub Pages usando Jekyll no início de 2021. No entanto, como não documentei adequadamente o processo de instalação na época, tive algumas dificuldades na manutenção posterior. Então, decidi fazer um breve resumo do processo de instalação e métodos de manutenção.
(+ Atualização de conteúdo em 12/2024)
1. Gerador de sites estáticos & hospedagem web
1-1. Página web estática vs página web dinâmica
Página web estática (Static Web Page)
- Uma página web que entrega dados armazenados no servidor diretamente ao usuário
- O servidor web entrega uma página pré-armazenada correspondente à solicitação do usuário
- Os usuários veem a mesma página web, a menos que os dados armazenados no servidor sejam alterados
- Geralmente, a resposta é rápida, pois apenas o arquivo correspondente à solicitação precisa ser enviado, sem necessidade de processamento adicional
- Como consiste apenas de arquivos simples, só é necessário configurar um servidor web, tornando o custo de configuração baixo
- O serviço é limitado, pois mostra apenas informações pré-armazenadas
- Adições, modificações e exclusões de dados devem ser feitas manualmente pelo administrador
- Estrutura relativamente mais favorável para otimização de mecanismos de busca (SEO), pois é fácil para os mecanismos de busca rastrear
Página web dinâmica (Dynamic Web Page)
- Uma página web que processa dados armazenados no servidor com scripts antes de entregá-los
- O servidor web interpreta a solicitação do usuário, processa os dados e então entrega a página web gerada
- Os usuários veem páginas web que variam de acordo com a situação, hora, solicitação, etc.
- A resposta é relativamente mais lenta, pois os scripts precisam ser processados antes de entregar a página web
- Custos adicionais são incorridos na configuração, pois um servidor de aplicação é necessário além do servidor web
- Diversos serviços são possíveis, pois informações variadas podem ser combinadas e fornecidas dinamicamente
- Dependendo da estrutura da página web, os usuários podem adicionar, modificar e excluir dados diretamente no navegador
1-2. Gerador de sites estáticos (SSG, Static Site Generator)
- Uma ferramenta que gera páginas web estáticas com base em dados brutos (geralmente arquivos de texto em formato markdown) e modelos predefinidos
- Automatiza o processo de construção e implantação de páginas web, eliminando a necessidade de escrever páginas HTML individuais manualmente
- ex) Jekyll, Hugo, Gatsby, Eleventy
1-3. GitHub Pages
- Um serviço de hospedagem de páginas web estáticas gratuito fornecido pelo GitHub
- Permite hospedar uma página web pessoal representativa por conta e criar e hospedar páginas de documentação de projetos ilimitadas por repositório
- Após criar um repositório com o nome no formato ‘{username}.github.io’ correspondente ao seu nome de usuário do GitHub, você pode fazer push diretamente das páginas HTML construídas para o repositório ou usar GitHub Actions para realizar a construção e implantação
- Se você possui um domínio próprio, pode conectá-lo nas configurações para usar um endereço de domínio diferente em vez do domínio padrão no formato ‘{username}.github.io’
2. Escolhendo o SSG e o tema a serem usados
2-1. Razões para escolher Jekyll
Existem vários SSGs como Jekyll, Hugo, Gatsby, etc., mas decidi usar Jekyll. Os critérios considerados ao escolher o SSG e as razões para escolher Jekyll são os seguintes:
- É possível minimizar tentativas e erros desnecessários e focar na escrita e operação do blog?
- Jekyll é o gerador de sites estáticos oficialmente suportado pelo GitHub Pages. Embora outros SSGs como Hugo e Gatsby também possam ser hospedados no GitHub Pages, e haja a opção de usar outros serviços de hospedagem como Netlify, na verdade, para operar um blog pessoal deste tamanho, não é muito importante qual SSG foi usado tecnicamente para construí-lo, nem a velocidade de construção ou desempenho. Portanto, decidi que seria melhor usar algo que fosse um pouco mais simples de manter e tivesse mais documentação de referência.
- Além disso, Jekyll tem o período de desenvolvimento mais longo em comparação com seus concorrentes como Hugo e Gatsby. Isso significa que a documentação está bem feita e há uma quantidade esmagadora de recursos de referência disponíveis quando surgem problemas.
- Há uma variedade de temas e plugins disponíveis?
- Mesmo usando um SSG em vez de escrever HTML diretamente, criar vários modelos por conta própria é trabalhoso, demorado e desnecessário. Há muitos temas excelentes já disponíveis na web, então basta adotar e usar um que você goste.
- Além disso, como eu originalmente uso principalmente C e Python, não conheço bem Ruby do Jekyll ou Go do Hugo, então queria usar ativamente temas e plugins existentes.
- Com Jekyll, pude encontrar rapidamente um tema que gostei à primeira vista, enquanto Hugo e Gatsby pareciam não ter tantos temas adequados para blogs pessoais em comparação. Parece que a conectividade com o GitHub Pages, que muitos desenvolvedores usam para hospedar blogs pessoais, e o período de desenvolvimento mencionado acima também tiveram um grande impacto aqui.
2-2. Escolha do tema
Minimal Mistakes (01/2021 ~ 04/2022)
- Repositório GitHub: https://github.com/mmistakes/minimal-mistakes
- Página de demonstração: https://mmistakes.github.io/minimal-mistakes/
- Tema que usei por cerca de 1 ano e 3 meses quando criei o blog pela primeira vez
- Suporte a função de comentários através de Disqus, Discourse, utterances, etc.
- Suporte a função de classificação por categorias e tags
- Suporte básico ao Google Analytics
- Possibilidade de escolher skins predefinidas
- Embora eu tenha mudado posteriormente para o tema Chirpy, que tem um design mais elegante e agradável, considerando que é um blog de engenharia de qualquer maneira, acho que foi bastante utilizável com seu design limpo, mesmo que não fosse bonito.
Chirpy Jekyll Theme (04/2022~)
- Repositório GitHub: https://github.com/cotes2020/jekyll-theme-chirpy/
- Página de demonstração: https://chirpy.cotes.page/
- Tema que estou usando desde que mudei o tema do blog em abril de 2022
- Suporte a classificação por múltiplas categorias e função de tags
- Suporte básico à expressão de fórmulas com sintaxe LaTeX baseada em MathJax
- Suporte básico à função de diagramas baseada em Mermaid
- Suporte a função de comentários através de Disqus, Giscus, etc.
- Suporte ao Google Analytics, GoatCounter
- Suporte a temas claro e escuro
- No momento da mudança de tema, MathJax e Mermaid não eram suportados nativamente no tema Minimal Mistakes e precisavam ser adicionados através de personalização, mas o tema Chirpy os suporta nativamente. Claro, a personalização não era grande coisa, mas ainda assim é uma pequena vantagem.
- Acima de tudo, o design é bonito. O tema Minimal Mistakes é limpo, mas tem uma rigidez característica que parece mais adequada para documentação técnica oficial de projetos ou páginas de portfólio do que para blogs. O tema Chirpy tem a vantagem de um design que não fica atrás de plataformas de blogs comerciais como Tistory, Medium, velog, etc.
3. Criando o repositório GitHub, construindo e implantando
Descreverei com base no Chirpy Jekyll Theme que estou usando atualmente (06/2024), e assumirei que o Git já está instalado.
Referência: Guia oficial de instalação do Jekyll e Página oficial do Chirpy Jekyll Theme.
3-1. Instalando Ruby & Jekyll
Instale Ruby e Jekyll de acordo com o Guia oficial de instalação do Jekyll, adequado ao seu ambiente de sistema operacional.
3-2. Criando o repositório GitHub
A página oficial do Chirpy Jekyll Theme apresenta dois métodos:
- Método de importar os arquivos principais com a gem “jekyll-theme-chirpy” e obter os recursos restantes do modelo Chirpy Starter
- Vantagem: Como mencionarei mais tarde, é fácil aplicar atualizações de versão.
- Desvantagem: A personalização é limitada.
- Método de fazer fork do repositório jekyll-theme-chirpy para o repositório do seu próprio blog
- Vantagem: Como você gerencia diretamente todos os arquivos dentro do repositório, pode personalizar livremente modificando o código diretamente, mesmo para funções não suportadas pelo tema.
- Desvantagem: Para aplicar atualizações de versão, você precisa fazer merge da tag upstream mais recente do repositório original, o que pode resultar em conflitos com o código que você personalizou diretamente, dependendo do caso. Nesse caso, você precisa resolver esses conflitos manualmente.
Eu adotei o método 1. No caso do tema Chirpy, ele já tem um alto nível de completude, então a maioria dos usuários não tem muito a personalizar. Além disso, até 2024, o desenvolvimento e a melhoria de funcionalidades ainda estão muito ativos, então, a menos que você planeje fazer modificações extensas, as vantagens de acompanhar o upstream original superam as vantagens de aplicar personalizações diretas. O guia oficial do tema Chirpy também recomenda o método 1 para a maioria dos usuários.
3-3. Configurações principais
Aplique as configurações necessárias nos arquivos _config.yml
no diretório raiz e _data/contact.yml
, _data/share.yml
. Os comentários são bem escritos e as configurações são intuitivas, então você pode aplicá-las sem muita dificuldade. As configurações que podem exigir trabalho externo separado incluem o registro do código de autenticação para integração com o Google Search Console e a integração de ferramentas de webmaster como Google Analytics ou GoatCounter, mas na verdade esses procedimentos não são muito complicados e não são o tema principal que pretendo abordar neste artigo, então omito descrições detalhadas.
3-4. Construindo localmente
Não é um procedimento obrigatório, mas você pode querer verificar antecipadamente se algo será exibido corretamente na web ao escrever um novo post ou fazer alguma modificação no site. Nesse caso, abra um terminal no diretório raiz do repositório local e execute o seguinte comando:
1
$ bundle exec jekyll s
Após alguns segundos, o site será construído localmente e você poderá verificar o resultado no endereço http://127.0.0.1:4000.
3-5. Implantando
Existem dois métodos:
- Usando GitHub Actions (ao hospedar no GitHub Pages)
- Se você estiver usando o GitHub Free Plan, deve manter o repositório público
- Na página web do GitHub, selecione a aba Settings do repositório, clique em Code and automation > Pages na barra de navegação à esquerda e selecione a opção GitHub Actions na seção Source
- Após a configuração, o fluxo de trabalho Build and Deploy será executado automaticamente sempre que um novo commit for feito push
- Construindo e implantando diretamente (ao usar outro serviço de hospedagem ou auto-hospedagem)
- Execute o comando abaixo para construir o site diretamente
1
$ JEKYLL_ENV=production bundle exec jekyll b
- Faça upload do resultado da construção no diretório
_site
para o servidor
- Execute o comando abaixo para construir o site diretamente
4. Escrevendo posts
O guia de escrita de posts do tema Chirpy documenta bem o método de escrita de posts e as opções disponíveis. Ele fornece várias funcionalidades além do que é descrito neste artigo, e contém informações úteis para referência, então consulte a documentação oficial se necessário. Aqui, resumirei os principais pontos a serem lembrados toda vez que você fizer um post.
Criando o arquivo markdown
- Formato do nome:
YYYY-MM-DD-TITLE.md
- Localização: diretório
_posts
Escrevendo o Front Matter
Na primeira parte do arquivo markdown, você deve escrever o Front Matter adequadamente.
---
title: TITLE
description: >-
DESCRIPTION
date: YYYY-MM-DD HH:MM:SS +/-TTTT
categories: [TOP_CATEGORIE, SUB_CATEGORIE]
tags: [TAG]
image:
path: /path/to/image
alt: image alternative text
toc: true
comments: false
math: true
mermaid: true
---
- title: Título do post
- description: Resumo. Se não for escrito, uma parte do início do conteúdo principal será usada automaticamente, mas é recomendado escrever a meta tag de descrição diretamente para otimização de mecanismos de busca (SEO). Uma quantidade apropriada é de cerca de 135~160 caracteres em alfabeto romano, ou 80~110 caracteres em coreano.
- date: Data e hora exatas de escrita do post e fuso horário (opcional, se omitido, a data de criação ou modificação do arquivo será reconhecida e usada automaticamente)
- categories: Classificação de categorias do post
- tags: Classificação de tags a serem aplicadas ao post
- image: Inserção de imagem de pré-visualização no topo do post
- path: Caminho do arquivo de imagem
- alt: Texto alternativo (opcional)
- toc: Uso da função de índice na barra lateral direita, o valor padrão é
true
- comments: Usado para especificar explicitamente o uso de comentários para posts individuais, independentemente da configuração padrão do site
- math: Ativa a função de expressão de fórmulas baseada em MathJax embutido, o valor padrão é desativado (
false
) para o desempenho da página - mermaid: Ativa a função de expressão de diagramas baseada em Mermaid embutido, o valor padrão é desativado (
false
)
5. Atualizando
Descreverei assumindo que você adotou o método 1 em 3-2. Se você adotou o método 2, como mencionado anteriormente, você precisa fazer merge da tag upstream mais recente diretamente.
- Edite o
Gemfile
para especificar a nova versão da gem “jekyll-theme-chirpy”. - No caso de atualizações maiores, arquivos principais não incluídos na gem “jekyll-theme-chirpy” e opções de configuração também podem ter sido alterados. Nesse caso, você precisa verificar as alterações usando a API do GitHub abaixo e aplicá-las manualmente:
1
https://github.com/cotes2020/chirpy-starter/compare/<older_version>...<newer_version>