【腾讯云的1001种玩法】如何腾讯云存储上搭建一个hexo博客

一.选型

我要写文章做博客,我对网站的要求是:

1.可以绑定域名,2.访问速度快,3.价格非常便宜,4.不需要操心维护,5.更新方便。

目前有4个选择:1.IaaS,2.Paas,3.虚拟空间,4具有静态网站功能的云存储(比如腾讯云对象存储COS)。

服务器价格高昂还需要费心维护,Paas价格比较便宜灵活性好,但是需要程序适应平台,虚拟空间共享ip不容易被搜索引擎青睐还不灵活,不能随心变换你的程序。于是乎最好的莫过于云存储,以腾讯云对象存储COS为例,支持静态网站,支持域名绑定,支持相对目录下的默认首页(index.html),这点很重要,例如你访问http://www.abc.com/sub/ 的时候,能访问sub目录下的index.html页面,这点阿里云的云存储是没有的,然后价格特别便宜,由于有免费的额度对于小流量的博客近乎免费,同时提供api接口,写写脚本就可以一键同步内容。好了接下来是具体实现。

二.博客程序

博客程序千千万,我们要能生成静态的,文章用markdown写的,主题不能太少的,于是选择了hexo

http://hexo.io

一款node.js编写的静态博客程序,最概况的操作是运行命令hexo new hello-world生成一个新文章,文章用markdown写好后hexo g生成静态网站,然后把静态网站上传到云存储,OK。

2.1安装hexo

环境要求:安装了node和npm。并运行下面命令:

npm install hexo-cli -g
hexo init blog
cd blog
npm install
hexo server

代码解释:首先用npm安装hexo,然后初始化一个博客,名字就叫blog,进入生成的blog目录,运行初始化安装,最后启动本地调试服务器,可以在本地看到一个博客网站了。

2.2写一文章

hexo new hellokitty

代码解释:新建一篇文章,名字叫做hellokitty,然后打开blog/source/_post/hellokitty.md 文件进行撰写。 文章写好后运行:

hexo g

代码解释:生成了整个静态的博客了,生成在public目录。

三.上传到腾讯云存储

前置要求:已经配置好了腾讯的云对象存储。

3.1拥有一个云存储

这个一笔带过,在腾讯云的对象存储中新建一个Bucket(桶),在桶的基础配置中开启静态网站访问,在域名管理中设置自定义域名并在你的dns解析中做好相应的设置。

3.2写上传脚本

前置条件:在控制台秘钥管理处获取一对秘钥。代码为python,系统需要安装python环境。

先看代码:

push2cos.py

# -*- coding: utf-8 -*-
import os
import qcloud_cos
'''
发布博客到腾讯云cos上面去
腾讯云上面对应的根目录为/blog
'''
COS_APPID=125100066 #你的appid
COS_SECRET_ID=u'<你的秘钥id>'
COS_SECRET_KEY=u'<你的秘钥密码>'
COS_REGION_INFO='guangzhou'#你的云存储的位置,这个看你设置
currentPath=os.path.dirname(os.path.abspath(__file__)) 
cos_client=None
lastChange={}#文件路径和最后修改时间
if  os.path.exists(os.path.join(currentPath,'lastchange.txt')):
    with open(os.path.join(currentPath,'lastchange.txt'),'r') as f:
        for line in f:
            item=line.split(',')
            lastChange[item[0]]=float(item[1])
def upload(remotePath,localPath):
    global cos_client
    if cos_client==None:
        cos_client=qcloud_cos.CosClient(COS_APPID,COS_SECRET_ID,COS_SECRET_KEY,COS_REGION_INFO)
    request=qcloud_cos.UploadFileRequest(u'你云存储bucket的名字',unicode(remotePath) ,unicode( localPath))
    request.set_insert_only(0)
    upload_file_ret = cos_client.upload_file(request)
    print upload_file_ret
def scanPath(pathname,remotePre=''):
    for root,path,filelist in os.walk(os.path.join(currentPath,pathname)):
        for filename in filelist:
            fullPath=os.path.join(root,filename)
            mtime=float(os.path.getmtime(fullPath))
            if fullPath in lastChange:               
                if mtime-lastChange[fullPath]>1:
                    lastChange[fullPath]=float(mtime)
                    remotePath=fullPath.replace(os.path.join(currentPath,pathname),'/blog/'+remotePre)
                    upload(remotePath,fullPath)
            else:
                lastChange[fullPath]=float(mtime)
                remotePath=fullPath.replace(os.path.join(currentPath,pathname),'/blog/'+remotePre)
                upload(remotePath,fullPath)
