说明:Fiora
是一款偏二次元的Web
多人在线聊天应用,使用Node.js
、Mongodb
、Socket.io
和React
编写,使用起来还行,挺简洁的,这里水个搭建教程,有兴趣的可以玩玩。
截图
功能
- 好友,群组,私聊,群聊
- 文本,图片,代码,
url
等多种类型消息 - 贴吧表情,滑稽表情,搜索表情包
- 桌面通知,声音提醒,语音播报
- 自定义桌面背景,主题颜色,文本颜色
- 查看在线用户,
@
功能 - 小黑屋禁言
手动安装
Github地址:https://github.com/yinxin630/fiora
所需环境:Nodejs >= 8.9.0
、Mongodb
。
说明:512M
内存vps
可能还需要先加一点虚拟内存,不然构建过程会失败,可以使用Swap
一键脚本→传送门。
1、安装Nodejs
#Debian/Ubuntu系统
curl -sL https://deb.nodesource.com/setup_10.x | bash -
apt install -y git nodejs
#CentOS系统
curl -sL https://rpm.nodesource.com/setup_10.x | bash -
yum install nodejs git -y
2、安装Mongodb
#CentOS 6系统,将下面命令一起复制进SSH客户端运行
cat <<EOF > /etc/yum.repos.d/mongodb.repo
[mongodb-org-4.0]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/6/mongodb-org/4.0/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-4.0.asc
EOF
yum -y install mongodb-org
#CentOS 7系统,将下面命令一起复制进SSH客户端运行
cat <<EOF > /etc/yum.repos.d/mongodb.repo
[mongodb-org-4.0]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/7/mongodb-org/4.0/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-4.0.asc
EOF
yum -y install mongodb-org
#Debian 8系统
apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 9DA31620334BD75D9DCB49F368818C72E52529D4
echo "deb http://repo.mongodb.org/apt/debian jessie/mongodb-org/4.0 main" | tee /etc/apt/sources.list.d/mongodb-org-4.0.list
apt update -y
apt install -y mongodb-org
#Debian 9系统
curl https://www.mongodb.org/static/pgp/server-4.0.asc | apt-key add -
echo "deb http://repo.mongodb.org/apt/debian stretch/mongodb-org/4.0 main" | tee /etc/apt/sources.list.d/mongodb-org-4.0.list
apt-get update -y
apt-get install -y mongodb-org
#Debian 10系统
curl https://www.mongodb.org/static/pgp/server-4.2.asc | apt-key add -
echo "deb http://repo.mongodb.org/apt/debian buster/mongodb-org/4.2 main" | tee /etc/apt/sources.list.d/mongodb-org-4.2.list
apt update -y
apt install -y mongodb-org
#Ubuntu 16.04系统
apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 9DA31620334BD75D9DCB49F368818C72E52529D4
echo "deb https://repo.mongodb.org/apt/ubuntu xenial/mongodb-org/4.0 multiverse" | tee /etc/apt/sources.list.d/mongodb-org-4.0.list
apt update -y
apt install -y mongodb-org
#Ubuntu 18.04、18.10、19.04系统
apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 9DA31620334BD75D9DCB49F368818C72E52529D4
echo "deb https://repo.mongodb.org/apt/ubuntu bionic/mongodb-org/4.0 multiverse" | tee /etc/apt/sources.list.d/mongodb-org-4.0.list
apt update -y
apt install -y mongodb-org
如果导入公匙时出现gnupg, gnupg2 and gnupg1 do not seem to be installed
错误,使用apt install -y gnupg2
,然后重新导入即可。
启动Mongodb
并设置开机自启:
#CentOS 6系统
service mongod start
chkconfig mongod on
#CentOS 7、Debian、Ubuntu系统
systemctl start mongod
systemctl enable mongod
3、安装fiora
#拉取源码并存放于/opt文件夹
git clone https://github.com/yinxin630/fiora.git -b master /opt/fiora
cd /opt/fiora
#安装依赖,这里不能用npm,需要用yarn来安装
npm i -g yarn
yarn
#构建
npm run build
#转移产物
npm run move-dist
#启动
npm start
运行后打开ip:9200
,注册一个账号,然后可以看SSH
客户端运行日志,获取自己的userId
。
#这里注册或登录的时候返回的信息,后面的5d329dd354b9则为自己的userId
<-- getLinkmansLastMessages mYNheu93jds7 5d329dd354b9
如果ip:9200
打不开的,可以检查下防火墙,CentOS
系统可以使用以下命令:
#CentOS 6
iptables -I INPUT -p tcp --dport 9200 -j ACCEPT
service iptables save
service iptables restart
#CentOS 7
firewall-cmd --zone=public --add-port=9200/tcp --permanent
firewall-cmd --reload
像阿里云等,还需要额外在安全组开放端口。
接下来再将自己的账号设置成管理员,先使用Ctrl+C
断开运行。
新建Systemd
配置文件,只适用于CentOS 7
、Debian 8+
、Ubuntu 16+
等。
#先修改你的userId和运行端口后复制到SSH运行
Administrator=5d329dd354b9
Port=9200
#新建fiora用户并授权
useradd -M fiora && usermod -L fiora
chown -R fiora:fiora /opt/fiora
#新建systemd配置文件,将以下代码一起复制到SSH运行
cat > /etc/systemd/system/fiora.service <<EOF
[Unit]
Description=fiora
After=network.target
Wants=network.target
[Service]
Type=simple
PIDFile=/var/run/fiora.pid
ExecStart=$(command -v npm) start
WorkingDirectory=/opt/fiora
Environment=Administrator=$Administrator Port=$Port
User=fiora
Restart=on-failure
RestartSec=42s
[Install]
WantedBy=multi-user.target
EOF
开始启动并设置开机自启:
systemctl start fiora
systemctl enable fiora
其它系统,比如CentOS
、Debian 7
等系统,可以直接使用以下方法启动:
#管理员userId和运行端口自行修改
export Administrator=5d329dd354b9 Port=9200
nohup npm start &
此时就可以访问ip:9200
,运行端口以你设置的为准,这时候你登陆的时候,会发现左侧多了个管理员图标。
4、域名反代
如果你想使用域名的话,这里依旧使用Caddy
反代,操作如下:
安装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:9200 {
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:9200 {
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
就可以打开域名进行访问了。
如果你想修改默认的频道名称的话,可以编辑config/server.js
文件,修改最下面的代码:
defaultGroupName: 'fiora',
然后重启应用即可。需要使用到七牛云CDN
的,可以参考作者给的教程自行设置→传送门
宝塔安装
1、安装宝塔
#CentOS系统
wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh
#Ubuntu系统
wget -O install.sh http://download.bt.cn/install/install-ubuntu_6.0.sh && sudo bash install.sh
#Debian系统
wget -O install.sh http://download.bt.cn/install/install-ubuntu_6.0.sh && bash install.sh
安装完成后,进入面板,点击左侧软件商店,然后安装PM2管理器
、MongoDB
、Nginx
(使用域名访问才需要安装,反之不用)。
注意:Debian
安装MongoDb
之前还需要使用命令apt install sudo
,不然可能存在MongoDb
启动不了的情况;如果你已经安装了MongoDb
,那就先使用apt install sudo
,再使用/etc/init.d/mongodb start
启动即可。
2、安装fiora
该步骤参考上面的手动步骤3
,区别在于新建systemd
配置文件的时候,Environment
参数还需要加一样,不然启动可能失败。
只需要把新建systemd
配置文件步骤换成下面这个,其它一模一样。
#先给node做个软连接,不然后面会启动失败
ln -sf $(which node) /usr/bin/node
#修改运行端口,可以默认
Port=9200
#以下命令一起复制进SSH客户端运行
cat > /etc/systemd/system/fiora.service <<EOF
[Unit]
Description=fiora
After=network.target
Wants=network.target
[Service]
Type=simple
PIDFile=/var/run/fiora.pid
ExecStart=$(command -v npm) start
WorkingDirectory=/opt/fiora
Environment=NODE_ENV=production Administrator=$Administrator Port=$Port
User=fiora
Restart=on-failure
RestartSec=42s
[Install]
WantedBy=multi-user.target
EOF
3、域名反代
先点击左侧网站,添加站点,然后再点击添加好了的域名名称,这时候就进入了站点配置,点击配置文件,在中间添加以下代码:
location / {
proxy_pass http://127.0.0.1:9200;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header X-Forward-Proto http;
proxy_set_header X-Nginx-Proxy true;
proxy_http_version 1.1;
proxy_redirect off;
}
其它的就自己慢慢摸索吧,博主也没过多使用,有问题可以直接去Github Issues
反馈。
请问这些安装环境是在vps ssh软件中实现的吗?(比如Xshell finalshell putty等)
是的,基本上都是这些登录linux系统的vps
大佬,npm run build 出现报错怎么解决,依赖也装好了的
[root@iZuitvyn0zqw8aZ fiora]# npm run build npm ERR! code ENOENT npm ERR! syscall open npm ERR! path /opt/fiora/package.json npm ERR! errno -2 npm ERR! enoent ENOENT: no such file or directory, open '/opt/fiora/package.json' npm ERR! enoent This is related to npm not being able to find a file. npm ERR! enoent npm ERR! A complete log of this run can be found in: npm ERR! /root/.npm/_logs/2020-05-14T08_08_43_357Z-debug.log这个问题已解决,可是重启服务器之后又要重新注册,怎么查看管理员ID呢
这个应该要看mongodb数据库表,你百度下mongodb用法看看
nginx反代的时候
location / {
会出现css,js和图片404的情况emm
后来加了个~就恢复了。
location ~/ {
不知道是我的问题还是emmm
老大,这个系统怎么卸载呢?
卸载直接停止,然后删掉源码文件夹就行了
pm2怎么启动呢
pm2好像文档有说明,https://github.com/yinxin630/fiora/blob/master/doc/INSTALL.ZH.md
npm run build时报错
TSError: ⨯ Unable to compile TypeScript:
build/build.ts:4:17 - error TS7016: Could not find a declaration file for module 'ora'. '/opt/fiora/node_modules/ora/index.js' implicitly has an 'any' type.
Try npm install @types/ora if it exists or add a new declaration (.d.ts) file containing declare module 'ora';
4 import ora from 'ora';
build/build.ts:5:16 - error TS7016: Could not find a declaration file for module 'rimraf'. '/opt/fiora/node_modules/rimraf/rimraf.js' implicitly has an 'any' type. Try `npm install @types/rimraf` if it exists or add a new declaration (.d.ts) file containing `declare module 'rimraf';` 5 import rm from 'rimraf';build/build.ts:8:21 - error TS7016: Could not find a declaration file for module 'webpack'. '/opt/fiora/node_modules/webpack/lib/webpack.js' implicitly has an 'any' type.
Try npm install @types/webpack if it exists or add a new declaration (.d.ts) file containing declare module 'webpack';
8 import webpack from 'webpack';
at createTSError (/opt/fiora/node_modules/ts-node/src/index.ts:421:12) at reportTSError (/opt/fiora/node_modules/ts-node/src/index.ts:425:19) at getOutput (/opt/fiora/node_modules/ts-node/src/index.ts:530:36) at Object.compile (/opt/fiora/node_modules/ts-node/src/index.ts:735:32) at Module.m._compile (/opt/fiora/node_modules/ts-node/src/index.ts:814:43) at Module._extensions..js (internal/modules/cjs/loader.js:1178:10) at Object.require.extensions.<computed> [as .ts] (/opt/fiora/node_modules/ts-node/src/index.ts:817:12) at Module.load (internal/modules/cjs/loader.js:1002:32) at Function.Module._load (internal/modules/cjs/loader.js:901:14) at Function.executeUserEntryPoint [as runMain] (internal/modules/run_main.js:74:12)这个有点像是依赖没安装完整
已经反馈作者修复好了
一步一步来的,换了好几台服务器也是一样的错误(都是centos 7的),实在不知道为什么了
npm启动不了err是什么情况
直接root目录运行?是的话,去源码目录运行启动命令就行了
为什么我进行反代以后,域名上面还是必须加上端口,否则无法访问。。
估计反代有点小问题还是?
唔,要是配置文件误删导致错误怎么办qwq,重新构建咩?
哪个配置文件?
在320m小鸡上搞的。。。构建略花时间。。qwq
js,,,重新构建了qwq
谢谢大佬了qwq
搞定