使用Hugo搭建网站最完整的教程

使用Hugo搭建网站最完整的教程

October 15, 2023·
qinadu

Hugo是一个流行的静态网站生成器,旨在帮助开发者快速构建高性能的网站。它是基于 Go 语言开发的框架,具有速度快、易于使用和开发灵活的特点。Hugo 支持Markdown 语法,我们可以将自己的文章写成Markdown 的格式,放在我们用Hugo 创建的博客系统中,从而展示给他人。

但Hugo对于新手来说会不太友好。所以千度将Hugo的完整从安装部署到开发的完整教程写下来分享给我的朋友们。

Hugo 安装

在Windows 中安装Hugo

首先安装choco 包管理器,需要在管理员权限下运行cmd,执行如下命令,一般情况下,网络没有问题,即可安装成功:

powershell -NoProfile -ExecutionPolicy unrestricted -Command "iex ((new-object net.webclient).DownloadString('https://chocolatey.org/install.ps1'))"

# 设置环境变量
SET PATH=%PATH%;%ALLUSERSPROFILE%\chocolatey\bin

然后使用choco 安装 hugo:

# 墙内安装可能较慢
choco install hugo -confirm

在MacOs 中安装Hugo

使用brew 命令安装:

brew install hugo

在Linux 中安装Hugo

在Linux 中可以使用snap 命令来安装,执行下面命令:

snap install hugo

如果你的Linux 是Ubuntu 版本,也可是使用apt 来安装,但是apt 安装的hugo 可能不是最新版的,这样会对一些hugo 主题的使用有所限制。

这种情况下我们可以到hugo 的github 仓库 中下载安装包来安装hugo,我们可以下载一个deb 包,然后使用如下命令安装:

dpkg -i <package.deb>

检查Hugo 是否安装成功

不管在哪种系统中安装Hugo,最后我们都可以使用下面命令查看Hugo 是否安装成功:

>>> hugo version
hugo v0.136.5-46cccb021b windows/amd64 BuildDate=2024-10-24T12:26:27Z VendorInfo=gohugoio

检查go与Hugo环境版本信息

#go 版本
go version go1.11.5 linux/amd64

#版本和环境详细信息
hugo env

Hugo Static Site Generator v0.54.0 linux/amd64 BuildDate: 2019-02-22T08:11:04Z
GOOS="linux"
GOARCH="amd64"
GOVERSION="go1.11.5"

快速开始Hugo

使用Hugo创建博客

#新建一个新的工程
hugo new site myblogName

#这个命令会创建一个名为myblog 的目录,这就是博客的根目录。目录结构如下:
├── archetypes
│   └── default.md
├── config.toml			# 博客站点的配置文件
├── content				# 博客文章所在目录
├── data				
├── layouts				# 网站布局
├── static				# 一些静态内容
└── themes				# 博客主题


#下载官网主题放到 …/blog/themes/目录下
cd themes
git clone https://github.com/vjeantet/hugo-theme-casper.git casper

#下载下来的主题会放在themes目录中:
└── hugo-theme-bootstrap4-blog
    ├── CHANGELOG.md
    ├── LICENSE.txt
    ├── README.md
    ├── archetypes
    ├── assets
    ├── exampleSite         # 本主题示例内容
    |      ├── content		# 示例博客文章
    │      |-- static
    │      |-- config.toml	# 本主题配置
    ├── i18n
    ├── images
    ├── layouts
    ├── package-lock.json
    ├── package.json
    ├── screenshot.png
    ├── source
    ├── theme.toml		
    └── webpack.config.js

Hugo目录介绍

