利用云服务器搭建个人博客

本文涉及的产品
云服务器 ECS,u1 4核8GB 1个月
云服务器 ECS,u1 4核16GB 1个月
云服务器ECS,u1 2核4GB 1个月
简介: 使用ESC云服务器和github actions搭建个人博客并且自动化部署

1、本地安装hexo

安装的前提是安装了nodejs,然后才能使用nodejsnpm进行安装

npm install hexo-cli -g

2、创建个人博客

hexo init blog

3、命令行切换至博客目录并进行初始化

cd blog

npm install

4、在本地进行查看

hexo server

注:本教程不涉及更换主题

5、在GitHub创建仓库并将代码上传到仓库之中

git init

git add .

git commit -m"自己的备注"

git remote add origin https:// http://7881188.cn/自己的仓库url地址

git push -u origin master

6、创建githubaction

name: deploy blog to aliyun

on:

 push:

   branches:

     - master

jobs:

 build:

   runs-on: ubuntu-latest

   steps:

     # 切换分支

     - name: Checkout

       uses: actions/checkout@master

     # 下载 git submodule

     - uses: srt32/git-actions@v0.0.3

       with:

         args: git submodule update --init--recursive

     # 使用 node:10

     - name: use Node.js 10

       uses: actions/setup-node@v1

       with:

         node-version: 10

     # npm install

     - name: npm install

       run: |

         npm install -g hexo-cli

         npm install

       env:

         CI: true

     # build

     - name: hexo build

       run: |

         hexo clean

         hexo generate

       env:

         CI: true

     # Deploy

     - name: Deploy

       uses: easingthemes/ssh-deploy@v2.0.7

       env:

         SSH_PRIVATE_KEY: ${{ secrets.ACCESS_TOKEN }}

         ARGS: "-avz --delete"

         SOURCE: "public/"

         REMOTE_HOST: ${{ secrets.REMOTE_HOST }}

         REMOTE_USER: ${{ secrets.REMOTE_USER }}

         TARGET: ${{ secrets.TARGET }}

先别提交,然后设置上述代码中的secrets.ACCESS_TOKENsecrets.REMOTE_HOSTsecrets.REMOTE_USERsecrets.TARGET

浏览器新增一个窗口,打开现在的这个项目的网页,然后点项目后面的Settings,然后点击Secrets中的Add a new secret按钮。

image.png

首先添加的是ACCESS_TOKEN(名字与第二步的workflow中名字相同就可以了),这个值并不是你服务器的密码。那么这个值是什么呢?首先去你服务器的~/.ssh目录,此时目录下应该有4个文件,分别是authorized_keysid_rsaid_rsa.pubknown_hosts。如果没有id_rsaid_rsa.pub的,可以使用ssh-keygen来生成,这两个文件就是安装Git时需要生成的私钥和公钥。这个时候你看看authorized_keys里面有没有内容,如果有内容说明你之前设置过,ACCESS_TOKEN的值就是authorized_keys所对应的私钥。如果没有内容的话,你可以直接设置为公钥id_rsa.pub的内容,如执行命令cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys,此时就会把id_rsa.pub的内容写入authorized_keys中,然后把ACCESS_TOKEN的值设置为私钥id_rsa中的内容,你可以运行命令cat ~/.ssh/id_rsa 然后把内容复制一份到ACCESS_TOKEN中,如下:

image.png

设置ACCESS_TOKEN值的目的是为了远程不使用密码来连接服务器,当ACCESS_TOKEN的值设置好了,接下来就容易了。依次设置REMOTE_HOSTREMOTE_USERTARGET的值,比如47.111.177.111root/home/blog等,具体的根据自己的ECS来设置。

提交workflow文件。 浏览器的标签切换到刚才的那个页面,然后提交workflow。当提交后可以看到代码的根目录下多了一个.github/workflows/deploy.yml文件(文件名叫什么无所谓),然后点击Actions标签看有一个workflow在运行,等待一会,如果显示如下,说明就好了:

image.png

7上传到服务器了,然后在服务器进行网站部署就行了


相关实践学习
ECS云服务器新手上路
本实验会自动创建一台ECS实例。首先,远程登陆ECS实例,并部署应用。然后,登陆管理控制台,并对这台ECS实例进行管理操作。
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情: https://www.aliyun.com/product/ecs
相关文章
|
12月前
|
域名解析 弹性计算 网络协议
如何在阿里云服务器搭建个人网站?
如何在阿里云服务器搭建个人网站?阿里云轻量应用服务器怎么使用?阿里云轻量应用服务器使用教程:轻量应用服务器购买、重置密码、远程连接、宝塔面板的Web环境搭建、WordPress网站程序安装到网站上线,阿里云服务器网分享轻量应用服务器从购买、配置建站环境、轻量服务器应用服务器远程连接、开端口到网站上线全流程
185 0
|
2月前
|
域名解析 弹性计算 数据安全/隐私保护
阿里云ECS免费搭建WordPress个人博客网站
阿里云ECS免费搭建WordPress个人博客网站
575 2
阿里云ECS免费搭建WordPress个人博客网站
|
弹性计算 关系型数据库 MySQL
阿里云ECS服务器搭建wordpress个人博客网站【详细图文教程】
阿里云ECS服务器搭建wordpress个人博客网站【小白专用的图文教程】 购买前请先领取阿里云幸运券 随机优惠还能百分百中奖小米电源一个! 在阿里云上搭建使用个人博客主要分为以下几个步骤: 1、购买阿里云ECS主机 2、购买域名 3、申请备案 4、环境配置 5、安装wordpress 6、域名解析 声明一下,本人对服务器端的知识不是很熟悉,但一心想做个自己的个人网站装一下哔,特此记录一下完整的配置过程,也算是给其他小白们的一剂福利吧。
50972 0
|
网络协议 数据安全/隐私保护 Web App开发
|
10月前
|
存储 程序员 API
30分钟快速搭建并部署一个免费的个人博客
30分钟快速搭建并部署一个免费的个人博客
169 0
|
域名解析 弹性计算 安全
技术干货!使用阿里云服务器搭建个人网站
技术干货!使用阿里云服务器搭建个人网站,使用阿里云服务器快速搭建网站教程,先为云服务器安装宝塔面板,然后在宝塔面板上新建站点,阿里云服务器网以搭建WordPress网站博客为例,来详细说下从阿里云服务器CPU内存配置选择、Web环境、域名解析到网站上线全流程:
9393 0
|
域名解析 弹性计算 安全
用阿里云服务器搭建一个自己的网站!
用阿里云服务器搭建一个自己的网站,使用阿里云服务器快速搭建网站教程,先为云服务器安装宝塔面板,然后在宝塔面板上新建站点,阿里云服务器网以搭建WordPress网站博客为例,来详细说下从阿里云服务器CPU内存配置选择、Web环境、域名解析到网站上线全流程:
336 0
|
域名解析 网络安全
|
弹性计算 Linux
使用阿里云ECS搭建属于自己的wordpress个人博客体验
本文介绍了作者这段时间使用阿里云ECS的体验和搭建wordpress过程中遇到的一些问题和自己当时的想法,以及经过一个多星期的使用有哪些收获。
使用阿里云ECS搭建属于自己的wordpress个人博客体验
|
开发框架 .NET Serverless
阿里云快速搭建个人博客
使用阿里云体验搭建博客
阿里云快速搭建个人博客