教程-使用FirefoxSend搭建一個臨時文件分享系統

原文鏈接(我的博客): https://520526.xyz/1224/
說明:Firefox SendFirefox推出的一個全新的臨時文件分享系統,不過貌似代碼開源了,也有幾個小夥伴搭建的時候遇到了點問題,要博主發個教程,這裏就水一下手動搭建和Docker搭建。

截圖

在這裏插入圖片描述
在這裏插入圖片描述
在這裏插入圖片描述

手動安裝

**Github地址:**https://github.com/mozilla/send 備用:https://github.com/a8866051/send 所需環境:Node.js 10+Redis,如果你服務器,特別是CentOS,內存512M或以下的話,建議加點虛擬內存,不然後面可能會安裝失敗。

1、安裝Nodejs

#Debian/Ubuntu系統
curl -sL https://deb.nodesource.com/setup_10.x | bash -
apt install -y nodejs git

PHP

複製

#CentOS系統
curl -sL https://rpm.nodesource.com/setup_10.x | bash -
yum install nodejs -y
yum -y groupinstall "Development Tools"

PHP

複製

2、安裝Redis CenOS 6系統:

#安裝EPEL
rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-6.noarch.rpm

PHP

複製

#安裝Redis
yum install redis git -y

PHP

複製

#啓動Redis
service redis start

PHP

複製

#設置開機自啓
chkconfig redis on

PHP

複製

CenOS 7系統:

#安裝EPEL
rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm

PHP

複製

#安裝Redis
yum install redis -y

PHP

複製

#啓動Redis
systemctl start redis

PHP

複製

#設置開機自啓
systemctl enable redis

PHP

複製

Debian/Ubuntu系統:

apt install redis-server -y

PHP

複製

3、安裝Firefox Send

git clone https://github.com/mozilla/send.git
cd send

PHP

複製

#安裝依賴
npm install

PHP

複製

#構建生產環境
npm run build

PHP

複製

#運行
npm run prod

PHP

複製

基本上官方安裝方法是這樣,不過貌似使用root用戶構建生產環境的時候會有點小問題,普通用戶倒是沒問題的。

一般我們玩的服務器都是直接給的root用戶,所以這裏就需要新建一個普通用戶進行構建操作。

先使用root登錄SSH客戶端,使用命令:

#新建一個j8mao用戶,指定該用戶的主目錄爲/home/j8mao

#Debian/Ubuntu系統
useradd -d /home/j8mao -m j8mao

PHP

複製

#CentOS系統,以下命令會自動給你創建一個/home/j8mao主目錄
useradd j8mao

PHP

複製

然後繼續使用命令:

#進入到/home/j8mao目錄下載send項目
cd /home/j8mao
git clone https://github.com/mozilla/send.git

PHP

複製

#將send目錄用戶權限改爲新建用戶j8mao
chown -R j8mao:j8mao send

PHP

複製

#切換j8mao用戶
su - j8mao

PHP

複製

#進入項目文件夾
cd send

PHP

複製

#安裝依賴
npm install

PHP

複製

#構建生產環境
npm run build

PHP

複製

#運行
npm run prod

PHP

複製

不出意外的話,構建和運行都沒問題,不過運行的話root用戶和新建的j8mao用戶都是可以運行的。

訪問地址爲ip:1443,然後一般情況下CentOS還需要開啓防火牆1443端口,使用命令:

#CentOS 6
iptables -I INPUT -p tcp --dport 1443 -j ACCEPT
service iptables save
service iptables restart

PHP

複製

#CentOS 7
firewall-cmd --zone=public --add-port=1443/tcp --permanent
firewall-cmd --reload

PHP

複製

想要訪問就需要使用域名反代,方法看後面。

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

PHP

複製

#CentOS 7、Debian、Ubuntu
curl -sSL https://get.docker.com/ | sh
systemctl start docker
systemctl enable docker

PHP

複製

2、拉取鏡像 這裏就直接使用博主製作的鏡像,使用命令:

docker run --name send -d -p 1443:1443 j8mao/send

PHP

複製

然後使用ip:1443訪問即可,如果你想用其它端口,就更改前面的1443參數,比如8888:1443

域名反代

方法一 寶塔5.9綁定域名 先確保域名已經解析到你的服務器ip 打開寶塔-網站-添加站點 設置反代:寶塔-網站-點擊域名-反向代理,設置值http://127.0.0.1:1443然後勾選啓用反向代理 添加nginx配置:寶塔-網站-點擊域名-配置文件。找到以下內容,添加以下三行。

location / 
    {
        ...

        proxy_buffering off;
        proxy_cache off;
        proxy_set_header X-Forwarded-Proto $scheme;

        ...
    }

如圖

在這裏插入圖片描述
在這裏插入圖片描述

寶塔6.x以上反向代理略有不同

1.添加反向代理:網站-點擊域名-反向代理-添加反向代理

2.修改反向代理配置:添加完反向代理之後,點擊配置文件,添加內容:

location / 
       {
           ...

           proxy_buffering off;
           proxy_cache off;
           proxy_set_header X-Forwarded-Proto $scheme;

           ...
       }

如圖
在這裏插入圖片描述
在這裏插入圖片描述
在這裏插入圖片描述

做完以上操作,應該就可以訪問你的域名了!

方法二 安裝Caddy

wget -N --no-check-certificate https://raw.githubusercontent.com/ToyoDAdoubiBackup/doubi/master/caddy_install.sh && chmod +x caddy_install.sh && bash caddy_install.sh

PHP

複製

配置Caddy:

#以下全部內容是一個整體,請修改域名後一起復制到SSH運行!

#http訪問,該配置不會自動簽發SSL
echo "www.j8mao.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-Proto {scheme}
  }
}" > /usr/local/caddy/Caddyfile

#https訪問,該配置會自動簽發SSL,請提前解析域名到VPS服務器
echo "www.j8mao.com {
 gzip
 tls admin@j8mao.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-Proto {scheme}
  }
}" > /usr/local/caddy/Caddyfile

PHP

複製

tls參數會自動幫你簽發ssl證書,如果你要使用自己的ssl,改爲tls /root/xx.crt /root/xx.key即可。後面爲ssl證書路徑。

啓動Caddy:

/etc/init.d/caddy start

PHP

複製

就可以打開域名進行訪問了。

最後使用啥的就不研究了,有問題可以看下Github文檔→傳送門

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章