MCSManager/README.md

254 lines
11 KiB
Markdown
Raw Normal View History

2018-05-30 15:54:56 +08:00
![doc_logo.png](/public/common/doc_logo.png)
2018-05-30 13:34:21 +08:00
[![Status](https://img.shields.io/badge/npm-v6.9.0-blue.svg)](https://www.npmjs.com/)
2020-03-11 16:39:02 +08:00
[![Status](https://img.shields.io/badge/node-v10.16.0-blue.svg)](https://nodejs.org/en/download/)
2018-05-30 14:22:22 +08:00
[![Status](https://travis-ci.org/Suwings/MCSManager.svg?branch=master)](https://travis-ci.org/Suwings/MCSManager)
2020-02-23 19:29:21 +08:00
[![Status](https://img.shields.io/badge/License-MIT-red.svg)](https://github.com/Suwings/MCSManager)
2018-05-30 15:54:56 +08:00
2020-07-21 10:04:00 +08:00
简单,易用,多实例,轻量级的 Minecraft Server 控制面板
2018-05-30 15:54:56 +08:00
2018-12-02 11:11:30 +08:00
2020-03-01 17:19:08 +08:00
2021-06-23 10:33:19 +08:00
[官方网站](http://mcsm.suwings.top/) | [中文简体](https://github.com/Suwings/MCSManager) | [中文繁體](README-traditional.md) | [API 文档](https://github.com/Suwings/MCSManager/wiki/API-Documentation) | [二次开发参考文档](https://github.com/Suwings/MCSManager/wiki/Development_Document)
2018-06-05 16:39:08 +08:00
2020-01-07 15:46:20 +08:00
<br />
2018-12-02 11:11:30 +08:00
2020-07-21 10:04:00 +08:00
**本项目 [赞助者名单](https://docs.qq.com/sheet/DYWJNVXhib0dtamh2?c=B3A0A0)**
2018-04-12 10:08:04 +08:00
<br />
2021-05-07 20:14:03 +08:00
2020-07-21 10:04:00 +08:00
简介
2017-12-11 17:24:52 +08:00
-----------
2020-07-21 10:04:00 +08:00
这是一款可以管理多个 Minecraft 服务端(支持群组端)的 Web 管理面板,并且可以分配多个子账号来分别管理不同的 Minecraft 服务端,支持绝大部分主流的服务端,甚至是其他非 Minecraft 的程序。
2017-11-12 09:54:53 +08:00
2020-07-21 10:04:00 +08:00
控制面板可运行在 Windows 与 Linux 平台,无需数据库与任何系统配置,只需安装 node 环境即可快速运行,属于轻量级的 Minecraft 服务端控制面板。
2017-11-30 22:55:08 +08:00
2020-03-01 17:19:08 +08:00
![main_theme.png](/public/common/main_theme.png)
2018-04-12 10:08:04 +08:00
<br />
2017-11-12 09:53:27 +08:00
2020-07-21 10:04:00 +08:00
运行环境
2017-12-11 17:24:52 +08:00
-----------
2020-07-21 10:04:00 +08:00
推荐 `Node 10.16.0` 以上,无需数据库和更改任何系统配置,开箱即可运行。
2019-10-25 21:30:06 +08:00
<br />
配置文件
-----------
2020-07-21 10:04:00 +08:00
配置文件是程序目录下的 `property.js` 文件,它会在你第一次运行的时候,自动生成。
2019-10-25 21:30:06 +08:00
2020-07-21 10:04:00 +08:00
> 此文件不会与 github 版本冲突git pull 更新时也不会自动覆盖。
2019-10-25 21:30:06 +08:00
2018-04-12 10:08:04 +08:00
<br />
2017-11-18 15:53:36 +08:00
2019-10-25 21:30:06 +08:00
2020-07-21 10:04:00 +08:00
常见问题
2020-03-12 13:38:29 +08:00
-----------
2020-07-21 10:04:00 +08:00
| 问题 | 详情 |
2020-03-12 13:38:29 +08:00
| ------------------------ | --------------------------------------------------------------------------------------------- |
2020-07-21 10:04:00 +08:00
无法正常安装面板?| [参考教程](https://github.com/Suwings/MCSManager/wiki/Linux-%E4%B8%8B%E5%AE%89%E8%A3%85%E4%B8%8E%E4%BD%BF%E7%94%A8%E8%AF%A6%E8%A7%A3)
Linux 下面板如何后台运行? | [参考方法](https://github.com/Suwings/MCSManager/wiki/Linux-%E4%B8%8B%E5%AE%89%E8%A3%85%E4%B8%8E%E4%BD%BF%E7%94%A8%E8%AF%A6%E8%A7%A3#%E4%BF%9D%E6%8C%81%E5%90%8E%E5%8F%B0%E8%BF%90%E8%A1%8C)
使用面板开启 `Bedrock Server` 端 | [参考教程](https://github.com/Suwings/MCSManager/wiki/%E4%BD%BF%E7%94%A8%E9%9D%A2%E6%9D%BF%E5%BC%80%E5%90%AF-Bedrock_server-%E6%9C%8D%E5%8A%A1%E7%AB%AF)
面板管理员的默认账号和密码是什么? | 账号 `#master` 密码 `123456`
面板如何正确关闭? | `Ctrl+C`
配置文件是什么? | `property.js` 文件
如何修改面板默认端口? | `property.js` 文件
如何配置反向代理? | [Apache 配置参考教程](https://github.com/Suwings/MCSManager/wiki/%E4%BD%BF%E7%94%A8-Apache2.4-%E8%BF%9B%E8%A1%8C%E5%8F%8D%E5%90%91%E4%BB%A3%E7%90%86)
配好反向代理却无法使用? | [Apache](https://github.com/Suwings/MCSManager/issues/34) [Nginx](https://github.com/Suwings/MCSManager/issues/22) [宝塔上的Nginx](https://github.com/Suwings/MCSManager/wiki/%E5%85%B3%E4%BA%8E%E5%AE%9D%E5%A1%94%E9%9D%A2%E6%9D%BF%E7%9A%84-Nginx-%E5%8F%8D%E5%90%91%E4%BB%A3%E7%90%86%E4%BB%A5%E5%8F%8ASSL%E8%AF%81%E4%B9%A6%E9%83%A8%E7%BD%B2)
反代后文件管理偶尔失效? | 请检查反代机器的防火墙是否拦截
我能修改登录页面吗?| [修改教程](https://github.com/Suwings/MCSManager/wiki/%E8%87%AA%E5%AE%9A%E4%B9%89%E4%BF%AE%E6%94%B9%E7%99%BB%E5%BD%95%E9%A1%B5%E9%9D%A2)
其他常见问题 | [查看 Wiki](https://github.com/Suwings/MCSManager/wiki)
关于HTTP跳转HTTPS的帮助 | [查看 Nginx 301永久重定向 范例](https://github.com/Suwings/MCSManager/wiki/Nginx%E5%85%A8%E5%B1%80301%E6%B0%B8%E4%B9%85%E9%87%8D%E5%AE%9A%E5%90%91)
2020-03-12 13:38:29 +08:00
<br />
2020-10-09 13:12:03 +08:00
在 Windows 运行
2017-12-11 17:24:52 +08:00
-----------
2020-10-09 13:12:03 +08:00
对于 Windows 系统,**已整合成直接运行版本,下载即可运行**(建议使用管理员权限运行):
2017-12-11 17:19:01 +08:00
2020-07-21 10:04:00 +08:00
http://mcsm.suwings.top/ (官方站点)
2017-12-11 17:19:01 +08:00
2020-10-09 13:12:03 +08:00
- 前往官方网站下载 Windows 版本即可,双击 `运行.bat``Start.bat` 文件即可。
2018-01-20 15:24:11 +08:00
2018-04-12 10:08:04 +08:00
<br />
2017-12-11 17:19:01 +08:00
2018-04-22 09:47:58 +08:00
2020-10-09 13:12:03 +08:00
在 Linux 运行
2017-12-11 17:24:52 +08:00
-----------
2020-10-09 13:12:03 +08:00
**一行命令快速安装适用于AMD64架构 Ubuntu/Centos/Debian/Archlinux**
2019-01-15 14:33:47 +08:00
2017-11-18 15:53:36 +08:00
```bash
2020-10-09 13:12:03 +08:00
wget -qO- https://gitee.com/Suwingser/MCSManager-installer/raw/master/install.sh | bash
```
- 执行完成后,使用 `systemctl start mcsm` 即可启动面板服务。
2020-10-11 12:57:14 +08:00
- 面板代码与运行环境自动安装在 `/opt/` 目录下。
2020-10-09 13:12:03 +08:00
<br />
**其他 Linux 发行版安装**
2020-10-11 12:57:14 +08:00
- 若一键安装不起作用,则可以尝试此步骤手动安装。
2020-10-09 13:12:03 +08:00
```bash
# 切换到安装目录,没有此目录请执行 mkdir /opt/
cd /opt/
# 下载运行环境
wget https://npm.taobao.org/mirrors/node/v12.16.1/node-v12.16.1-linux-x64.tar.gz
# 解压文件
tar -zxvf node-v12.16.1-linux-x64.tar.gz
# 链接程序到环境变量中
ln -s /opt/node-v12.16.1-linux-x64/bin/node /usr/bin/node
ln -s /opt/node-v12.16.1-linux-x64/bin/npm /usr/bin/npm
# 克隆仓库(若没有 git请安装它如 apt install -y git)
2019-09-17 16:02:03 +08:00
git clone https://github.com/suwings/mcsmanager.git
2020-07-21 10:04:00 +08:00
# 进入目录
2019-09-17 16:02:03 +08:00
cd mcsmanager/
2020-07-21 10:04:00 +08:00
# 安装依赖库
2019-09-17 16:02:03 +08:00
npm install
2020-07-21 10:04:00 +08:00
# 启动面板
2020-02-16 13:55:58 +08:00
npm start
2020-10-09 13:12:03 +08:00
# 关闭面板使用 Ctrl+C 快捷键即可
2017-11-12 09:53:27 +08:00
```
2018-05-30 16:04:16 +08:00
2020-10-09 13:12:03 +08:00
- 注意这种安装方式不会自动注册面板到系统服务Service所以必须使用 `screen` 软件来管理。
- 或者您可以 [点击这里](https://github.com/Suwings/MCSManager/wiki/%E4%BD%BF%E7%94%A8-systemctl-%E7%AE%A1%E7%90%86%E5%99%A8) 来手动配置面板到系统
> 关于更多的安装说明,请 [单击这里](https://github.com/Suwings/MCSManager/wiki/Linux-%E4%B8%8B%E5%AE%89%E8%A3%85%E4%B8%8E%E4%BD%BF%E7%94%A8%E8%AF%A6%E8%A7%A3)
2019-09-17 16:07:36 +08:00
2018-04-12 10:08:04 +08:00
<br />
2017-11-18 15:53:36 +08:00
2021-05-07 20:14:03 +08:00
2021-05-25 21:49:51 +08:00
特大更新
-----------
项目 star 超过 1k 之后将开始计划更新 9.0 特大更新版本,将支持分布式管理,更优秀的前端和守护进程。
2021-05-27 13:04:02 +08:00
<br />
2021-05-25 21:49:51 +08:00
2021-05-07 20:14:03 +08:00
2020-07-21 10:04:00 +08:00
通过 Docker 启动 MC 服务端
2018-11-15 08:58:19 +08:00
-----------
2020-07-21 10:04:00 +08:00
我们支持面板在 Linux 系统下,配合 Docker 以命令的形式,来创建 Minecraft 服务端所需 Java 环境镜像,并且在容器中启动和关闭你的 Minecraft 服务端。
2018-11-15 08:58:19 +08:00
2020-07-21 10:04:00 +08:00
如果你不会使用,请点击`具体使用方法` 链接,如果你还未安装 Docker 请点击 `安装Docker` 的链接。
2020-07-21 10:04:00 +08:00
**具体使用方法:** [单击跳转](https://github.com/Suwings/MCSManager/blob/gh-pages/Question_1.md)
2020-07-21 10:04:00 +08:00
**安装 Docker:** [单击跳转](https://github.com/Suwings/MCSManager/blob/gh-pages/Question_2.md)
2019-10-25 21:30:06 +08:00
2018-11-15 08:58:19 +08:00
<br />
2020-07-21 10:04:00 +08:00
项目目录结构
2017-12-11 17:24:52 +08:00
-----------
2020-07-21 10:04:00 +08:00
**注意:** 并不是所有目录的文件我们都建议你进行更改!
2017-11-12 09:53:27 +08:00
2020-07-21 10:04:00 +08:00
| 目录名 | 详情/解释 |
2017-12-11 16:37:03 +08:00
| ------------------------ | --------------------------------------------------------------------------------------------- |
2018-06-01 19:20:09 +08:00
| **property.js** |控制面板配置文件|
2020-07-21 10:04:00 +08:00
| **core/logo.txt**               |控制台输出 logo 文字|
| **public/** |前端所有代码,资源目录,前后端分离,使用 ws 和 ajax 通讯|
| **public/login/**               |纯 UI 逻辑登陆页面|
| **public/template/**             |前端业务模板,每个模板拥有着一个生命周期,开始与结束。|
| **public/onlinefs_public/**      |文件在线管理模块前端所有代码|
| **public/common/js/meum.js** |控制面板左侧菜单列表|
| **public/common/js/login.js** |通用登录流程逻辑,可重复利用在各类 HTML 登录模板|
| **server/server_core**           |Minecraft 服务端核心目录包括服务端文件配置Mod以及插件|
| **server/x.json**               |Minecraft 服务器面板配置文件|
| **users/x.json**               |控制面板用户配置文件|
| **route/**                     |控制器HTTP 请求业务逻辑层(可二次扩展)|
| **route/websocket/**            |控制器Webscoket 请求业务逻辑层(可二次扩展)|
| **core/Process/**               |Minecraft Server 类实现|
| **core/User/**                   |User 类实现|
| **core/DataModel.js**            |数据持久化模型,几乎是所有的配置的 I/O 模型|
| **model/**                     |模型层,用于提供控制器与服务端,用户操作,也提供设计模式模型|
| **helper/**                     |业务逻辑辅助层,用于辅助和重复利用业务逻辑|
| **onlinefs/**                    |文件管理独立模块 ([Suwings/IndependentFileManager](https://github.com/Suwings/IndependentFileManager))|
<br />
浏览器兼容性
2018-02-04 16:00:16 +08:00
-----------
2020-07-21 10:04:00 +08:00
- `ECMAScript 5` 标准
2021-03-17 15:26:25 +08:00
- `IE 11+` `Chrome` `Firefox` `Safari` `Opera` 等现代主流浏览器
2018-02-04 16:00:16 +08:00
2020-07-21 10:04:00 +08:00
**例外:** 文件在线管理界面需要 `IE 11+`
2018-04-12 09:54:06 +08:00
2018-04-12 10:08:04 +08:00
<br />
2020-07-21 10:04:00 +08:00
自定义设计
2018-04-12 10:08:04 +08:00
-----------
2020-07-21 10:04:00 +08:00
你可以对前端以及后端进行任何程度的修改,包括版权声明。
2018-04-29 20:42:42 +08:00
2018-04-16 18:59:52 +08:00
<br />
2020-07-21 10:04:00 +08:00
反向代理 与 SSL
2018-04-12 09:54:06 +08:00
-----------
2018-06-01 19:41:26 +08:00
2020-07-21 10:04:00 +08:00
尽管默认没有 Https ,您可能在公共网络下不太放心,但是我们不传递明文的密码,可以保证你的账号的密码是难以泄露的。
2018-06-01 19:41:26 +08:00
2020-07-21 10:04:00 +08:00
具体密码传递过程可参考 [单击这里跳转](https://github.com/Suwings/MCSManager/wiki/%E7%99%BB%E5%BD%95%E5%AF%86%E7%A0%81%E4%BC%A0%E9%80%92%E8%BF%87%E7%A8%8B%E5%9B%BE)
2018-06-01 19:41:26 +08:00
2018-05-30 11:44:20 +08:00
**Property 文件**
2018-05-30 11:36:22 +08:00
2020-07-21 10:04:00 +08:00
反向代理之前,建议你阅读 `property.js` 文件
2018-05-30 11:36:22 +08:00
2020-07-21 10:04:00 +08:00
> 里面有各类的设置,包括 gzip压缩端口和ip绑定等等。
2018-05-30 11:36:22 +08:00
2020-07-21 10:04:00 +08:00
**实现 HTTPS 与 WSS**
2018-05-01 12:04:34 +08:00
2020-07-21 10:04:00 +08:00
打开前端 URL 定位文件 `public/common/URL.js`, 将 http 与 ws 改成 https 与 wss
2018-04-22 09:47:58 +08:00
2020-07-21 10:04:00 +08:00
可保证前端所有请求均为 https 和 wss但是后端方面还需要配置 SSL 与 反向代理。
2018-04-22 09:47:58 +08:00
2018-05-30 11:44:20 +08:00
**反向代理**
2018-04-22 09:47:58 +08:00
2020-07-21 10:04:00 +08:00
后端请通过反向代理完成,或自行修改 Express 初始化 App。
2018-04-22 09:47:58 +08:00
2019-09-29 10:28:25 +08:00
[Apache 反向代理教程](https://github.com/Suwings/MCSManager/wiki/%E4%BD%BF%E7%94%A8-Apache2.4-%E8%BF%9B%E8%A1%8C%E5%8F%8D%E5%90%91%E4%BB%A3%E7%90%86)
2020-07-21 10:04:00 +08:00
[SSL 功能实现示例](https://github.com/Suwings/MCSManager/issues/146)
2020-07-21 10:04:00 +08:00
**注意:** [Nginx 反向代理注意](https://github.com/Suwings/MCSManager/issues/22) | [Apache 反向代理注意](https://github.com/Suwings/MCSManager/issues/34) | [关于 Caddy 反向代理坑](https://github.com/Suwings/MCSManager/issues/122)
2018-04-22 09:47:58 +08:00
<br />
2020-07-21 10:04:00 +08:00
权限系统
2018-04-13 10:06:27 +08:00
-----------
2020-07-21 10:04:00 +08:00
尤其注意的是,为了更加简化面板权限系统,我们只分为两种账号。
2018-04-13 10:06:27 +08:00
2020-07-21 10:04:00 +08:00
`管理账号` 凡是以 # 字符开头的用户,均为管理账号,列如 `#master` `#admin` `#test`
2018-04-13 10:06:27 +08:00
2020-07-21 10:04:00 +08:00
`普通账号` 不以 # 字符开头的用户,列如 `test` `usernameww` `xxx`
2018-04-13 10:06:27 +08:00
2020-07-21 10:04:00 +08:00
普通账号能够管理的服务器只能由管理账号来进行设定,管理账号可以管理任何服务器,并且能管理所有用户。
2018-04-13 10:06:27 +08:00
2020-07-21 10:04:00 +08:00
具体使用,我想你只需要运行就知道,设计的十分简单。
2018-04-13 10:06:27 +08:00
<br />
2020-07-21 10:04:00 +08:00
问题报告
2017-12-11 17:24:52 +08:00
-----------
2021-03-17 15:26:25 +08:00
欢迎发现任何 BUG 及时反馈,必当及时修复。
若发现严重安全漏洞又不便公开发布,请发送邮件至: Suwings@outlook.com安全问题修复后将在代码中附加漏洞发现者姓名。
2017-12-11 16:37:03 +08:00
2018-04-12 10:08:04 +08:00
<br />
2017-12-11 16:37:03 +08:00
2020-07-21 10:04:00 +08:00
开源协议
2017-12-11 17:24:52 +08:00
-----------
2020-02-23 19:30:51 +08:00
MIT License
2018-04-12 10:08:04 +08:00
<br />