本项目是用树莓派制作一个轻量级的web服务器,提供一个公网地址供所有用户(也可限定账号登录)来进行下载图片、文件、与gpt3.5进行聊天、与midjourney进行绘画交互。简单来说,制作一个集图片、文件、聊天、绘画四个功能模块的web,用树莓派作为其web服务器,利用apache2生成内网网址,再使用ngrok进行内网穿透,使得其在公网中也可访问。
普通用户可能有时候需要某一个特定的地方下载文件,比如学生从mystu上下载学习资料或者到ftp里面下载一些共享的文件,亦或者从邮箱上下载某些文件。在下载的时候会遇到种种问题,其中比较特别的就是离开了该局域网后就不能下载某个网站下的图片或者文件了,因此树莓派可以用作公网的微服务器来用于web的搭建、文件的传输、图片的下载…等等。
对于web开发者,假如做出了一个vue\ react 或者其他简单的html的静态页面,想让公网的全部人都看到并且能够输入网站进入该页面,而不是只有localhost或者局域网内的用户能看到,那么树莓派+apache2+ngrok+内网穿透+vue build就能实现这一点。
其实对于静态网站的部署有很多办法,其中免费且稳定的方法就有GitHub Page,下图就是一个使用Github Page部署一个用Slidev构建的线上ppt的例子,使用https://hiddensharp429.github.io/slidev/1就可以访问这个部署在Github上的项目了。html项目、vue打包后的项目、react打包后的项目等等都可以直接部署在Github上面,但是这个
这个二级域名你是不可以修改的,只有你购买的域名才有修改这个二级域名的权利。
由此就凸显了树莓派+ngrok的威力了,使用ngrok部署的项目可以自定义二级域名例如可以使用https://hiddensharppi.ap.ngrok.io \ https://hiddensharppi.in.ngrok.io/\ https://hiddensharppi.ngrok.com/等等域名,并且hiddensharppi这个字段是可以任意编辑的(例如我改成**https://ilovestudy.ap.ngrok.io/**完全可以)。
假如有多个人需要相互之间传输下载文件,但是又不想使用微信等通讯工具来满足其需求,这时候树莓派就可以充当一个小型的文件服务器了,如果这几个人在同一个局域网内进行通讯就可以直接通过访问树莓派内存里面的文件夹share来进行文件的传输,该项目的注重的是在公网内用户如何达到这样的一个目的:“管理员上传相关的文件,来自不同局域网的用户通过输入网址来访问树莓派服务器,点击相关文件的url链接来下载他们所需要的文件”。
用户使用树莓派的web服务器主要要求服务器具有如下特征:
对于第一点域名友好的,树莓派web服务器可以使用ngrok来进行二级域名和最大程度的域名自定义,由此可以实现第一点;
对于第二点服务稳定的,树莓派相对于电脑作为web服务器,树莓派本身机身小,不需要关机,连接简单,操作易上手等等特性使得其可以称得上是微型web服务器的最优选;
对于第三点延迟较低的,树莓派web服务器原本是用apache2进行局域网内的网址部署,但是利用了ngrok进行了内网穿透,使得本来只能局域网内访问的网址变成了在联网的情况上均可以访问的网址。
树莓派通常使用Raspbian作为默认操作系统,它是基于Linux的。同时也可以选择使用其他的操作系统,例如Ubuntu等,若想要完成这个项目,要求对Linux系统操作命令拥有一定的熟练度。
本项目主要的涉及的技术栈有Raspbian、Apache、Nginx、http\tcp\ip协议、ngrok、ssh、vue.js、node.js、html、css等,由于该项目的树莓派使用的内存是16G的,故没有涉及到后端开发,因此之前所搭建的个人Chatgpt网站和Midjourney网站就没有上传至树莓派服务器。
本项目主要选择方向是想使用的ngrok来进行树莓派的内网穿透,主要使用过内网穿透有:国内之前比较好用的ngrok.ttun\ frp \ ngrok.ciqiuwl \ ngrok等,该项目的最后选择的是ngrok。
根据项目的预期负载和网站的性质,应该选择适当的树莓派型号。不同型号的树莓派具有不同的处理器和内存规格,较高规格的型号可以处理更多的并发请求和复杂的任务。
树莓派的内存(RAM)对于同时处理多个请求和运行内存密集型应用程序非常重要。较大的内存容量可以提高服务器的响应速度和性能。
存储空间:考虑您需要存储的网站内容和相关文件的大小。选择合适的存储介质,如SD卡或外部硬盘驱动器,以满足您的存储需求。
在命令行中使用cat /proc/cpuinfo
后输出
renegadew@raspberrypi:~ $ cat /proc/cpuinfo
processor : 0
model name : ARMv7 Processor rev 3 (v7l)
BogoMIPS : 108.00
Features : half thumb fastmult vfp edsp neon vfpv3 tls vfpv4 idiva idivt vfpd32 lpae evtstr m crc32
CPU implementer : 0x41
CPU architecture: 7
CPU variant : 0x0
CPU part : 0xd08
CPU revision : 3
processor : 1
model name : ARMv7 Processor rev 3 (v7l)
BogoMIPS : 108.00
Features : half thumb fastmult vfp edsp neon vfpv3 tls vfpv4 idiva idivt vfpd32 lpae evtstr m crc32
CPU implementer : 0x41
CPU architecture: 7
CPU variant : 0x0
CPU part : 0xd08
CPU revision : 3
processor : 2
model name : ARMv7 Processor rev 3 (v7l)
BogoMIPS : 108.00
Features : half thumb fastmult vfp edsp neon vfpv3 tls vfpv4 idiva idivt vfpd32 lpae evtstr m crc32
CPU implementer : 0x41
CPU architecture: 7
CPU variant : 0x0
CPU part : 0xd08
CPU revision : 3
processor : 3
model name : ARMv7 Processor rev 3 (v7l)
BogoMIPS : 108.00
Features : half thumb fastmult vfp edsp neon vfpv3 tls vfpv4 idiva idivt vfpd32 lpae evtstr m crc32
CPU implementer : 0x41
CPU architecture: 7
CPU variant : 0x0
CPU part : 0xd08
CPU revision : 3
Hardware : BCM2711
Revision : c03111
Serial : 100000002b61e311
Model : Raspberry Pi 4 Model B Rev 1.1
由于里面没有MemTotal
相关字段,故需要安装lshw
来查看内存情况。
### lshw通常没有默认安装的,需要手动安装。
### 第一步先更新
sudo apt update
### 第二部安装lshw
sudo apt install lshw
### 第三步执行lshw命令
sudo lshw -short | grep memory
输入该命令后输出了/0/5 memory 3838MiB System memory
即内存存量为3838MiB(3.8G)。
使用的树莓派的型号是Raspberry Pi 4 Model B Rev 1.1,并且配备了ARMv7架构的处理器,它具有相对较强的处理能力和内存支持,通常可以胜任轻量级的Web服务器任务。
综上所示对于一般的Web服务器需求,树莓派4 Model B是一个经济实惠且功能强大的选择。
操作系统:树莓派常用的操作系统是基于Linux的Raspberry Pi OS(以前称为Raspbian)。它是专门为树莓派设计的操作系统,内置了许多优化和适配。可以从树莓派官方网站下载并安装Raspberry Pi OS。
Web服务器软件:您可以选择安装常见的Web服务器软件,如Apache、Nginx或Lighttpd。这些软件在树莓派上都有相应的版本,并且支持常见的Web技术和协议,如HTTP和HTTPS。
文件传输:使用FileZilla已经ssh通讯来完成树莓派和本地电脑之间的文件传输,从而达到不需要在树莓派中写web开发的相关代码,直接在本地windows电脑上写好后传到树莓派上即可。
内网穿透:订阅了ngrok的personal类型的账号,从而可以达到自定义域名的目的。
整个项目大致分为三个阶段:前期、中期和后期。
Raspberry Pi 4 Model B Rev 1.1拥有如下配置
BCM2711芯片
搭载四核ARM Cortex-A72处理器
内存是4GB的
内置了VideoCore VI图形处理器,支持OpenGL ES 3.x和硬件加速的视频解码
提供了两个特殊的HDMI接口
它支持千兆以太网接口
并且具有两个USB 3.0接口和两个USB 2.0接口
具有双频(2.4 GHz和5 GHz)802.11ac无线局域网(Wi-Fi)和蓝牙5.0,可以无线连接到网络和外部设备。
该项目将要用到的硬件设施如下
- 一台显示器
- usb接口的鼠标
- usb接口的键盘
- 千兆网线
- 特殊的HDMI线
以下将列出在做项目过程中学习并使用到的所有命令
sudo apt-get update //更新Ubuntu系统软件包列表
sudo apt upgrade //升级 Ubuntu 系统中已安装软件包
sudo apt install nodejs //安装nodejs
sudo apt install npm //安装npm
sudo apt-get install <packageName> //用于在 Ubuntu 系统中安装软件包
sudo apt-get install raspi2png //安装raspi2png
sudo raspi-config//打开Raspberry Pi 配置工具
sudo raspi2png -p screenshot.png //使用raspi2png进行页面截图
ifconfig //显示ip地址
ip addr show //显示ip地址
whoami //显示当前登录用户的用户名
sudo passwd <username> //更改用户的密码
sudo nft list ruleset //查看防火墙规则
sudo service ssh status //查看ssh服务是否在运行
sudo service ssh start //开启ssh服务
ls //当前文件夹中的所有文件和子文件夹的列表
ls -l //长格式列出文件和文件夹,并包括它们的权限、所有者、大小、修改日期
ls -a //括以点开头的隐藏文件和文件夹。
sudo tar xvzf /ngrok-v3-stable-linux-amd64.tgz -C /user/local/bin //n解压grok文件到/user/local/bin目录中
sudo nautilus //以管理员身份运行文件管理器
sudo unzip /path/to/ngrok.zip //解压某个文件
sudo ngrok config add-authtoken <your authoken> //为ngrok配置token
sudo ./ngrok http 80 //使用ngrok启动树莓派服务器的80端口
cd /etc/apache2/ //跳转到指定的文件目录下
sudo vim ports.conf //用管理员的身份进入ports.conf文件进行修改
sudo service apache2 restart //重启apache2服务
简述:
本地电脑连接树莓派需要树莓派开启ssh服务,先前一直连接不上树莓派有个原因就是树莓派的ssh服务没有开启。
解决方法:
(这里我就不在树莓派上演示了,用远程的windows电脑操控它,这样好截图)
这样就开启了ssh服务了,值得注意的是树莓派初始的ssh管理是比较松的。
使用sudo service ssh status
查看ssh服务是否开启
前提:
结果:
使用该软件远程连接树莓派失败,显示异常
分析:
解决办法:
使用PuTTY来进行远程连接(仅命令行)
显示如下页面即为连接成功
注意:请确保本机与树莓派在同一局域网内,并且树莓派开启了ssh
PuTTY是一款集成虚拟终端、系统控制台和网络文件传输为一体的自由及开放源代码的程序。它支持多种网络协议,包括SCP,SSH,Telnet,rlogin和原始的套接字连接。——wikipedia
PuTTY软件的使用在初级阶段记录中有相关描述在此就不再赘述
https://www.chiark.greenend.org.uk/~sgtatham/putty/latest.html
FileZilla是一种免费的FTP客户端以及服务器端开放源代码程序,具有多种平台的软件包,可以在Windows,Linux和macOS平台上运行。服务器和客户端都支持FTP和FTPS,而客户端还可以连接到SFTP服务器。
如图例,点击上传了后将会将左边全部所选文件传输到右边文件夹里面。
使用下列命令来给树莓派进行安装相关的软件包
sudo apt install nodejs
sudo apt install npm
sudo apt-get install raspi2png
sudo apt-get install apache2
可以使用node -v
和npm -v
来查看npm和node是否安装成功
该部分在4.4.1树莓派开启ssh服务中有具体的阐述,在此不再赘述。
在执行了5.2中的sudo apt-get install apache2
命令后会在树莓派的/var/www/html
生成一个apache的初始页面index.html
文件。
放置在这里面的html文件都会被部署到树莓派服务器上。(前提是你的apach在运行中),下面这张图是我部署了打包后的vue项目,并非初始的index.html,一开始只有一个index.html文件。
在浏览器上输入你的树莓派ip地址,这里我的树莓派ip地址是10.141.42.21,后会看到下面这个页面。
至此简单的部署就完成了,在你所属的局域网的所有用户均可以通过使用浏览器访问树莓派的ip地址来看树莓派这个web服务器上面部署了什么页面。
值得注意的是仅限于局域网内,并非公网可访问的。
问题背景:
想要部署自己的页面到树莓派服务器上主要有两步
index.html
相关文件index.html
相关文件通过FileZilla
上传到/var/www/html
中在使用FileZilla进行上传和删除操作的时候会报错,显示权限不过。
解决方法:
在树莓派图形界面或直接在FileZilla中将html文件的修改权限从user->all,开放html文件夹里面的所有文件的更改权限
问题描述:
该web仅有在用户所用网络与树莓派在同一局域网下才可访问部署在树莓派上的web,假如用户使用别的网络去浏览器访问树莓派的ip地址10.141.42.21
,会显示连接不上
解决办法:
使用内网穿透技术使得部署在树莓派上的web项目暴露在公网中供用户访问,将考虑使用ngrok、ngrok-ittun、nginx等工具
使用unzip /path/to/ngrok.zip
为ngrok-v3-stable-linux-arm .tgz解压
在命令行中使用ngrok config add-authtoken
为ngrok配置账号token
使用./ngrok http 80
来启动ngrok,默认端口是80端口
启动后可以访问Forwarding后面的网址https://f4916595f05a.ngrok.app
来访问树莓派上部署的web,不需要在跟树莓派同一局域网中就可以访问到该web了。
单独只是这样还不够优雅,ngrok除了支持最基本的内网穿透还提供很多增值服务,其中选定服务器地区Region
和二级域名subdomain
功能都可以应用
这条指令有些参数是可选的,比如--region
和 --domain
以及后面的9000
这个端口,具体的参数列表可参考官方中文文档http://ngrok.cn/docs.html#subdomain
该网站是用vue2 + node.js + js + vue cil来构建的,源代码会打包在一个名为pi-website的压缩包里面,同时在附录部分也会列出来。注意,由于考虑到树莓派的性能问题,故只完成了文件和图片两个模块,聊天
模块被单独分离出来,详情请看chatgpt-web,聊天模块暂时还没有开发出来。
dist:build生成的文件
src:源代码目录
babel.config.js:Babel配置文件
package.json:项目配置文件
vue.config.js:Vue配置文件
…
原本是想将chatgpt和midjourney部署到树莓派服务器的,但是由于后端开发的经验较少,并且树莓派的硬件承受不起这两个模块的并发运行,故只能将本地部署chatgpt的vue项目打包成一个rar放到服务器上了。若想要在本地部署chatgpt可按照下方这个简易的操作步骤来,也可参考压缩吗里面的README文件。
npm install pnpm -g
pnpm bootstrap
pnpm install
pnpm start
启动后端pnpm dev
即可运行
使用./ngrok http --region=ap --domain=hiddensharppi.ap.ngrok.io 9000
启动ngrok服务,将本地9000端口(apache2所启动的端口)进行内网穿透,使得在外网的用户也可访问。
树莓派网址:https://hiddensharppi.ap.ngrok.io/#/drawing
问题背景:
使用sudo apt-get install nginx
显示无法定位软件包
解决办法:
sudo apt-get update
apt-cache search nginx
搜索相关可用软件包sudo apt-get install nginx
注:该项目最后没有使用nginx,还是无法正常安装。
说明从网上了解ngrok-ittun内网穿透支持二级域名的修改,并且延迟较低,但是好像从2018年开始启用ngrok-ittun就会一直显示reconnecting
资料来自于腾讯云开发者社区https://cloud.tencent.com/developer/article/1093830?areaSource=106002.12
问题背景:
许多软件启动的进程均在80端口,因此在进行web的部署的时候可能会发生冲突。
解决方法:
将apache2服务默认端口设置成9000,启动ngrok时也启动9000端口
cd /etc/apache2/
sudo vim ports.conf
,对ports.conf文件进行修改。# If you just change the port or add more ports here, you will likely also
# have to change the VirtualHost statement in
# /etc/apache2/sites-enabled/000-default.conf
Listen 9000 //这里填写你想要它默认启动的窗口,原本是80
Listen 443
Listen 443
# vim: syntax=apache ts=4 sw=4 sts=4 sr noet
sudo service apache2 restart
重启apache2
PI website
图片
文件
聊天
绘画
welcome to my pi website
@author:hiddensharp
欢迎来到我的树莓派web服务器
×
/*
* @Author: hiddenSharp429 [email protected]
* @Date: 2023-06-28 14:56:45
* @LastEditors: hiddenSharp429 [email protected]
* @LastEditTime: 2023-06-28 18:52:19
* @FilePath: \pi-website\src\main.js
* @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
*/
import Vue from 'vue'
import App from './App.vue'
import VueRouter from 'vue-router'
import ImageModule from './components/ImageModule.vue'
import FileModule from './components/FileModule.vue'
import ChatModule from './components/ChatingModule.vue'
import DrawingModule from './components/DrawingModule.vue'
Vue.config.productionTip = false
Vue.use(VueRouter)
const routes = [
{ path: '/image', component: ImageModule },
{ path: '/file', component: FileModule },
{ path: '/chat', component: ChatModule },
{ path: '/drawing', component: DrawingModule }
]
const router = new VueRouter({
routes
})
new Vue({
router,
render: h => h(App)
}).$mount('#app')
README FIRST
PHOTO LIST里面是一些图片,可以点击download进行下载。也可以右击选择在新标签页中打开链接来查看图片。现在一共有六个样例图片,后期可进行添加或者删除。
PHOTO LIST
{{ image.name }}
{{ image.size }}
Download
README FIRST
PHOTO LIST里面是一些文件,可以点击download进行下载。也可以右击选择在新标签页中打开链接来查看文件。现在一共有六个样例文件,后期可进行添加或者删除。
File LIST
{{ file.name }}
{{ file.size }}
Download
README FIRST
由于树莓派的硬件设施问题,暂不支持聊天模块,后期会可能会进行添加,下面是一个部署好了本地chatgpt的网站,详情请下载下面这个压缩包。
简易教程
1.安装node和npm
2.安装pnmp: npm install pnpm -g
3.在终端打开chatgpt-web,输入命令pnpm bootstrap
4.添加一个新的终端CD进入services文件夹,输入pnpm install
5.在OPENAI_API_KEY后面填写密钥 若没有可以使用我的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
6.启动魔法,尽量使用chatgpt支持的地区
7.在SOCKS_PROXY_HOST填写服务器的ip地址,可以使用本地主机
8.在SOCKS_PROXY_PORT填写魔法的端口号
9.配置完后在services的终端输入pnpm start
启动后端
10.运行起来后若不确定是否启动成功可以访问ip:3002,若显示Cannot GET则说明成功
11.不要关闭后端的命令行,重新打开前端目录chatgpt-web,输入命令pnpm dev
即可运行
Source code
{{ file.name }}
{{ file.size }}
Download
README FIRST
由于树莓派的硬件设施问题,暂不支持绘画模块,后期会可能会进行添加,本地draw的网站正在紧张的研发中,敬请期待。
https://hiddensharppi.ap.ngrok.io/#/drawing
【树莓派】教你用树莓派搭建简易的私人服务器!_哔哩哔哩_bilibili
如何使用树莓派搞个web服务器_哔哩哔哩_bilibili
【类型(教程、树莓派)】树莓派搭建Web服务器教程_哔哩哔哩_bilibili
liunx下,修改apache2服务器默认的80端口。_linux重定向apache2的80端口_import bugs的博客-CSDN博客
Ngrok配置外网域名-解决开发中所需的特定端口_ngrok指定端口端口_七夜琉璃的博客-CSDN博客
How to set up a custom domain | ngrok documentation
五分钟实现树莓派frp内网穿透,公网访问树莓派_哔哩哔哩_bilibili
5分钟学会树莓派内网穿透!树莓派FRP简单快速配置教程,不废话,就是干_哔哩哔哩_bilibili
【类型(教程、树莓派)】树莓派搭建Web服务器教程_哔哩哔哩_bilibili
shell - 用树莓派构建一台服务器,永久运行网站 - 个人文章 - SegmentFault 思否
用树莓派做一个服务器是否可行? - 知乎 (zhihu.com)
ChatGPT实战搭建Express与Vue3网页版chatgpt-web源码(上)_哔哩哔哩_bilibili