...
├── config // 模板需要的内容语料
|   ├── default 
|   |   ├── config.toml
|   |   └── config.cn.toml
|   |   └── config.en.toml
|   |   └── footer.cn.toml
|   |   └── footer.en.toml
|   |   └── ...
├── content // 内容部分,日常多由运营同学管理维护
|   ├── en // 国际化支持
|   |   ├── posts // 内置默认的博客(post)类型资讯
|   |   |   ├── post-01.md
|   |   |   ├── post-02.md
|   |   └── release // 新增的 release 类型资讯
|   |   |   ├── release-01.md
|   |   |   └── release-02.md
|   ├── cn
|   |   ├── posts
|   |   |   ├── post-01.md
|   |   |   ├── post-02.md
|   |   └── release
|   |   |   ├── release-01.md
|   |   |   └── release-02.md
...
├── themes // 站点的主题
|   ├── nebula-theme // 主题名
|   |   ├── layout // 模板
|   |   |   ├── _default // 默认的模板
|   |   |   |   ├── baseof.html // 渲染的种子页面定义
|   |   |   |   ├── list.html  // 默认博客 post 类型资讯 - 列表页的使用模板页面
|   |   |   |   ├── single.html // 默认博客 post 类型资讯 - 详情页使用模板页面
|   |   |   ├── partials // 复用的模板片段
|   |   |   |   ├── head.html
|   |   |   |   ├── footer.html
|   |   |   |   ├── menus.html
|   |   |   |   ├── ...
|   |   |   ├── index.html // 首页('/') 默认会使用的模板
|   |   |   ├── section
|   |   |   |   ├── release.html // 新增资讯类型 release 渲染时使用的模板页面 - 发布历史页面
|   |   |   |   ├── news.html // 新增资讯类型 news 渲染时使用的模板页面 - 媒体新闻页面
...

到此hugo即可算安装完成,让我们继续学习

Hugo命令大全

Hugo常用命令

#编译生成静态文件并输出到public目录		
hugo

#编译生成静态文件并启动web服务
hugo server
#或
hugo server --bind="0.0.0.0"

#创建文章
hugo new index.md  
#在content/文件夹可以看到,此时多了一个markdown格式的文件index.md,打开文件可以看到时间和文件名等信息已经自动加到文件开头,包括创建时间,页面名,是否为草稿等。

#创建一个新的文章,指定文章路径、名称和文件扩展名。
hugo new post/my-article.md

#启动开发服务器,并包括草稿(draft)文章在内。
hugo server -D

#生成静态网站文件,包括草稿(draft)文章在内。
hugo -D

#生成静态网站文件之前清除缓存。
hugo --gc

#生成静态网站文件之前清除缓存并压缩代码。
hugo --gc --minify

#将生成的网站文件部署到指定的部署目标,如 GitHub Pages、Netlify 等。
hugo deploy

常用参数

  --bind="127.0.0.1"    				#服务监听IP地址;
  -p, --port=1313       				#服务监听端口;
  -w, --watch[=true]					#监听站点目录,发现文件变更自动编译;
  -D, --buildDrafts     				#包括被标记为draft的文章;
  -E, --buildExpired    				#包括已过期的文章;
  -F, --buildFuture     				#包括将在未来发布的文章;
  -b, --baseURL="www.datals.com"  		#服务监听域名;
  --log[=false]: 		   				#开启日志;
  --logFile="/var/log/hugo.log":        #log输出路径;
  -t, --theme=""          				#指定主题;
  -v, --verbose[=false]: 				#输出详细信息

组合使用方法

hugo server -t hyde --buildDrafts --baseURL=http://www.yourname.com  --bind=0.0.0.0 --port=80 -w
-t hyde        							#使用hyde主题,如果使用-t 选择了主题会将当前默认的主题覆盖;
 --buildDrafts							#参数将生成被标记为草稿的页面,是否发布:hugo 会忽略所有通过 draft: true 标记为草稿的文件。必须改为 										 draft: false 才会编译进 HTML 文件。
 --baseURL=http://www.yourname.com      #站点监听域名
 --bind=0.0.0.0   						#监听全部网段
 --port=80        						#服务监听端口
 -w               						#如果修改了网站内的信息,会直接显示在浏览器的页面上,不需要重新运行hugo server,方便我们进行修改。  

hugo命令使用方法详解

执行hugo命令,站点目录下会新建文件夹public/,生成的所有静态网站页面都会存储到这个目录, 如果使用Github pages来作为博客的Host,你只需要将public/里的文件上传就可以。 如果使用nginx作为web服务配置root dir 指向public/ 即可;

编写博客文章

你只需要按照Markdown 的格式编写自己的文章,让后将写好的文章放在myblog/content/posts,hugo 就会读取到这片文章,并将这片文章展示在比的博客中。

