This repository has been archived on 2023-11-13. You can view files and clone it, but cannot push or open issues or pull requests.
blog/README.md
2023-06-03 15:58:09 +08:00

5.9 KiB
Raw Permalink Blame History

诲之的博客

本博客是从黄玄的博客借鉴修改而来,最原始的博客模板是clean blog jekyll,个人认为,博客整体风格是很棒的,对于并不是前端的小白来讲,也比较容易上手,适合折腾一下,不过根据博主自己的经验还是先打好基础再去折腾,会比较不走弯路,不会浪费过多的时间。

User Manual 👉

构建一个Jekyll博客网站需要的东西有一台有公网IP的服务器一个有所属权的域名以及必要的软件环境比如jekyll所依赖的ruby环境jekyll主程序以及web服务器Nginx或者Apache下面我们一步一步来构造let's start~

一个VPS服务器

按照步骤首先需要有一个VPS服务器根据域名是否已经备案可以选择国内或者国外的知名的国内VPS服务器厂商有阿里云的ECS腾讯云的CVM天翼云的EVM还有UCloud,加拿大的BandwagonHost,美国的vultr以及Linode等等,具体如何开通不在此记录。

一个用有所属权的域名

域名Domain Name又称网域是由一串用点分隔的名字组成的Internet上某一台计算机或计算机组的名称用于在数据传输时对计算机的定位标识有时也指地理位置。域名的出现是为了解决IP不好记忆的问题使用域名的另一个好处是可以在同一个IP上构建不同的网站。和VPS一样域名是需要购买的国内国外均有基于维护的成本国内是比较方面的域名提供商也是参考VPS提供商即可。

购买完域名之后需要设置解析即哪一个域名要解析到哪一个IP上

Jekyll环境

接下来配置Jekyll环境Jekyll是一个静态网页生成器诞生之初网络上也充斥着关于静态网页博客的各种讨论和争执不过现在看来似乎没有什么意义了。他就是一个工具内容才是核心。Jekyll是依赖ruby环境的大多数人可能没有听说过这个编程语言我也仅仅是听过而已。不过这并不影响我们使用因为只要安装好环境其他时间我只需要与Markdown打交道。如下是安装环境的主要命令Ubuntu环境下在Debian和Redhat下安装的时候所需要的依赖是不同的这里不详细的记录主要是看报错日志缺少哪个依赖安装上即可。

[root@rustle ~]$ apt install ruby ruby-dev
[root@rustle ~]$ gem install jekyll bundler
[root@rustle ~]$ bundle install
[root@rustle ~]$ jekyll build

web 服务器环境

目前主流的web服务器有nginx和apache两种这里使用nginx为例来做演示如下是安装配置过程

# install nginx
[root@rustle ~]$ wget http://nginx.org/download/nginx-1.20.2.tar.gz
[root@rustle ~]$ tar -xzf nginx-1.20.2.tar.gz && cd nginx-1.20.2
[root@rustle nginx-1.20.2]$ ./configure --with-http_ssl_module && make && make install
...
[root@rustle nginx-1.20.2]$ ln -s /usr/local/nginx/sbin/nginx /usr/sbin/nginx

# configure sercice
[root@rustle ~]$ systemctl enable nginx.service
[root@rustle ~]$ systemctl disable nginx.service
[root@rustle ~]$ systemctl start nginx.service
[root@rustle ~]$ systemctl stop nginx.service
[root@rustle ~]$ systemctl restart nginx.service
[root@rustle ~]$ systemctl status nginx.service

如下是nginx.service的把内容将该文件放在/lib/systemd/system/可执行如上的nginx的启动停止重载等命令

---------------------------------------------------------------------------------------
[Unit]
Description=nginx
After=network.target
  
[Service]
Type=forking
ExecStart=/usr/local/nginx/sbin/nginx -c /opt/websites/conf/rustle.cc.conf
ExecReload=/usr/local/nginx/sbin/nginx -s reload
ExecStop=/usr/local/nginx/sbin/nginx -s quit
PrivateTmp=true
  
[Install]
WantedBy=multi-user.target
---------------------------------------------------------------------------------------

最后是修改nginx域名的配置文件位置一般在/usr/local/nginx/conf/nginx.conf如果是使用apt或者yum这种在线工具安装的nginx那么配置文件在/etc/nginx/conf/nginx.conf修改好重新运行nginx服务即可。

配置证书(可选)

如下是申请Let's Encrypt免费证书的命令行方法只适用于申请单证书。当域名增加的时候只需要重新执行最后一行即可Let's Encrypt证书有效期是3个月可以使用certbot renew --dry-run命令实现自动续期:

[ 0 root@rustle ~]$ yum install epel-release
[ 0 root@rustle ~]$ yum upgrade
[ 0 root@rustle ~]$ yum install snapd
[ 0 root@rustle ~]$ systemctl enable --now snapd.socket
[ 0 root@rustle ~]$ ln -s /var/lib/snapd/snap /snap
[ 0 root@rustle ~]$ snap install core
[ 0 root@rustle ~]$ snap refresh core
[ 0 root@rustle ~]$ snap install --classic certbot
[ 0 root@rustle ~]$ ln -s /snap/bin/certbot /usr/bin/certbot
[ 0 root@rustle ~]$ certbot --nginx-server-root /usr/local/nginx/conf

效果图

Reference

License

Apache License 2.0 Copyright (c) 2022-present Manford Fan

本博客是从黄玄的博客借鉴修改而来,最原始的博客模板是clean blog jekyll,引用借鉴请注明原始出处。