Qiita Teams that are logged in
You are not logged in to any team

Log in to Qiita Team
Community
OrganizationAdvent CalendarQiitadon (β)
Service
Qiita JobsQiita ZineQiita Blog
3
Help us understand the problem. What is going on with this article?
@tommy_aka_jps

Hexo + Gitlab + Netlify で yahoo ジオシティーズの引越し先を作った話

More than 1 year has passed since last update.

あらすじ

昨年の話ですが、こんなブラックメールお知らせが手元に届きました。

いつかこんな日が来るような気がしてはいましたが時代を感じました。Yahooジオシティーズは私が初めてまともなホームページを作った際に使ったレンタルサーバーで、今もなお使い続けてましたが、このお知らせを受けて移行(もしくは閉鎖)の検討が必要となりました。

とりあえず閉鎖はしないで引越しすることにしましたが、いかんせんソースがだいぶ古かったのでこの際作り直してみようとおもいました。HTMLタグ辞典見ながら適当に作った化石のようなサイトを晒すのも憚られるのでURLは内緒です:sweat_smile:

というわけで引っ越し先サイトを作ってみることにした次第です。

ホームページ要件

  • 静的ページ(3〜4ページ) => 現在ジオシティーズ
  • ブログ => FC2ブログ
  • いづれも非商用サイト

実は技術系じゃないふつうのブログもやってます。(更新止まってますが)
FC2ブログ自体は別にサービス終了の予定はないのですがこの際統合してしまいたいです。

最近興味のある 静的サイトジェネレータ でブログもブログ記事ではない固定ページも両方作れるというのをちらほら見かけていたのでやってみることにしました。(WordPress に移行する選択肢もありましたが、単に静的サイトジェネレータを使ってみたいがために今回は外しました。)

静的サイトジェネレータの選定

StaticGen | Top Open Source Static Site Generators

いろいろありますね。
特にこだわりはないんですが、Jekyll はとりあえず外しました。(現在会社のメイン業務では Ruby を使うことが多いのでこれが一番すんなりできそうではありますが、プライベートではあえて違うものを触ってみようと考えたことが理由です。)今回はタイトルのとおり Hexo を使ってみようと思います。

アップロード先サーバーの選定

一番重要ですね。そもそもホームページの移転がメインですし。(改装は単なるついでです)
サイトの公開は周りの評判も悪くない Netlify を使ってみることにしました。

Netlify lets you link a GitHub, GitLab, or Bitbucket repository to a site. Each time you push to your Git provider, Netlify runs a build with your tool of choice and deploys the result to our powerful CDN.

Netlify のドキュメント によると GitHub, GitLab, Bitbucket と連携できる ようなので、ソースはこのどれかで管理するのが良さそうかなと思いました。*プライベートリポジトリが無料で作成できるのと、GitHub とユーザーインターフェースがわりと近そうに見える(主観)という理由から GitLab を選択しました。