与普通Markdown 文章不一样的地方是,你需要在文章的开头写入如下结构的内容,这些内容包含在三杠线之间,在三杠线下边就是Markdown 的正文了:

---
文章属性内容
---
Markdown 正文

这些内容会被hugo 解析,作为当前文章的一些属性,常用的属性如下:

---
title: "文章标题"			# 文章标题
author: "作者"				# 文章作者
description : "描述信息"	# 文章描述信息
date: 2015-09-28			# 文章编写日期
lastmod: 2015-04-06			# 文章修改日期

tags = [					# 文章所属标签
    "文章标签1",
    "文章标签2"
]
categories = [				# 文章所属标签
    "文章分类1",
    "文章分类2",
]
keywords = [				# 文章关键词
    "Hugo",
    "static",
    "generator",
]

next: /tutorials/github-pages-blog		# 下一篇博客地址
prev: /tutorials/automated-deployments	# 上一篇博客地址
---

比如我们编写了这样一篇文章,文件名为my-first.md:

---
title: "我的第一篇博客"                         
author: "我是作者"  
description : "这是描述信息"    
date: 2018-09-18        
lastmod: 2018-09-26             

tags : [                                    
"我的博客标签",
]
categories : [                              
"我的博客分类",
]
keywords : [                                
"我的博客关键字",
]
---
这里是Markdown 正文

我们将myblog/content/posts 目录中的其它文章删除,只留我们自己的这篇文章:

.
└── my-first.md 

使用hugo server 重启博客服务,打开地址网址可以看到现在的博客中,只有我们自己写的文章:

Hugo 的配置文件

博客的配置文件可以根据自己的需要修改,我们来看下Bootstrap v4 主题的配置文件,这些配置属性通过应为并不难理解。

配置文件中属性的内容我做了修改,并添加了中文注释。

# Hugo 属性设置

# 网站地址
baseurl = "https://localhost:1313/"	

# 网站语言
languageCode = "en-us"				

# 网站title
title = "我的博客"					 

# 主题的名字,这个要跟myblog/themes 目录中的子目录的目录名一致
theme = "hugo-theme-bootstrap4-blog"	

# home/category/tag 页面显示的文章数 (Default: 10)
paginate = 5

# home/category/tag 页面用于摘要的字数 (Default: 70)
summaryLength = 50

# optionally override the site's footer with custom copyright text
# copyright = "Except where otherwise noted, content on this site is licensed under a [Creative Commons Attribution 4.0 International license](https://creativecommons.org/licenses/by-sa/4.0/)."
#googleAnalytics = "UA-123-45"
#disqusShortname = "XYW"

# 博客链接的路径格式
[permalinks]
  posts = "/:year/:month/:title/"
  page = "/:slug/"
  
# 顶部栏
[[menu.navbar]]
  name = "首页"
  url = "http://localhost:1313"

# 侧边栏,可以写多个
[[menu.sidebar]]
  name = "新浪"
  url = "https://www.sina.com"

[[menu.sidebar]]
  name = "Github"
  url = "https://github.com"

# Theme 属性设置
#
[params]
  # Site author
  author = "作者名"

  # homepage 页描述信息
  description = "我的博客站点"

  # Show header (default: true)
  #header_visible = true

  # Format dates with Go's time formatting
  date_format = "Mon Jan 02, 2006"

  # verification string for Google Webmaster Tools
  #google_verify_meta = "BAi57DROASu4b2mkVNA_EyUsobfA7Mq8BmSg7Rn-Zp9"

  # verification string for Bing Webmaster Tools
  #bing_verify_meta = "3DA353059F945D1AA256B1CD8A3DA847"

  # verification string for Yandex Webmaster Tools
  #yandex_verify_meta = "66b077430f35f04a"

  # Optionally display a message about the site's use of cookies, which may be
  # required for your site in the European Union. Set the parameter below to a
  # page where the user can get more information about cookies, either on your
  # site or externally, for example:
  #cookie_consent_info_url = "/cookie-information/"
  #cookie_consent_info_url = "http://cookiesandyou.com"

  # show sharing icons on pages/posts (default: true)
  #sharingicons = true

  # Display post summaries instead of content in list templates (default: true)
  #truncate = true

  # Disable the use of sub-resource integrity on CSS/JS assets (default: false)
  # Useful if you're using a CDN or other host where you can't control cache headers
  #disable_sri = false

  [params.sidebar]
    # Optional about block for sidebar (can be Markdown)
    about = "我的博客[简单示例](http://localhost:1313/)."

    # 侧边栏显示最近几条文章 (Default: 5)
    #num_recent_posts = 2

  [params.social]
    # Optional, used for attribution in Twitter cards (ideally not a person
    # for example: nytimes, flickr, NatGeo, etc).
    # See: https://dev.twitter.com/cards/types/summary-large-image
    twitter = "username"

