说明:Firefox Send
好像一两年前博主就分享过,是Firefox
推出的一個全新的临时文件分享系统,具体查看→传送门,不过貌似代码开源了,也有几个小伙伴搭建的时候遇到了点问题,要博主发个教程,这里就水一下手动搭建和Docker
搭建。
截图
手动安装
Github地址:https://github.com/mozilla/send
所需环境:Node.js 10+
、Redis
,如果你服务器,特别是CentOS
,内存512M
或以下的话,建议加点虚拟内存,不然后面可能会安装失败,也可以用下Swap
一键脚本→传送门。
1、安装Nodejs
#Debian/Ubuntu系统
curl -sL https://deb.nodesource.com/setup_10.x | bash -
apt install -y nodejs git
#CentOS系统
curl -sL https://rpm.nodesource.com/setup_10.x | bash -
yum install nodejs -y
yum -y groupinstall "Development Tools"
2、安装RedisCenOS 6
系统:
#安装EPEL
rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-6.noarch.rpm
#安装Redis
yum install redis git -y
#启动Redis
service redis start
#设置开机自启
chkconfig redis on
CenOS 7
系统:
#安装EPEL
rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
#安装Redis
yum install redis -y
#启动Redis
systemctl start redis
#设置开机自启
systemctl enable redis
Debian
/Ubuntu
系统:
apt install redis-server -y
3、安装Firefox Send
git clone https://github.com/mozilla/send.git
cd send
#安装依赖
npm install
#构建生产环境
npm run build
#运行
npm run prod
基本上官方安装方法是这样,不过貌似使用root
用户构建生产环境的时候会有点小问题,普通用户倒是没问题的。
一般我们玩的服务器都是直接给的root
用户,所以这里就需要新建一个普通用户进行构建操作。
先使用root
登录SSH
客户端,使用命令:
#新建一个moerats用户,指定该用户的主目录为/home/moerats
#Debian/Ubuntu系统
useradd -d /home/moerats -m moerats
#CentOS系统,以下命令会自动给你创建一个/home/moerats主目录
useradd moerats
然后继续使用命令:
#进入到/home/moerats目录下载send项目
cd /home/moerats
git clone https://github.com/mozilla/send.git
#将send目录用户权限改为新建用户moerats
chown -R moerats:moerats send
#切换moerats用户
su - moerats
#进入项目文件夹
cd send
#安装依赖
npm install
#构建生产环境
npm run build
#运行
npm run prod
不出意外的话,构建和运行都没问题,不过运行的话root
用户和新建的moerats
用户都是可以运行的。
访问地址为ip:1443
,然后一般情况下CentOS
还需要开启防火墙1443
端口,使用命令:
#CentOS 6
iptables -I INPUT -p tcp --dport 1443 -j ACCEPT
service iptables save
service iptables restart
#CentOS 7
firewall-cmd --zone=public --add-port=1443/tcp --permanent
firewall-cmd --reload
想要访问就需要使用域名反代,方法看后面。
Docker安装
1、安装Docker
#CentOS 6
rpm -iUvh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
yum update -y
yum -y install docker-io
service docker start
chkconfig docker on
#CentOS 7、Debian、Ubuntu
curl -sSL https://get.docker.com/ | sh
systemctl start docker
systemctl enable docker
2、拉取镜像
这里就直接使用博主制作的镜像,使用命令:
docker run --name send -d -p 1443:1443 moerats/send
然后使用ip:1443
访问即可,如果你想用其它端口,就更改前面的1443
参数,比如8888:1443
。
域名反代
安装Caddy
:
wget -N --no-check-certificate https://raw.githubusercontent.com/iiiiiii1/doubi/master/caddy_install.sh && chmod +x caddy_install.sh && bash caddy_install.sh
#备用地址
wget -N --no-check-certificate https://www.moerats.com/usr/shell/Caddy/caddy_install.sh && chmod +x caddy_install.sh && bash caddy_install.sh
配置Caddy
:
#以下全部内容是一个整体,请修改域名后一起复制到SSH运行!
#http访问,该配置不会自动签发SSL
echo "www.moerats.com {
gzip
proxy / 127.0.0.1:1443 {
websocket
header_upstream Host {host}
header_upstream X-Real-IP {remote}
header_upstream X-Forwarded-For {remote}
header_upstream X-Forwarded-Port {server_port}
header_upstream X-Forwarded-Proto {scheme}
}
}" > /usr/local/caddy/Caddyfile
#https访问,该配置会自动签发SSL,请提前解析域名到VPS服务器
echo "www.moerats.com {
gzip
tls admin@moerats.com
proxy / 127.0.0.1:1443 {
websocket
header_upstream Host {host}
header_upstream X-Real-IP {remote}
header_upstream X-Forwarded-For {remote}
header_upstream X-Forwarded-Port {server_port}
header_upstream X-Forwarded-Proto {scheme}
}
}" > /usr/local/caddy/Caddyfile
tls
参数会自动帮你签发ssl
证书,如果你要使用自己的ssl
,改为tls /root/xx.crt /root/xx.key
即可。后面为ssl
证书路径。
启动Caddy
:
/etc/init.d/caddy start
就可以打开域名进行访问了。
最后使用啥的就不研究了,有问题可以看下Github
文档→传送门。
宝塔反代上传不了文件
F12看下控制台,看是不是红色报错是ws开头的,如果是,那就百度nginx/apache转发websocket
Firefox Send自建服务器,请问上传的文件是放到自己的服务器还是火狐的服务器?如果自建的服务器不能访问互联网,是否还能使用?
还想问一下博主这个允许上传的文件的大小能不能手动的改一下,我看默认是1G,想改大一点,奈何太菜,不知道怎么改源码
自己修改配置文件即可
好像被官方限制了,貌似登录用户才可以上传最大2.5G的文件,具体你试试
稳啊,虽然手动安装没有成功,但是docker可以
弄好之后发现会提示我此链接已过期
我刚加了websocket,测试了一下,没这个问题。看你设置的过期时间对不对
过期时间并没问题。。
你用的手动搭建还是docker?我刚试了下手动,是没问题,顺便把你的网址给我下
稍等,我把我之前做的send docker镜像推送下,我做的那个是没问题的
搞定了。。然后CADDY价格验证美滋滋,3Q
还有一个问题是用IP:1443打开,就能成功上传,用域名打开,就一直卡在0%,不知道为啥
这个问题等我有空看看吧。
老哥,不知道为什么上传完的链接,分享出去是无效的,不能使用
你是用的docker吧?我把自己的docker镜像推送了,没你说的这个问题了,域名卡住的问题也解决了,直接看教程吧。
有宝塔面板的咋安装?
redis可以在宝塔面板装,其它照着做
真会玩,是不是每天都重装系统?
被你发现了。
谢谢博主
使用点上传文件停在0%不动了~~
caddy的配置里面加一句websocket就好了
还真是,看了下控制台,是没转发ws,我加上去
反代之后上传会卡住0%..
看是不是网络问题,我之前也出现过一次,刷新一次就好了
好像是有一个WSS协议的没被反代到