if not os.path.exists(os.path.join(currentPath,'static')) or not os.path.exists(os.path.join(currentPath,'blog')):
    print '当前目录不存在./blog或者./static目录'
    exit(1)
scanPath('blog/public/')
scanPath('static/','static/')
with open(os.path.join(currentPath,'lastchange.txt'),'w') as f2:
    for key in lastChange:
        f2.write('%s,%f\n'%(key,lastChange[key]))

代码说明:以上代码原理是扫描脚本所在根目录下的blog目录和static目录并检查他们最近的更新时间,如果文件发生了变化就上传到腾讯云,文件lastChange.txt是用来记录文件最后的修改时间。我的博客是放在云存储中的blog子目录里的,各位按需进行相应的变化。记得按需修改目录和相关app参数

3.3 实际使用体验

每次我要写文章,我就运行命令hexo new 新文章,写完后运行hexo g生成静态网站,然后python push2cos.py,三行命令搞定。这个就是我寄放在腾讯云的博客:

http://www.lixin.me

相关推荐

【腾讯云的1001种玩法】利用腾讯云搭建个人博客

腾讯云服务器免费体验

【腾讯云的1001种玩法】如何使用腾讯云做博客

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

编辑于

李鑫的专栏

1 篇文章1 人订阅

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏极客生活

非常Nice的几个Chrome插件

安装一个新的环境,第一件事打开系统自带的浏览器下载安装Chrome,第二件事就是设置为默认浏览器。

561
来自专栏张戈的专栏

关于网站图标favicon.ico那点事儿,你造吗?

众所周知,联盟成员导航是中国博客联盟的特色之一。而网站图标则是导航的装饰之一,起到锦上添花的作用,让页面更精美耐看。 但是随着成员数量的增长,图标便成了页面的拖...

4726
来自专栏游戏杂谈

网页二维码推广App的实现

1、已经下载过的用户,可以直接打开应用(一般人的手机上安装的应用都非常多,要快速找到某个应用是很困难的事情,而且Android、IOS的搜索都做的很烂~ ~ )...

642
来自专栏月色的自留地

解决vs-code高cpu占用率问题

(microsoft.vscode.cpp.extension.darwin进程高cpu占用问题)

1542
来自专栏LiveEdu在线科技教育平台

10个最好用的HTML/CSS 工具、插件和资料库

大家在使用HTML/CSS开发项目的过程中,有使用过哪些工具,插件和库?下面介绍的10种HTML/CSS工具,插件和资料库,是国外程序员经常用到的。

2778
来自专栏魏琼东

应用SAAS结构技术的开源药店管理系统-如何自己部署这种SOA/SAAS结构的应用

一、药店系统内容说明 在前些时间,我们发布了一个基于AgileEAS.NET平台的SAAS结构的案例-AgileEAS.NET平台开发实例-药店系统-快速的SA...

29810
来自专栏静晴轩

Gitcafe绑定自定义域名

之前将自己练习写作工具替换为Markdown,部署工具改为Hexo,并且将托管地搬家到GitCafe之后,便是被各种的舒爽所围绕。她们的组合方便快捷,让人仅仅只...

2865
来自专栏java一日一条

在 Visual Studio 上更好开发 Python 的六大功能!

Visual Studio 2013/2015 搭配 Python Tools for Visual Studio 扩充套件让 Visual Studio 能提...

591
来自专栏Linyb极客之路

我珍藏的神兵利器 - 效率工具

快速启动应用+文件搜索+各种实用插件(计算器、翻译、网页快速访问等)。我的最爱,没有它我几乎半残。

1304
来自专栏技术博客

win7 64位系统及开发环境重装后的总结

   话说来这家公司之后就一直使用这个系统,现在感觉这系统跑的实在是有点慢了,运行,调试各种浪费时间呀,不过也用了将近20个月了,这也可以说是我用的最久的一个系...

806

扫码关注云+社区