问小白 wenxiaobai
资讯
历史
科技
环境与自然
成长
游戏
财经
文学与艺术
美食
健康
家居
文化
情感
汽车
三农
军事
旅行
运动
教育
生活
星座命理

零成本搭建个人网站

创作时间:
作者:
@小白创作中心

零成本搭建个人网站

引用
1
来源
1.
https://www.cnblogs.com/soulio/p/18308853/zero-cost-build-a-personal-website-2ngwyl

本文将介绍如何使用Markdown笔记、MkDocs工具以及serv00免费服务器,零成本搭建一个个人网站。

方案

Markdown 笔记作为网站的内容。使用 MkDocs 将笔记转换为静态网站,部署到 serv00 免费服务器。将自己的域名解析到服务器。用户通过域名访问网站。
关于域名:

建议购买一个域名。完成本文部署后,国内网络可以直接访问你的网站。

不用自己的域名也行,可以使用 serv00 的免费域名
user.serv00.net
。但是 serve00.net 被墙了,国内网络无法直接访问你的网站。
如果你有魔法加速,在搭建过程中请开启魔法加速。部署完成后可以关闭加速。

1.领取 serv00 免费服务器

视频教程
serv00 领取地址
关于【邮箱不可用】的原因和解决方法:

  • 一个 ip 只能申请一次,多次申请也会提示邮箱不可用:更换节点
  • 部分邮箱不可用:更换邮箱

2.利用 MkDocs 将 Markdown 笔记转换为静态网站

  1. python 虚拟环境
# 更新包列表
sudo apt update  

# 安装python环境  
sudo apt install python3 python3-pip python3-venv -y  
# python虚拟环境  
python3 -m venv .python-venv/  
# 激活python虚拟环境  
source .python-venv/bin/activate  
# 更新虚拟环境的 pip  
.python-venv/bin/pip install --upgrade pip  
  1. 安装 MkDocs
pip install mkdocs -U
pip install mkdocs-material -U  
  1. 创建 MkDocs 项目
mkdocs new ~/mkdocs/
cd ~/mkdocs  
  1. 启动
    mkdocs serve

    127.0.0.1:8000
    预览网站
mkdocs serve  
  1. 将笔记复制到项目 docs 目录下,
    127.0.0.1:8000
    预览网站
  2. 生成网站资源
mkdocs build  

3.部署静态网站到服务器

提供三种方案,选择一种即可:

  • 云服务器 + 域名:需要购买服务器和域名,优点是自由度最高。
  • serv00 免费服务器 +serv00 免费域名:优点是全免费,缺点是这样部署的网站国内无法访问。
  • serv00 免费服务器 + 域名:优点是国内可以直接访问,缺点需要购买域名。
    推荐购买一个域名,除了用来搭建网站,还以可以搭建家庭服务器,性价比很高。

方案一、使用自己的域名

使用 serv00 免费服务器,自己的域名,Cloudflare 代理。这也是推荐的方式。

国内网络   ---无法直达---   serv00服务器(个人网站)  

国内网络   ---Cloudflare代理---  serv00服务器(个人网站)  

优点:国内网络可以访问。
花费:需要购买一个域名。
2.
登录 serv00 管理页面,添加静态网站

~/domains/
可以查看和管理刚添加的站点
4.
上传静态资源到服务器
本地计算机执行

# 打包
zip -r site.zip ~/mkdocs/site/  

# 上传到服务器 ~/domains/域名目录  
scp site.zip user@ip:~/domains/soulio.top/  

在 serv00 服务器上执行

# 切换工作目录到 ~/domains/域名目录
cd ~/domains/soulio.top/  

# 删除域名原来的静态资源  
rm -r public_html/  
# 解包  
unzip -d site.zip  
# 重命名  
mv site/ public_html/  

目的就是用自己的静态文件,替换默认的静态文件。
6.
设置域名的 DNS 服务器为 Cloudflare
注册并登录 Cloudflare
点击【添加站点】,填写自己的域名,根据后提提示完成即可。
8.
域名解析
获取服务器 ip:登录 serv00 管理页面,点击【SSL】>【WWW websites】查看 ip
域名解析:在 Cloudflare 中添加解析。务必勾选代理。

恭喜你完成方案一,现在可以通过域名 soulio.top(自己的域名) 访问自己的网站了。

方案二、使用免费域名和服务器

使用 serv00 免费服务器 + serv00 免费三级域名 + 魔法网络

国内网络   ---魔法加速---  serv00服务器(个人网站)  

优点:免费,零成本。
缺点:国内网络无法直达。
2.
上传静态资源到服务器
本地计算机执行

# 打包
zip -r site.zip ~/mkdocs/site/  

# 上传到服务器  
scp site.zip user@ip:~/domains/xxx.serv00.net/  

在 serv00 服务器执行

# 切换工作目录到域名文件夹
cd ~/domains/xxx.serv00.net/  

# 删除域名原来的静态资源  
rm -r public_html/  
# 解包  
unzip -d site.zip  
# 重命名  
mv site/ public_html/  

恭喜你完成方案二,现在可以通过 serv00 免费域名 soulio.soulio.top(需要魔法网络) 访问自己的网站了。

方案三、使用自己的域名和云服务器

如果你已经一台自己的云服务器,则可以直接部署在云服务器上。网站的加载速度可能会快一些。

国内网络 ---直达--- 国内服务器
国内网络 ---直达--- 国外服务器  

可以使用 Apache/Nginx 部署静态网站,此处以 Nginx 为例。
2.
购买服务器
4.
安装 Nginx

sudo apt install nginx-core -y  
  1. 上传 MkDocs 项目的 site 文件夹到服务器
    在本地计算机上执行
# 打包
zip -r site.zip ~/mkdocs/site/  

# 上传  
scp site.zip user@ip:/usr/share/nginx/html/  

在服务器上执行

# 解包
unzip -d /usr/share/nginx/html/site.zip  
  1. Nginx 部署网站
  2. 添加配置文件 etc/nginx/sites-enabled/mysite
server {
    # 端口
    listen 80;  

# 域名
server_name site.soulio.top;
location / {
    root /usr/share/nginx/html/site; # 静态文件的目录
    index index.html index.htm;
    charset utf-8;
    try_files $uri $uri/ =404;
}  

}

4.  
生效配置  
检查配置合理性  

nginx -t

生效配置  

nginx -s reload

10.  
DNS 解析  
购买域名,域名解析到服务器 ip,示例:  
恭喜你完成方案三,现在可以通过域名 soulio.top(自己的域名) 访问自己的网站了。  
## 结语  
-  
访问示例网站 soulio.top  
- 持续更新 Linux、Docker、Nginx、HomeServer、Net 等计算机笔记。  
- 笔记整理为【官方文档】的形式发布  
- 暂定 两周更新一次  
-  
博客园 和 CSDN 用来发布一些碎片笔记。  
在实践过程中可能会遇到一些难题,可以通过学习以下知识点解决:  
scp 命令、Nginx 基础、DNS 解析、文件打包和解包命令、MkDocs 基础操作、Cloudflare 域名解析操作。
© 2023 北京元石科技有限公司 ◎ 京公网安备 11010802042949号