# Default content language for Hugo 0.17's multilingual support (default is "en")
# See: https://github.com/spf13/hugo/blob/master/docs/content/content/multilingual.md
#DefaultContentLanguage = "en"

# Languages to render
#[languages.en]
#[languages.bg]
  # Bulgarian date format is dd.mm.yyyy
  #date_format = "02.01.2006"

# vim: ts=2 sw=2 et

我们使用以上配置文件,再次启动服务即可

9、将博客部署在Git

建好自己的博客后,需要将其部署在公网,才能让别人访问。有两种方法:

  • 购买自己的域名和服务器,将博客部署在上面。
  • 将博客托管在github。
  • 将博客托管在其他如cloudface分发平台

这里我们介绍第2中方式。

9.1、准备要部署的内容

要想讲博客部署在github,首先得有一个github 账号。

然后需要在github 上创建一个仓库,用于存放我们的博客系统。

我们创建的仓库的名字应该是这种格式"账户名.github.io",比如我创建的仓库的名字为"codeshellme.github.io"。

要向仓库中存放的内容,使用hugo 命令生成的。在myblog 目录下,运行hugo 命令:

>>> hugo
                   | EN  
-------------------+-----
  Pages            | 14  
  Paginator pages  |  0  
  Non-page files   |  0  
  Static files     |  1  
  Processed images |  0  
  Aliases          |  6  
  Sitemaps         |  1  
  Cleaned          |  0  

Total in 74 ms

执行成功后,会生成一个public 目录,这个目录中的内容,就是我们博客系统的所有内容,我们需要将这些内容存放在Git 仓库中。

9.2、部署到Git

按照如下步骤将博客内容上传到Git 仓库,在public 目录下,依次执行下面的命令:

# 初始化仓库
git init

# 将所有内容添加到git
git add .

# 提交到git 本地
git commit -m "我的博客第一次提交"

# 关联到远程git,注意这里需要写你自己的git 地址
git remote add origin https://github.com/yourname/yourname.github.io.git

# 推送到远程git
git push origin master

9.3、访问公网地址

经过上面的步骤,我们就将博客内容托管在了github。那么你的博客的地址将是这种格式:

https://仓库名字

例如博客地址就是:

https://yourname.github.io

访问这个地址就可以访问我们的博客了。

如果以后我们写了新的博客,则需要再使用hugo 命令生成新的内容,再将新的内容push 到Git 仓库就可以

10,给博客添加评论功能

博客有了评论功能才能跟读者互动,所以评论功能对一个博客来说也是必不可少的。

可用的评论系统插件 有挺多的,比如:

在这几个之中,我比较喜欢的Valine,因为其它几个在评论的时候都需要读者登录账号,授权等等,我觉得这样比较麻烦,会让读者失去评论的兴趣。

Valine 不需要读者登录就可以对文章进行评论,而且简洁高效。下面我们主要介绍如何使用Valine 来为我们的博客系统增加评论功能。

10.1,注册登录leancloud 账号

首先需要注册登录一个leancloud 账号,登录账号之后,进入下一步。

10.2,创建一个应用并记录App IdApp Key

登录账号后,进入控制台,点击创建应用来创建一个应用

img

应用创建好以后,进入刚刚创建的应用,点击左下角的设置>应用Key,就能看到你的APP IDAPP Key了:

img

10.3,创建两个存储

