Tip

GitHub Pages에 포트폴리오 호스팅하기 - 1) GitHub Pages란

  • -
반응형

GitHub에서 무료로 웹 서비스 호스팅을 사용할 수 있다는 것을 알고 “포트폴리오 페이지 하나쯤 만들어놔야지..” 했는데 차일피일 미루다가 이제야 만들어 봤네요. 설정 과정, 처음 보는 문법들, 발생한 에러들과 해결법까지. 만들었던 과정들을 공유하고자 글을 작성했습니다.


GitHub Pages

GitHub에서는 GitHub Pages라는 기능을 통해 홈페이지를 운영할 수 있는 웹호스팅 서비스를 제공해준다.

GitHub Pages는 정적 페이지만 호스팅이 가능하다. 하지만 무료라는 점과 Github Pages에서 직접 제공하는 Jekyll에 다양한 테마들이 오픈소스로 공유되어 있어 커스텀이 편리하다. 이러한 이유로 개발자들에게는 개인 포스팅을 위한 블로그 또는 포트폴리오로서 널리 활용되고 있다.

 

GitHub Pages는 내부적으로 Jekyll에 의해 작동된다. Jekyll은 Ruby라는 언어로 만들어져 있고, Jekyll 사용을 위해서는 Markdown의 문법도 알아두어야 하기 때문에 Jekyll, Ruby, Markdown에 대해 조금은 알고 넘어가보려 한다.

 

참고로 GitHub Pages의 호스팅 도메인은 username.github.io로 접속이 가능하다.(기본 도메인)

*username : GitHub 닉네임

 

GitHub Pages

Websites for you and your projects, hosted directly from your GitHub repository. Just edit, push, and your changes are live.

pages.github.com

 

Jekyll

Jekyll은 정적 사이트 생성기로 마크업 언어(HTML, XML, Markdown)로 작성된 텍스트를 사용해 웹 사이트를 생성한다.

Jekyll의 디렉토리 구조는 다음과 같다. 

  • config.yml : 이 파일은 Jekyll 사이트 설정 옵션을 정의하는 파일. 설정 정보는 변수로 구분되어 저장하며, 페이지 어디서든 호출해 사용할 수 있다.
  • _includes : header.jsp, footer.jsp를 나누어 사용하듯 페이지 재사용을 위한 템플릿 파일이 위치한 폴더.(Spring tiles와 같은 개념?)
  • _layouts : 말 그대로 페이지 레이아웃을 담당하는 파일이 위치한 폴더.
  • _posts : 마크다운 형식의 글이 위치한 폴더. 파일명의 포맷을 YYYY-MM-DD-TITLE.markdown과 같이 한다.
  • _sass : css 구성 파일을 보관하는 폴더. xxx.scss 파일은 빌드되면서 xxx.css로 변환된다.
  • _site : 빌드된 최종 파일들이 위치하는 폴더로 이 폴더의 파일은 수정해도 의미가 없다.(빌드시 다시 변경 되기 때문에..)

 

구조를 이해하고 있으면 이후에 Jekyll의 다양한 테마를 커스터마이징 하는데 도움이 된다. 사용해본바로 테마에 따라 구조는 조금씩 다른 경우도 있어서 가장 기본적인 파일/폴더만 정리하였다.

 

이미지 출처 : http://jekyllrb-ko.github.io/docs/structure/

 

Quickstart

Jekyll is a static site generator. It takes text written in your favorite markup language and uses layouts to create a static website. You can tweak the site’s look and feel, URLs, the data displayed on the page, and more.

jekyllrb.com

 

Ruby

Ruby는 C, Java와 마찬가지로 프로그래밍 언어 중 하나이다.

Ruby는 객체 지향 언어로 원시 자료형이 존재하지 않는다. 모든 것이 객체인 순수 객체 지향 언어이다.

 

Jekyll은 Ruby라는 언어로 작성된 프레임워크이다.

(Ruby 문법을 몰라도 사이트를 생성하는데 어려움이 없었기 때문에 Ruby는 이런 거구나 정도만 이해하고 넘어가시면 될 것 같습니다)

 

Markdown

Markdown은 마크업 언어(*태그 등을 이용하여 문서나 데이터의 구조를 명기하는 언어)의 하나로서 문서를 간결하고 자유롭게 작성할 수 있다.

문법이 복잡하지 않기 때문에 배우기 쉽고 직관적이다.

 

Markdown이 사용된 대표적인 예로 GitHub에 README.md 파일이 있다.

 

Jekyll 테마 고르기

하나부터 열까지 만들어볼 생각은 아니었기 때문에 Jekyll 테마를 골라 커스터마이징하기로 했다. 여기에서 다양한 테마를 구경할 수 있었고 두 가지 정도의 기준을 세워 테마를 골랐다.

  1. 내용이 직관적으로 눈에 들어왔으면 좋겠음
  2. 심플한 디자인

[선택한 테마]

 

Plainwhite

A portfolio-style jekyll theme for writers. Features Responsive Design Disqus Powered Comments Google Analytics SEO

jekyllthemes.org

테마를 적용하는 방법은 다음과 같다.

 

1) Homepage 클릭

 

2) 상단에 Fork 클릭

* Fork는 다른 사람의 Repository에 있는 소스를 내 Repository에 복제하여 수정하고 추가할 수 있는 복제 기능이다.

 

3) 복제된 테마 소스

 

4-1) Settings - Repository name 변경

앞서 GitHub Pages에서 기본으로 제공하는 도메인은 username.github.io라고 하였다.

아래와 같이 저장소 이름을 변경하면 https://eeesnghyun.github.io 접속시 fork 받은 소스 루트에 있는 index.md(또는 index.html) 파일이 로드된다. 이것이 저장소 이름을 username.github.io로 변경하는 이유이다.

 

* GitHub Pages에 대한 저장소가 만들어지면 https://eeesnghyun.github.io/repositoryname 다른 저장소의 접근도 가능하다.(정적 사이트에 한하여)

 

4-2) GitHub Pages 설정 확인

만약 아래(우측)와 같이 활성화가 되어있지 않다면 (좌측) Branch와 소스 경로를 root로 하여 저장해준다.

 

5) 접속 테스트

테스트 과정 중에 캡쳐해서 기존 화면과 좀 다릅니다

 

참고)

 

GitHub Pages

Websites for you and your projects, hosted directly from your GitHub repository. Just edit, push, and your changes are live.

pages.github.com

 

Quickstart

Jekyll is a static site generator. It takes text written in your favorite markup language and uses layouts to create a static website. You can tweak the site’s look and feel, URLs, the data displayed on the page, and more.

jekyllrb.com

 

웹호스팅 (github pages) - 생활코딩

--- 직접 웹서버를 운영하는 일은 쉽지 않은 일입니다. 우선 컴퓨터가 있어야 하고요, 컴퓨터가 냉장고처럼 항상 켜져 있어야 합니다. 웹서버라는 프로그램을 배워서 설치해야 합니다. 또 인터넷

opentutorials.org


다음장에서 본격적인 커스터마이징 작업이 시작됩니다.

+ 사용해보면서 이해한 것을 토대로 작성했기 때문에 혹시 틀린점이 있다면 알려주세요 :)

반응형
Contents

포스팅 주소를 복사했습니다

이 글이 도움이 되었다면 공감 부탁드립니다.