基于docker搭建Hugo

在这里插入图片描述

本周和上周一样,除了周六早上,还增加了周二和周三晚上的全区全员核酸筛查,在老苏印象中,上周只有周日没做核酸,这周估计也差不多。

昨晚的结果到现在还没出来呢,辛亏礼拜一去做了一个,要不然今天上班又得在众目睽睽下捅鼻子做抗原 😂

在这里插入图片描述


什么是 Hugo ?

Hugo 是一个用 Go 编写的静态 HTMLCSS 网站生成器。号称是世界上最快的网站构建框架。

之前有网友说,Hugo 使用 Nginx Proxy Manager 反代之后不能正常访问,而其他的可以,问老苏是否还有其他设置项。

没有调查就没有发言权,老苏决定自己在群晖上搭一个,原本以为有 hexo 做基础,应该是手到擒来的事,谁知道还是挺费事的,干脆记录一下吧。

命令行安装

和一般的容器跑起来就是一个 web 服务不同,Hugo 的容器更像是一个开发环境,用来生成静态的 HTML 文件,需要通过执行多次命令来完成网站的搭建。

SSH 客户端连上群晖,依次执行下面👇的命令

老苏常用的SSH 客户端主要是 FinalshellPuTTY

下载镜像

一定要下载带 -ext 的版本,否则安装 themes 可能会遇到 TOCSS 错误

# 下载镜像
docker pull klakegg/hugo:latest-ext

# 新建文件夹 hugo 和 子目录
mkdir -p /volume2/docker/hugo/src

# 进入 hugo 目录
cd /volume2/docker/hugo

生成站点

hexo 一样,也需要通过命令行来创建站点

# 创建一个新的 hugo 站点
docker run --rm -it \
   -v $(pwd)/src:/src \
   klakegg/hugo:latest-ext \
   "new site . --force"

【注意】:截图不是基于 -ext 的版本,但是效果是一样的,从侧面也反映了老苏确实踩了坑 😂

这个时候,src 目录中会出现文件

新建文章

开始建第一篇文章

# 新建第一个帖子
docker run --rm -it \
   -v $(pwd)/src:/src \
   klakegg/hugo:latest-ext \
   "new posts/first_post.md"

在这里插入图片描述

对比之前,又多了一些

在这里插入图片描述

新建的第一个帖子在 /hugo/src/content/posts 目录中

在这里插入图片描述

打开 first_post.md 除了文件头,内容还是空的

为了避免打开是个空白页,我们要填点内容,同时要将 draft: true 改为 draft: false

你好,hugo