因为评论文章阅读数统计依赖于存储,所以要建立两个存储 Class,分别命名为Counter (用于计数功能)和 Comment(用于评论功能)。

左边栏找到并点击 存储,点击 创建Class:

img

10.4,为应用添加安全域名

左边栏点击设置,找到安全中心,点击后会看到安全域名设置框,输入博客使用的域名,点击保存即可,比如填写的是:

https://yourname.github.io/

img

到这里为止,leancloud 账号的设置工作才算完成。接下来我们来看如何使用Valine 评论系统。

11,使用Valine 评论系统

这里我写一个简单html 页面,来演示如何使用Valine,代码如下:

<!DOCTYPE html>
<html>

<head>
    <title>Valine 评论测试</title>
    <!-- 引入Valine js 脚本 -->
    <script src='https://unpkg.com/valine/dist/Valine.min.js'></script>
</head>

<body>
    <h2>下面就是Valine 评论系统</h2>
    <hr />
    <div id="vcomments"></div>
    <script>
    new Valine({
        el: '#vcomments',
        appId: 'xxx',	// 这里填写 10.2 节我们得到的App Id
        appKey: 'yyy',	// 这里填写 10.2 节我们得到的App Key
        notify: false,
        verify: true,
        avatar: 'robohash',
        placeholder: '在这里评论'
    })
    </script>
</body>

</html>

这里面有一些Valine 参数需要解释一下:

参数作用
appId这是在 10.2 节得到的App Id
appKey这是在 10.2 节得到的App Key
notify用于控制是否开启邮件通知功能
verify用于控制是否开启评论验证码功能
avatar用于配置评论项中用户头像样式
placeholder评论框的提示符

可以参见这里查看更多配置项。

然后将上面的html 代码放在Apache 中(也可以是其它Web Server),从浏览器中访问这个html 页面,是这样的:

img

我们就可以在这里评论了。

我们可以进入下面的页面,对这些评论内容进行管理,比如删除评论:

img

12,在Hugo 博客中使用Valine

有些Hugo 主题就自带了Valine 评论功能,我们只需要在配置文件config.toml 中配置就可以使用。

一般配置代码就是下面的样子:

[params.valine]
    enable = true	# 打开评论功能
    appId = 'xxx'
    appKey = 'yyy'
    notify = false  
    verify = true 
    avatar = 'robohash' 
    placeholder = '评论一下,说明你来过~'
    visitor = true

但是,有些Hugo 主题并没自带Valine 评论功能,这就需要我们自己在Hugo 框架中加入Valine 代码。

比如,我们本篇文章中使用的hugo-theme-bootstrap4-blog 主题,就没有Valine 评论的功能。

我们需要稍微了解一下hugo-theme-bootstrap4-blog 主题的代码结构语法,才知道在哪里添加怎样的Valine 代码。

下面跟着我的步骤,为hugo-theme-bootstrap4-blog 主题添加Valine 评论功能。

12.1,编写comments.html 文件

编写代码,文件名为comments.html,并将代码放入themes/hugo-theme-bootstrap4-blog/layouts/partials/ 目录中,代码如下(如果看不懂也没有关系,照着做就行):

{{ if and .IsPage (ne .Params.comment false) -}}

  <!-- valine -->
  {{- if .Site.Params.valine.enable -}}
  <!-- id 将作为查询条件 -->
    {{- if .Site.Params.valine.visitor -}}
	  <span id="{{ .RelPermalink | relURL }}" class="leancloud_visitors" data-flag-title="{{ .Title }}">
		<span class="post-meta-item-text">文章阅读量 </span>
		<span class="leancloud-visitors-count">0</span>
		<p></p>
	  </span>
    {{- end }}
  <div id="vcomments"></div>
  <script src="//cdn1.lncld.net/static/js/3.0.4/av-min.js"></script>
  <script src='//unpkg.com/valine/dist/Valine.min.js'></script>
  <script type="text/javascript">
    new Valine({
        el: '#vcomments' ,
        appId: '{{ .Site.Params.valine.appId }}',
        appKey: '{{ .Site.Params.valine.appKey }}',
        notify: {{ .Site.Params.valine.notify }},
        verify: {{ .Site.Params.valine.verify }},
        avatar:'{{ .Site.Params.valine.avatar }}',
        placeholder: '{{ .Site.Params.valine.placeholder }}',
        visitor: {{ .Site.Params.valine.visitor }}
    });
  </script>
  {{- end }}

