Jekyll 블로그 검색엔진 최적화

· by 박승재

검색엔진 최적화(SEO; Search Engine Optimization)는 말 그대로 사이트를 구글, 네이버와 같은 검색엔진에서 검색이 더 잘되게 하는 것을 말합니다.

Jekyll과 GitHub Pages로 블로그를 만들면 개발자가 직접 검색엔진에 등록해야 검색엔진이 사이트를 보여줄 수 있습니다.

이 글에서는 Jekyll로 만든 블로그를 검색엔진에 등록하고 검색엔진 최적화를 하는 방법을 소개합니다.

Jekyll로 블로그 자체를 만드는 방법에 대해서는 Jekyll로 나만의 블로그 만들기를 참고하세요.

HTML

<title> 태그는 독자와 검색엔진에 특정 페이지의 주제가 무엇인지 알려줍니다. <title> 태그는 HTML의 <head> 요소 안 쪽에 위치해야 하며 페이지마다 고유한 제목을 만들어야 합니다.

{% if page.title %}
  {% capture title %}{{ page.title }} - {{ site.title }}{% endcapture %}
{% else %}
  {% capture title %}{{ site.title }}{% endcapture %}
{% endif %}
<title>{{ title }}</title>

<description> 태그는 검색엔진에 페이지 내용을 요약하여 제공합니다. <description> 태그는 <title> 태그와 마찬가지로 HTML의 <head> 요소 안 쪽에 위치해야 합니다.

{% if page.excerpt %}
  {% capture description %}{{ page.excerpt | strip_html | truncate: 100 }}{% endcapture %}
{% else %}
  {% capture description %}{{ site.description }}{% endcapture %}
{% endif %}
<meta name="description" content="{{ description }}">

<title><description> 태그는 구글 Search Console에서 필수적으로 설정하길 권장하는 태그입니다.

참고: 검색엔진 최적화(SEO) 초보자 가이드

그 다음은 OG 태그를 설정해야 합니다.

OG 태그는 페이스북에서 만든 개념으로 웹 페이지에 대한 간단한 정보를 제공하며 검색엔진이나 앱에서 페이지 내용 미리보기 등을 표시하는데 사용합니다.

OGTag Example
카카오톡에서는 OG태그를 이용해 웹 페이지 정보를 보여줍니다
<meta property="og:type" content="website">
<meta property="og:url" content="{{ page.url | absolute_url }}">
<meta property="og:title" content="{{ title }}">
<meta property="og:description" content="{{ description }}">

<!-- 미리보기 사진 -->
<meta property="og:image" content="{{ "/assets/img/icon512.png" | relative_url }}">

OG 태그는 페이스북, 네이버 블로그, 카카오톡 등 다양한 플랫폼에서 인식합니다.

한편, 트위터에서는 OG태그의 정보를 더할 자체적인 메타 데이터 표기법도 가지고 있습니다.

트위터 카드라고 불리는 이 태그는 트위터 내에서 웹 사이트 정보를 표시하는데 사용됩니다.

트위터 카드 종류 중 Summary Card는 제목, 요약, 이미지(썸네일)를 보여줄 수 있는 태그로 아래와 같이 사용합니다.

<meta name="twitter:card" content="summary">
<meta name="twitter:title" content="{{ title }}">
<meta name="twitter:description" content="{{ description }}">

<!-- 미리보기 사진 -->
<meta name="twitter:image" content="{{ "/assets/img/icon512.png" | relative_url }}">

트위터 카드 태그는 트위터 내에서 OG 태그보다 우선순위가 높으며, 트위터 카드가 없으면 OG 태그를 이용해 정보를 구성합니다.

캐노니컬 태그는 중복되거나 유사한 태그를 하나의 태그로 통합하는 태그입니다. 예를 들어 아래는 모두 같은 페이지를 가리키지만 형태가 다른 주소입니다.

검색엔진이 위 페이지를 서로 다른 페이지라고 오해하는 것을 막기 위해 캐노니컬 태그로 검색엔진에 페이지의 기본 주소를 알려줘야 합니다.

<link rel="canonical" href="https://int-i.github.io/">

인트아이 블로그에서는 위 태그 이외에도 검색엔진에 추가적인 정보를 주기 위해 아래 태그를 사용합니다.

<!-- 페이지가 UTF-8 인코딩을 사용함 -->
<meta charset="UTF-8">

<!-- IE 호환성 보기 모드 활성화 -->
<meta http-equiv="X-UA-Compatible" content="IE=edge">

<!-- 웹 페이지 이름 -->
<meta name="application-name" content="{{ site.title }}">

<!-- 웹 페이지 제작자(저자) -->
<meta name="author" content="{{ site.author.name }}">

<!-- 웹 페이지 엔진 -->
<meta name="generator" content="Jekyll v3.8.5">

<!-- 웹 페이지 키워드 -->
<meta name="keywords" content="{{ keywords }}">

<!-- 모바일 화면 최적화 -->
<meta name="viewport" content="width=device-width, initial-scale=1.0">

참고: : The Document-level Metadata element

Atom

RSS는 Rich Site Summary의 약자로 사이트의 정보를 외부로 전달하기 위한 기술입니다.

아톰(Atom) 피드는 RSS를 확장한 개념으로 Jekyll에서는 jekyll-feed 플러그인을 이용해 쉽게 아톰 피드를 생성할 수 있습니다.

먼저, _config.ymljekyll-feed 플러그인를 추가합니다.

plugins:
  - jekyll-feed

그 다음, _config.ymlauthor 정보를 등록합니다.

author:
  name: 인하대학교 인트아이

아래와 같이 생성되는 피드 파일 이름을 바꿀 수 있습니다.

feed:
  path: atom.xml

이제 https://int-i.github.io/atom.xml에 접속하면 아톰 피드가 정상적으로 생성되는 것을 확인할 수 있습니다.

Sitemap

사이트맵은 사이트에 있는 페이지, 동영상 및 기타 파일과 각 관계에 관한 정보를 제공하는 파일입니다. 검색엔진은 사이트맵을 읽고 사이트를 더 지능적으로 크롤링하게 됩니다.

Jekyll에서는 jekyll-sitemap 플러그인을 이용해 자동으로 사이트맵을 생성할 수 있습니다.

plugins:
  - jekyll-sitemap

https://int-i.github.io/sitemap.xml에 사이트맵이 만들어지는 것을 볼 수 있습니다.

만약 사이트맵이 안보인다면 baseurl을 확인해보세요. baseurl/(기본값)으로 설정되어 있다면, https://int-i.github.io//sitemap.xml에 사이트맵이 생성됩니다. baseurl""으로 바꿔주세요.

참고: sitemap에 /가 중복되는 생기는 이슈

Search Console

구글 Search Console에서 속성 추가>URL 접두어에 사이트 주소를 입력해 사이트를 등록합니다.

Google Search Console

그리고 Sitemaps 탭으로 가, 위에서 만든 사이트맵을 제출합니다.

Google Search Console Sitemap

등록이 완료되면 구글 검색창에 site:int-i.github.io를 검색해 구글이 내 사이트의 존재를 알고 있는지 확인합니다.

Search Google

자신의 사이트가 검색 결과에 포함되어 있다면 구글 검색 DB에 내 사이트가 등록된 것입니다.

참고: 구글 검색에 내 사이트 등록하는 방법