本文介绍如何在树莓派上搭建一个可以外网访问的静态博客1. 软件硬件环境需求
硬件需求树莓派:Raspberry-Pi 3b(当前版本),如图1.1花生棒:内网穿透工具
路由器:不限
软件需求Nginx:一款web代理服务器
Hexo:静态博客生成工具Markdown编辑器:markdown语法编辑器,常用于博客
2. 安装博客生成工具树莓派上可安装的静态博客工具种类繁多,此处介绍Hexo博客生成工具,Hexo具备简单易用、主题丰富等特点,被广泛应用在Github Page博客中,关于Hexo的特点,更多详情可访问Hexo官网。本文使用Hexo搭建博客,要使用Hexo建站,需要实现以下几个步骤。
步骤1 安装Git
确保你的树莓派已经安装了Git代码工具(貌似不推送到Github Page的话可不安装)
Debian: sudo apt-get install git-core
树莓派3B的Debian系统自带Git工具,可跳过此步。
步骤2 安装Node.js
Hexo的运行依赖于该语言环境,安装Node.js的最佳方式是使用nvm,首先输入以下两条命令:
cURL:$ curl https://raw.github.com/creationix/nvm/master/install.sh | shWget:$ wget -qO- https://raw.github.com/creationix/nvm/master/install.sh | shnvm安装完成后,关闭终端并重启,运行以下命令安装Node.js.$ nvm install 4
步骤3 安装Hexo完成上述环境需求后,即可使用npm安装Hexo.$ npm install -g hexo-cli
步骤4 简单配置Hexo工作环境Hexo需要一个独立的文件夹作为博客的管理空间,首先进入家目录:/home/xxx/,使用mkdir Blog命令创建一个博客文件夹,得到博客的目录:/home/pi/Blog/,在该目录下,输入命令:
# hexo init
等待该命令的执行,以完成博客环境的初始化,此命令只有在第一次创建博客环境时需要执行。
初始化完成后Hexo生成了一系列的文件目录,如图2-1所示:
其中博客存放在Blog/source/_posts目录下,假设当前已经有写好的文章(Hexo初始化后存在一篇HelloWorld.md文章),在Blog/下输入以下命令来生成静态博客:
# hexo g
该命令将解析生成的静态博客存放在目录/Blog/public/下。要想看到博客的网页效果,可使用以下命令:
# hexo s
执行该命令后终端打印出:INFO Start processing
INFO Hexo is running at http://localhost:4000/. Press Ctrl+C to stop.
在本地浏览器中输入上述url即可看到静态网页,如图2-2所示:
3. 安装使用web服务器3.1 安装Nginx服务器要想实现局域网内的博客访问,还需要实现web服务代理,考虑到树莓派性能的限制,此处选择安装一款轻量级的Web 服务器Nginx,安装命令如下:# sudo apt-get install nginx安装完成后启动nginx:# sudo /etc/init.d/nginx start
完成启动后使用ifconfig查询当前树莓派的IP地址,在浏览器中输入IP地址即可看到Nginx建立的网页效果,如图3-1所示。
Nginx的www根目录默认在 /usr/share/nginx/www/下,为了让Nginx指向Hexo解析生成的博客,需修改Nginx的配置文件。首先打开配置文件:# sudo vim /etc/nginx/sites-available/default配置文件的主要内容如下:# Default server configuration#server {listen 80 default_server;listen [::]:80 default_server;# SSL configuration## listen 443 ssl default_server;# listen [::]:443 ssl default_server;## Self signed certs generated by the ssl-cert package# Don't use them in a production server!## include snippets/snakeoil.conf;#root /var/www/html;root /home/pi/Blog/public;
配置文件中主要关注两点:监听端口号以及Nginx代理的博客地址,listern 一栏默认端口号为80,可改成其它非默认端口号,root一栏为博客首页所在路径,更改到个人博客的目录下即可(参照上述配置)。
3.2 配置本地静态IP一般情况下,设备的IP地址是动态分配的,要实现对博客的外网访问,有必要将树莓派IP地址配置成静态。通过以下命令配置网口:# sudo vim /etc/network/interfaces打开网口配置文件后,需根据个人选择的网络连接进行配置,以树莓派3B为例,该版本支持以太网口及Wi-Fi连接,本例中使用Wi-Fi连接到室内路由器,因此需对wlan0作如下类似修改:allow-hotplug wlan0iface wlan0 inet staticwpa-conf /etc/wpa_supplicant/wpa_supplicant.confaddress 192.168.1.55netmask 255.255.255.0gateway 192.168.1.1文件中将wlan0的manual修改为static,并根据当前路由器的网段配置了静态IP(需保证与其它设备不冲突),其它网口配置类似,完成之后重新启动网络即可。
# sudo /etc/init.d/networking restart
3.3 上电启动Nginx写到这里已经忘了Nginx安装完后是否默认打开了上电启动服务,不过要想设置Nginx或其它服务的上电启动或禁止,可使用sysv-rc-conf服务工具,该工具在终端下提供了一个简单的“可视化”界面,设置过程比较简单。首先需安装sysv-rc-conf:#sudo apt-get install sysv-rc-conf安装完成之后执行以下命令启动配置服务:
# sudo sysv-rc-conf
图3.2中的service列对应各个服务,每种服务所在的行对应不同的运行级别,从0~6及S,中括号内的“空格”表示当前运行级别下关闭该服务,“X”表示开启该服务。该图中可以用鼠标点击配置,也可以用键盘方向键来定位,然后用空格键选择;其中组合键Ctrl+N表示翻下一页,Ctrl+P翻上一页,q退出。配置完成后重启树莓派即可。
4. 配置花生壳
前三节已经实现了局域网内的博客搭建及访问,要实现公网下对树莓派博客的访问则限制颇多。
首先,当前多数家庭或公司的路由器的公网IP有租时限定,IP地址随机分配,因此难以做到直接邦定个人域名;此外,有些地区电信运营商封杀个人网络的80/8080端口,实现公网访问更加困难。因此常见的搭建个人公网博客的方式有:租赁虚拟主机,如阿里云,腾讯云.etc.使用类似Github Page,cnBlogs这样的博客平台。内网穿透技术,俗称的“打洞”。
或许还有其它的方式,暂且不表。对比三种方式可知,欲实现公网访问树莓派博客网站,还是内网穿透技术比较靠谱,铺垫了这么多,终于引出了花生棒这么一款硬件产品。
花生棒是一款实现了内网穿透及动态域名解析技术的硬件产品,这使得局域网内的主机能够被外网所访问,更多功能详情可参考花生壳介绍。
本文只介绍如何配置花生棒,使得其能够动态解析公网域名并访问到内网的树莓派中。
4.1 购买及配置
花生棒的最新版本为2代,Oray官网针对花生棒推出了多款套餐,如果只是拿来学习用,买全裸花生棒即可,所实现的功能一样,但价格最便宜,点击购买链接即可购买。
花生壳的供电很简单,使用Micro USB接口(常见的安卓数据线),电源适配器建议使用旧手机充电头(供电5V,电流<1A)即可。 完成供电后通过网线连接到路由器,当LED灯从闪烁变成绿灯常亮时,花生壳成功连接到ORAY服务器。
此时登陆ORAY官网,在“管理中心->产品管理”下,选择花生壳,即可添加花生棒,需要填入的SN码在购买的花生棒背面。按照提示完成花生棒的注册激活。
4.2 内网映射
在ORAY官网打开已注册的花生棒,选择内网映射,如图4-4所示,每个花生棒都赠送了一个免费的域名,例如 12345.cicp.net,此外,用户也可以再免费注册一个ORAY下的二级域名,比如笔者为树莓派注册的域名:raspberrypi.imwork.net。想要更加个性化,则可在ORAY下购买顶级域名或者将个人域名转入ORAY账户下。
在内网映射中,点击当前域名一栏的编辑选项对域名进行配置,如图4-5所示,应用类型选择自定义应用,应用名称自定义即可,内网主机填入当前局域网内的树莓派静态IP地址;内网端口类型选择端口映射,内网端口号为树莓派的Nginx代理服务器的配置端口号,默认为80端口,外网端口号为浏览器访问路由器的端口号,选择HTTP80端口即可。完成配置后保存,等待几分钟后在浏览器输入域名,即可访问自己的树莓派博客了。
最后,想吐槽的是,花生棒虽然能用,但是还是有较多不足之处,比如偶尔响应较慢,无Wi-Fi版本;此外还对流量进行严格限制,还好博客没人访问,要不然早给超限关闭了,若有更好的类似产品欢迎读者推荐。
点击阅读原文了解更多详情
特 别 推 荐
芯片的诞生全过程 复杂漫长的旅程
如何优雅地进行PCB布线?
一大批动图让你真正了解电机