无需本地环境,搭建一个个人博客网站

前言

随着互联网的进步,越来越多的操作得以在网上进行。今天我们来做一个静态博客“云玩家”。

搭建

创建仓库

首先,在线上创建一个 Git 仓库。

创建仓库

创建之后,复制它的 SSH 地址。

注册 CloudStudio

访问 https://cloudstudio.net 并注册一个账号(建议使用 GitHub 方式)。

新建一个 Ubuntu 的工作空间并设置仓库地址。

新工作空间

配置仓库

打开终端,输入如下内容以安装 Node.js [文档]

bash
1
2
curl -fsSL https://deb.nodesource.com/setup_17.x | bash
apt-get install -y nodejs

新终端

安装完成后,输入以下内容以更新 Npm 并安装 Hexo

bash
1
2
npm install -g npm
npm install -g hexo

输入以下内容进行初始化:

bash
1
2
3
4
5
6
7
mkdir hexo
cd hexo
hexo init
cd ..
mv hexo/* .
mv hexo/.* .
rmdir hexo

以上命令新建了一个空 hexo 目录( hexo 初始化需要空目录),并在该目录执行初始化,初始化完成后将内容移回当前目录。

更改主题

我们使用 Icarus 主题。

bash
1
2
3
4
npm install -S hexo-theme-icarus
npm uninstall hexo-theme-landscape
npm uninstall hexo-renderer-ejs # https://github.com/ppoffice/hexo-theme-icarus/issues/855
npm install --save bulma-stylus@0.8.0 hexo-renderer-inferno@^0.1.3

修改配置文件

_config.yml >folded
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138

# Hexo Configuration

## Docs: https://hexo.io/docs/configuration.html

## Source: https://github.com/hexojs/hexo/

# Site

title: 网站标题
subtitle: 副标题
description: 描述
keywords:

* 关键词
* 关键词
author: 作者
language: zh-CN
timezone: Asia/Shanghai

# URL

## Set your site url here. For example, if you use GitHub Page, set url as 'https://username.github.io/project'

url: http://example.com
permalink: :year/:month/:day/:title/
permalink_defaults:
pretty_urls:
trailing_index: true # Set to false to remove trailing 'index.html' from permalinks
trailing_html: true # Set to false to remove trailing '.html' from permalinks

# Directory

source_dir: source
public_dir: public
tag_dir: tags
archive_dir: archives
category_dir: categories
code_dir: downloads/code
i18n_dir: :lang
skip_render:

# Writing

new_post_name: :title.md # File name of new posts
default_layout: post
titlecase: false # Transform title into titlecase
external_link:
enable: true # Open external links in new tab
field: site # Apply to the whole site
exclude: ''
filename_case: 0
render_drafts: false
post_asset_folder: false
relative_link: false
future: true
highlight:
enable: true
line_number: true
auto_detect: false
tab_replace: ''
wrap: true
hljs: false
prismjs:
enable: false
preprocess: true
line_number: true
tab_replace: ''

# Home page setting

# path: Root path for your blogs index page. (default = '')

# per_page: Posts displayed per page. (0 = disable pagination)

# order_by: Posts order. (Order by date descending by default)

index_generator:
path: ''
per_page: 10
order_by: -date

# Category & Tag

default_category: uncategorized
category_map:
tag_map:

# Metadata elements

## https://developer.mozilla.org/en-US/docs/Web/HTML/Element/meta

meta_generator: true

# Date / Time format

## Hexo uses Moment.js to parse and display date

## You can customize the date format as defined in

## http://momentjs.com/docs/#/displaying/format/

date_format: YYYY-MM-DD
time_format: HH:mm:ss

## updated_option supports 'mtime', 'date', 'empty'

updated_option: 'mtime'

# Pagination

## Set per_page to 0 to disable pagination

per_page: 10
pagination_dir: page

# Include / Exclude file(s)

## include:/exclude: options only apply to the 'source/' folder

include:
exclude:
ignore:

# Extensions

## Plugins: https://hexo.io/plugins/

## Themes: https://hexo.io/themes/

theme: icarus

# Deployment

## Docs: https://hexo.io/docs/one-command-deployment

deploy:
type: ''

还需要对主题进行一次初始化,输入:

bash
1
hexo server

完成后,按下 Ctrl + C

提交更改

切换到版本管理选项卡,提交更改并推送。

提交更改

推送更改

至此,我们可以暂时关闭 CloudStudio 了。

打开 GitHub Web Editor

打开仓库,按下 . 键即可打开。

继续配置

继续修改主题配置文件(由于主题配置文件更加复杂,所以没有编写示例)。

GitHub Pages 集成

最后,我们只需要新建一个 GitHub Action 就可以自动化部署了。

在仓库根目录新建 .github/workflows/pages.yml 文件,填入以下内容:

.github/workflows/pages.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
name: Github Pages
on: push
jobs:
publish:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: actions/setup-node@v1
with:
node-version: '17.4.0'
- run: npm install
- run: npm run-script build
- uses: peaceiris/actions-gh-pages@v3
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
publish_dir: ./public
force_orphan: true

提交,稍作等待后来到仓库 Settings - Pages,选择多出来的 gh-pages 分支。

设置

完成

配置完成

今后想进行写作,可以直接前往 GitHub Web Editor,在 source/_posts 目录新建文章或在 CloudStudio 运行 hexo new '文章名' 新建文章。

CloudStudio 有每日工作空间使用时长限额 2 小时。

以下是新建的默认文章格式,供参考:

new-post.md
1
2
3
4
5
6
---
title: 标题
date: YYYY-MM-DD hh:mm:ss
---

正文

建议仔细阅读 Hexo 文档Icarus用户指南

可以使用 Forestry 进行更加方便舒适的内容管理,在本文中不展开讨论。

无需本地环境,搭建一个个人博客网站

https://blog.ltfan.top/2022/01/28/Make-Blog-Website/

作者

xfqwdsj

发布于

2022-01-28

更新于

2022-12-10

许可协议

评论