{{- end }}

12.2,使用comments.html 文件

themes/hugo-theme-bootstrap4-blog/layouts/_default/single.html 文件中加入下面代码,引入comments.html 文件:

{{ partial "comments.html" . }}

你在single.html 的什么位置加入这行代码,Valine 评论区就在页面的什么位置。

12.3,修改配置文件

在配置文件config.toml中加入下面配置项:

[params.valine]
    enable = true	# 打开评论功能
    appId = 'xxx'	# 填写正确的appId
    appKey = 'yyy'	# 填写正确的appKey
    notify = false  
    verify = true 
    avatar = 'robohash' 
    placeholder = '评论一下,说明你来过~'
    visitor = true	# 开启计数功能

重启博客系统,访问博客中的文章,可见文章中就出现了Valine 评论区

img

到此为止,我们就在Hugo 博客中加入了评论功能。

Hugo丰富工具集

除了强大的内容管理系统外,Hugo 还有很多很好用的内置模板及工具函数,满足不同需求情况下提升搭建效率,抽象实现细节,更专注于站点的搭建,诸如:

这个针对只有列表页的需求,比如博客,发版历史,新闻类等,好用的分页模板,轻松的就帮你完成了。

  • 资源 RSS 模板 - RSS

对于资讯型的站点必不可少,官方已内置了默认的 rss 模板,只需要添加一行代码,即可搞定 rss,当然还支持个性化定制。

  • 各类内容及字符串处理工具函数 - Functions

这个不用多说,对应程序中的各类常见的字符串替换,Hugo 都有着良好的支持,同时它还支持类似 Pipe 管道的方式,将处理内容以 | 分隔层层传递下去,就像我们在 Linux 输入的命令一样。

  • 好用的 CLI 工具

内置了 http server 方便本地开发,同时又能将整个站点打包成纯静态的资源,方便了对于部署的操作和维护成本,可以一键初始化并启动项目,开箱即用的感觉,上手容易。

  • 好用的内容管理工具
    • 迅速提取博客内容的目录导航 - TableOfContents 使用此工具函数,会根据你当前的文章内容,提取目录概要,节省了生成锚点内容的时间。
    • 便捷获取文章的概览内容 - Summary
    • 便捷获取文章的图片资源 - Image Processing
    • 自定义 URL 的规则 - URL Management

以上便是我们在实践中,有接触过的一些 Hugo 比较好用的工具,当然它提供的远比这个更丰富,更多工具可查看参考官方文档

常用的git命令

git add .
//添加所有修改或更新的文件到 Git 仓库

git commit -m "Update"
//提交你的更改

git push origin master
//推送你的更改到 GitHub 仓库

git init
//初始化一个仓库:这将在当前目录创建一个新的Git仓库。

git clone <仓库URL>
//克隆仓库:这将复制远程仓库的内容到本地。

git add <文件名>
//添加文件到暂存区:将指定的文件添加到暂存区,准备提交。

git commit -m "提交信息"
//提交更改:将暂存区的更改提交到版本历史中。

git status
//查看状态:查看工作目录和暂存区的状态。

git log
//查看提交历史:显示提交历史记录,包括作者、日期和提交信息。

git checkout <分支名>
//切换分支:切换到指定的分支。

git branch <新分支名>
//创建分支:创建一个新的分支。

git merge <目标分支名>
//合并分支:将目标分支的更改合并到当前分支。

git pull
//拉取远程更改:从远程仓库拉取最新更改并合并到当前分支。

git push
//推送更改:将本地提交推送到远程仓库。

git rm <文件名>
//删除文件:从版本控制中删除文件。

git mv <旧文件名> <新文件名>
//重命名文件:对文件进行重命名,并将更改提交到版本控制。

git remote -v
//查看远程仓库:查看与本地仓库关联的远程仓库。

git tag <标签名>
//创建标签:创建一个标签,通常用于标记版本。

好了,今天就先总结到这吧~下期再见!

标签
hugo