![](https://cdn.jsdelivr.net/gh/wbsu2003/images2022@main/picgo/2022/05/202205162339779.png)

关于页面

# 新建 about
docker run --rm -it \
   -v $(pwd)/src:/src \
   klakegg/hugo:latest-ext \
   "new about/_index.md"

在这里插入图片描述

同样需要将 draft: true 改为 draft: false

安装 git

  • 套件中心设置 –> 套件来源 –> 新增

在这里插入图片描述

名称:随意,位置:http://packages.synocommunity.com/

  • 套件中心 –> 社群,找到并安装套件 Git

在这里插入图片描述

下载主题

# 下载主题
git clone https://github.com/reuixiy/hugo-theme-meme.git src/themes/meme

# 不行就加个代理
git clone https://ghproxy.com/github.com/reuixiy/hugo-theme-meme.git src/themes/meme

在这里插入图片描述

下载完成后主题在 src/themes/meme 目录中

修改设置

需要用 src/themes/meme/config-examples/zh-cn/config.toml 替换掉 src/config.toml

# 将配置文件替换为主题的配置文件
rm config.toml && cp src/themes/meme/config-examples/zh-cn/config.toml src/config.toml

在这里插入图片描述

启动服务

# 启动服务
docker run --rm -it \
  -v $(pwd)/src:/src \
  -p 1313:1313 \
  klakegg/hugo:latest-ext \
  server

需要注意的是,这只是调试模式

运行

在浏览器中输入 http://群晖IP:1313 就能看到主界面

在这里插入图片描述

进入帖子

hexo 中复制了几个 md 文件,除了没有封面外,直接可用

在这里插入图片描述

打开文章,效果也挺好的

反代测试

如果你针对 1313端口在 Nginx Proxy Manager 中做反向代理,在浏览器的 开发者工具 中能看到有下面这样的错误

老苏的域名没有备案,所以不能使用 80443 端口,因此域名是带端口的,类似 https://hugo.laosu.ml:444 ,但是 wss 还是会去连 1313 端口

WebSocket connection to 'wss://hugo.laosu.ml:1313/livereload' failed: 

看起来似乎并没有影响使用,和使用 http://群晖IP:1313 访问并没有什么区别。不过这种方式只是用来预览的调试模式,并不是正确的使用方式。

老苏觉得正确的方式应该是生成静态 HTML 文件

# 生成静态文件
docker run --rm -it \
  -v $(pwd)/src:/src \
  klakegg/hugo:latest-ext 

然后将 src/public 目录中生成好的站点静态文件,发布、托管到 Web 服务器,可以选择的方式有很多:

  • Web Station
  • GitHub Pages
  • 基于 nginx 容器搭建的 Web 服务器

其他命令

当然,Hugo 容器还有个更方便的 shell 模式,这种模式下你可以在一个界面完成上面的所有操作

# 启动 shell
docker run --rm -it \
  -v $(pwd)/src:/src \
  klakegg/hugo:latest-ext \
  shell

要生成静态文件,只要输入 hugo 就可以了

要预览只要输入 hugo server

参考文档

gohugoio/hugo: The world’s fastest framework for building websites.
地址:https://github.com/gohugoio/hugo

klakegg/docker-hugo: Truly minimal Docker images for Hugo open-source static site generator.
地址:https://github.com/klakegg/docker-hugo

Hugo中文文档
地址:https://www.gohugo.org/

reuixiy/hugo-theme-meme: You can’t spell aWEsoME without MEME! 😝
地址:https://github.com/reuixiy/hugo-theme-meme

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 要基于Docker搭建Hadoop集群,您需要遵循以下步骤: 1. 安装Docker:您需要在所有节点上安装Docker。可以通过Docker官方文档来了解如何在您的操作系统上安装Docker。 2. 创建Docker镜像:您需要创建包含Hadoop的Docker镜像。您可以使用Dockerfile来创建镜像,并在其中安装所需的软件包。 3. 创建Docker容器:一旦您创建了Docker镜像,您需要在每个节点上创建Docker容器。您可以使用Docker命令来创建容器。 4. 配置Hadoop集群:您需要配置Hadoop集群,以便每个节点都能够与其他节点通信。您需要编辑Hadoop配置文件,如core-site.xml和hdfs-site.xml,并指定节点的IP地址和端口号。 5. 启动Hadoop集群:最后,您需要启动Hadoop集群。您可以使用启动脚本启动Hadoop集群。 在完成这些步骤后,您应该已经成功地在基于Docker的Hadoop集群上设置了分布式计算环境。 ### 回答2: 随着大数据技术的发展,hadoop已经成为了很多企业的首选,但是hadoop的部署和维护是一件非常繁琐的事情,需要很多经验和技巧。为了简化这个过程,很多人开始尝试将hadoop集群部署在docker容器中。 Docker是一个开源的容器化平台,可以轻松地部署和运行各种应用程序。Docker的容器可以在任何运行Docker的机器上运行,这使得hadoop的集群可以很容易地部署在任何地方。 基于docker搭建hadoop集群的步骤如下: 1. 安装Docker 首先需要在每台机器上安装Docker。安装过程可以参考Docker官方文档。 2. 创建docker镜像 在第一台机器上创建一个docker镜像,这个镜像可以包含我们需要的hadoop环境。 可以通过Dockerfile创建这个镜像,并且在 Dockerfile 中指定需要的软件包和配置。这个镜像可以包含hadoop,jdk等组件。 3. 部署容器 在第一台机器上使用这个docker镜像创建一个容器,这个容器就是hadoop的NameNode。可以指定hadoop的配置文件,并且可以将hadoop的数据目录挂载到本地硬盘上。 同时,在其他机器上也创建容器,这些容器就是hadoop的DataNode。 4. 启动hadoop服务 启动NameNode容器后,需要进入容器内部,启动hadoop服务。使用hadoop dfsadmin -report 命令可以查看hadoop集群的状态。 5. 配置hadoop集群 hadoop的配置文件可以在NameNode容器内修改,也可以将配置文件挂载到容器内部。配置文件的修改可以通过修改Dockerfile或者手动修改容器内的文件来完成。 一些hadoop集群相关的配置信息需要在hadoop-env.sh,hdfs-site.xml和core-site.xml等文件中进行修改。 6. 测试hadoop集群 在hadoop集群启动后,可以使用hdfs dfs -ls / 命令来测试hadoop集群的正常运行。 基于docker搭建hadoop集群的优点在于部署和维护都非常方便,同时可以快速地扩展集群。Docker容器可以很容易地在不同的主机上运行,并且可以保证集群的统一性。 ### 回答3: Docker是一种轻量级的容器化技术,可以方便快捷地搭建、运行、迁移和管理软件应用,而Hadoop是目前广泛应用于大数据处理和分析的开源平台,使用Hadoop可以有效地解决数据分析和处理的瓶颈问题。基于Docker搭建Hadoop集群,可以实现快速部署与运维,提高集群的可维护性和可扩展性,同时也可以降低运行成本。 以下是基于Docker搭建Hadoop集群的步骤: 1. 安装Docker:首先需要在主机上安装Docker运行环境。 2. 下载Hadoop镜像:从Docker Hub上下载Hadoop镜像,并创建一个自定义的网络。 3. 创建Hadoop节点容器:创建一个Hadoop节点容器,并在其内部配置Hadoop环境变量。 4. 配置Hadoop:配置Hadoop集群的核心配置文件core-site.xml、hdfs-site.xml、yarn-site.xml和mapred-site.xml等。 5. 启动Hadoop集群:使用start-dfs.sh和start-yarn.sh脚本启动Hadoop集群,查看配置是否生效。 6. 部署应用程序:将应用程序放入Hadoop集群中的HDFS文件系统,使用yarn命令启动应用程序。 7. 监控和维护:使用Hadoop的监控和管理工具,对集群进行监控和维护。 基于Docker搭建的Hadoop集群具有很多优点,如环境准备简单、扩展性强、可移植性高、资源利用率高等,同时也需要注意安全性和稳定性的问题。在实际应用中,可以根据实际需求,对集群进行灵活配置和管理,以便更好地支持大数据处理和分析任务的需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

杨浦老苏

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值