*作業当時はまだ GitHub でプライベートリポジトリが無料で作れるようになる 前でした。もうちょっと待てばよかったです(白目

事前準備

https://hexo.io/docs/#Requirements
Node.js と Git が必要なのでインストールしておいてください。
一応簡単な説明を後述します。

Node.js

Installing Node.js via package manager | Node.js
Node.js インストールについては本件ではあまり細かくは触れませんが、バージョン管理マネージャーを経由しておくと何かと便利なのでおすすめします。自分は nvm を使っています

coreybutler/nvm-windows: A node.js version management utility for Windows. Ironically written in Go.
Windows用の nvm もありますので Windows の方はこちらをどうぞ。

Git

Git - Installing Git
Mac の方は homebrew のコマンドで、Windows の方は Git for Windows でインストールするのが手っ取り早いと思います。

Hexo のインストール

公式 では npm インストールを指示していますが、手元の端末に Yarn が入っているので、ここでは Yarn を使ってインストールします。

$ yarn global add hexo-cli

新しいサイトの作成

hexo をインストールしたらあとはコマンド操作だけです。楽です。

hexo ディレクトリの初期化

hexo-site という名前は任意なので特になんでもいいです。この名前でディレクトリが作成され、その中にいろんなものができあがります。

$ hexo init hexo-site

依存パッケージのインストール

hexo の init がはじめての場合はいろいろ足りないものがあるのでやっておきましょう。

$ cd hexo-site/
$ yarn install

各種プラグインのインストール

一応最低限と思しきプラグインです。このへんはだいたい必要になるとおもいますのでよくわからない人はとりあえず入れておきましょうw

# SCSS (hexoの使用テーマによって要否が異なる。とりあえず入れておけば無難w)
$ yarn add hexo-renderer-scss

# RSS
$ yarn add hexo-generator-feed

# robots.txt
$ yarn add hexo-generator-robotstxt

プラグインについてはこちらを参考にさせていただきました。

Hexoブログで使ってるプラグインを公開します(package.json)

公式のプラグイン一覧ページも参考までに貼っておきます。

Plugins | Hexo

ローカルでサイトを確認

$ hexo server
INFO  Start processing
INFO  Hexo is running at http://localhost:4000 . Press Ctrl+C to stop.

メッセージのとおり、http://localhost:4000 をブラウザで開くとご覧のとおりです。
2019-01-01_22h37_59.png

ちなみにコマンドは hexo s でもOKです。rails と似てますね。
あとはこれを自分のサイト用にいろいろ改造していこうというところです。

Git管理

私の場合はあらかじめ GitLab に hexo-site リポジトリを作成していたので、git init 後に git remote add しています。このへんは好みなのであまり参考にしなくてもいいと思います:sweat_smile:

$ cd hexo-site
$ git init
Initialized empty Git repository in /Users/************/hexo-site/.git/

$ git remote add origin git@gitlab.com:Jpsern/hexo-site.git
$ git add .
$ git commit
$ git push origin master

サイトの設定変更

_config.yml を編集して任意の値に変更していきます。(細かい値はおいおい変更します。)

サイト名はいいのが思いつかなかったのでとりあえず予定ドメイン名をそのまま付けました。(仮名が正式名になるパティーン)

_config.yml
# Site
-title: Hexo
+title: 'Jpsern.com'
 subtitle:
 description:
 keywords:
-author: John Doe
+author: 'TOMMY(a.k.a Jpsern, Jps.)'
-language:
+language: ja
-timezone:
+timezone: Asia/Tokyo

テーマの変更

おいおい自作したいですが、ひとまずは便利な既存テーマを使わせてもらうことにします。

テーマを選ぶ

Themes | Hexo

公式テーマだけでもけっこうな数がありますね。今回はこの中から apollo を使ってみたいと思います。

フォークする

おいおいいじってみたいのでリポジトリを直接使うのはやめて、自分の git アカウントへフォークしておきます。フォークしたいリポジトリへ行って、「Fork」ボタンを押すだけの簡単なお仕事です。

Fork a repo - User Documentation

サブモジュールとして追加する

リポジトリの中に別のリポジトリを clone すると怒られます。なのでサブモジュールとして追加することにします。

$ git submodule add git@github.com:Jpsern/hexo-theme-apollo.git themes/apollo-fork
$ git add .gitmodules
$ git add themes/apollo-fork

ちなみに怒られた例

clone はできますが、git add するとリポジトリ内に別のリポジトリを作成するならサブモジュールにしなさい、と叱られます。なので良い子は真似しないでね。

$ git add apollo
warning: adding embedded git repository: themes/apollo
hint: You've added another git repository inside your current repository.
hint: Clones of the outer repository will not contain the contents of
hint: the embedded repository and will not know how to obtain it.
hint: If you meant to add a submodule, use:
hint:
hint:   git submodule add <url> themes/apollo
hint:
hint: If you added this path by mistake, you can remove it from the
hint: index with:
hint:
hint:   git rm --cached themes/apollo
hint:
hint: See "git help submodule" for more information.

補足

ちなみにテーマを git clone ではなく zip でダウンロードして、自分の Hexo プロジェクト内にぶちこんで一括管理される場合は、前述の フォークする 〜 サブモジュールとして追加する はスルーで OK です。自分の場合は、hexo プロジェクト自体はプライベートリポジトリ、テーマについては公開リポジトリとして、それぞれ別に管理したかったので、この記事のような形をとっています。

config を変更して反映させる

こんなかんじで config の設定を変更します。

_config.yml
 # Extensions
 ## Plugins: https://hexo.io/plugins/
 ## Themes: https://hexo.io/themes/
-theme: landscape
+theme: apollo-fork

control + C で一旦サーバーを停止して、再度 hexo server すると config が反映されます。テーマの変更はこれで完了です。(細かい調整はここでは省略します)
localhost:4000 をブラウザで開くと以下のとおり apollo が反映された状態になりました。

スクリーンショット 2019-02-04 10.19.32.png

固定ページ用のテンプレを作ります

これからジオシティーズに置いていたコンテンツを置くための固定ページを作ります。ただ、現状は固定ページでもブログ記事ページと同じテンプレートが使われているため、日付表示が入ったり等、固定ページには必要の無いものがあります。

Hexoの固定ページを日付け無しに | Pagent

上記を参考に固定ページ専用のテンプレートを別途作って余計なものは外しておきます。

固定ページの追加

例として、ジオシティーズに置いていた自作の打ち込み曲用ページを music という固定ページを作ってそこにまとめて置くことにします。

hexo new page music

これで music ページができました。source/music/index.md が作成されますので、ページの具体的な表示内容等は index.md をいじっていくことになります。マークダウンファイルには普通の HTML も書けますので、うまいこと織り交ぜてページを作ります。

ちなみに、Hexo は基本的に source ディレクトリの中身がデプロイ時にそのままサイトのドキュメントルートへ変換・コピーされるようです。例えば source/unko.html を作っておくと、デプロイ後にhttp://{%domain%}/unko.html で見ることができるようになります。静的サイトジェネレータを使ってるのに html を直接置く というパターンは稀かもしれませんが原理は覚えておいて損はないと思います。

ブログ記事の作成

hexo new post {タイトル}

このようにコマンドを入力すると、source/_posts 直下に引数で渡したタイトルと同じ名前の .md ファイルが生成されます。これを編集していくのが基本的な流れになります。ファイル名が日本語になるのはなんかちょっと怖いので、hexo new post コマンド実行時のタイトル部分には英語の文字列を渡しています。(ブログ記事に表示されるタイトルは .md ファイル内にある title という項目で編集できます。特にファイル名が使われるわけではないです。)

Netlify へのデプロイ

ページもだいたいできあがったらさっそく公開します。リモートに作業内容を全て push したあとは Netlify 上の操作で簡単に公開できます。というわけでまずはホスティングサービス側へ作業内容を push しておきましょう。サブモジュール側の push も忘れないようにしておいてください。(←忘れた人)

0. 連携設定

GitLab などのホスティングサービスとの連携設定は、Netlify に自分が使用しているホスティングサービスのアカウントでログインしていればもう連携設定は自動で行われているので特に必要ありません。

1. New Site from Git を押します

1.newsitefromgit.png

2. ホスティングサービスを選択します

2.selecthosting.png

3. リポジトリを選択します

3.selectrepo.png

4. 必要な設定を入力してデプロイ

基本は下記と全く同じ設定にしてもらえればOKです。
4.deploysite.png

あとは Netlify から公開用URLが発行されて画面に表示されます。そこにアクセスすればめでたく公開が完了です。お疲れ様でした!

更新について

特に設定を変更していない場合、リモートリポジトリ(この記事の場合は hexo-site リポジトリ)の master ブランチが更新されるたびに勝手に Netlify にデプロイされるようになります。簡単ですね。

補足

テーマの細かい調整はこの記事に書いていないことをちょこちょこやってます。そのあたりにもし興味があったり、参考にしてみたい、という方がいらっしゃいましたら下記で全てのコミットが見れますのでよろしければどうぞ。
https://github.com/Jpsern/hexo-theme-apollo

残る課題

FC2 ブログからのデータ移行どうやるかが思案のしどころですね。。。記事もそうなんですが画像周りが面倒です。
スクリプト作ってもたぶん1回しか使わないし、全部で100個くらいしか記事もないので手でやってしまおうかとエンジニアにあるまじきことを考えてます(ぁ

というわけで

そんなかんじで完成したサイトはこちらです。
https://jpsern.com/

Netlify は無料で使ってますが、せっかくなのでドメイン買ってあててみました。そのあたりの細かい話はそのうち別記事にしたいと思います。

私には珍しい長文の記事でしたが最後までお付き合いいただきありがとうございましたm(__)m

3
Help us understand the problem. What is going on with this article?
Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
tommy_aka_jps
小ネタばかり投稿しているひとです。

Comments

No comments
Sign up for free and join this conversation.
Sign Up
If you already have a Qiita account Login
3
Help us understand the problem. What is going on with this article?