一站式Linux&数据库管理平台mayfly-go
mhr18 2024-11-25 10:39 22 浏览 0 评论
前言
平时工作过程中,对于远程连接Linux,我们通常会使用SSH工具如:putty、xshell等,对于mysql、mongodb数据库管理通常会使用Navicat、Dbeaver这类工具,redis则有RedisDesktopManager,部分软件可能还需要破解才能使用。每次都要安装来安装去、安装多个软件,这样不免有些繁琐。那么有没有一款工具可以提供一站式管理呢,答案是有的。mayfly-go就是最近比较火的,一款开源的web版linux、mysql、redis、mongo统一管理操作平台。
一、关于mayfly-go
1.简介
web版linux、mysql、redis、mongo统一管理操作平台。
项目地址:https://gitee.com/objs/mayfly-go
项目文档:https://objs.gitee.io/mayfly-go-docs/
下载地址:https://gitee.com/objs/mayfly-go/releases/
开发语言与主要框架
- 前端:typescript、vue3、element-plus
- 后端:golang、gin、gorm
2.功能介绍
- linux: ssh终端(终端操作记录回放),文件查看(可根据常见后缀名高亮显示关键词等)、修改、上传、下载、删除等,脚本管理执行,进程操作,运行状态查看等(可当做堡垒机使用)。
- dbms(目前支持mysql、postgres): 可视化数据增删改查,sql语句提示,表信息、索引信息、建表语句查看,建表等(类似mini版navicat)。
- redis(单机、哨兵、集群): 增删改查redis数据,redis基本信息查看,如版本,内存,cpu等使用情况、集群信息节点查看。
- mongo: 增删改查mongo文档数据,数据库、集合状态查看,新建删除集合等。
- 支持ssh tunnel访问: linux机器、数据库、redis、mongo都支持ssh隧道访问操作。
- 系统管理: 同时拥有完善的账号、角色、资源权限控制等,也可基于该项目进行二次开发作为系统后台系统。
二、安装
1.下载解压
wget https://gitee.com/objs/mayfly-go/releases/download/v1.2.12/mayfly-go-linux-amd64.zip # 在线下载
unzip mayfly-go-linux-amd64.zip # 解压
mv mayfly-go-linux-amd64 mayfly # 改名
解压后会得到以下文件
readme.txt文件中提示了部署方法:
相关配置文件:
后端:
config.yml: 服务端口,mysql,aeskey(16 24 32位),jwtkey等信息在此配置即可。
建议务必将aes.key(资源密码加密如机器、数据库、redis等密码)与jwt.key(jwt秘钥)两信息使用随机字符串替换。
服务启动&重启:./startup.sh
服务关闭:./shutdown.sh
直接通过 host:ip即可访问项目
初始账号 admin/admin123.
2.配置数据库
1)创建数据库
部署mayfly-go的机器上需要提前安装准备好mysql数据库服务,并创建mayfly-go所使用的数据库
# 登录数据库
mysql --host 192.168.1.123 --port 3307 -uroot -pwcgjwcgj
# 在mysql命令行创建mayfly数据库
create database mayfly character set utf8 collate utf8_general_ci;
2)导入mayfly-go.sql
# 由于我的是用docker搭建的mysql容器,所以需要把要执行的文件从宿主机拷贝到容器内
docker cp mayfly-go.sql mysql:/home/
# mysql命令行执行mayfly-go.sql文件
source /home/mayfly-go.sql
查看mayfly数据,此时已创建多张相关表:
3.编辑配置文件config.yml
server:
# debug release test
model: release
port: 8888
cors: true
tls:
enable: false
key-file: ./default.key
cert-file: ./default.pem
# 机器终端操作回放文件存储路径
machine-rec-path: ./rec
jwt:
# jwt key,不设置默认使用随机字符串
key:
# 过期时间单位分钟
expire-time: 1440
# 资源密码aes加密key
aes:
key: 1111111111111111
mysql:
# 改为你自己的ip地址和端口号
host: 192.168.1.123:3307
# 改为你自己的用户名和密码
username: root
password: xxxx
db-name: mayfly
config: charset=utf8&loc=Local&parseTime=true
max-idle-conns: 5
log:
# 日志等级, trace, debug, info, warn, error, fatal
level: info
# file:
# path: ./
# name: mayfly.log
4.启动mayfly-go
./startup.sh
查看nohup.out文件可以看出mayfly-go已经启动成功并连接到mysql数据库
如果前台仍然访问不了,可能是防火墙8888端口未开放,放开端口即可:
firewall-cmd --zone=public --permanent --add-port=8888/tcp
firewall-cmd --reload
5.访问前台页面
http://192.168.1.123:8888,初始账号 admin/admin123.(注意后面有个点)
三、使用
1.前置准备工作
创建账号
【添加账号】:系统管理-账号管理-添加-输入用户名-确认
【设置账号密码】:系统管理-账号管理-勾选账号-编辑-输入密码-确认
【分配用户角色】:系统管理-账号管理-勾选账号-角色分配-勾选角色-确认
添加项目
【添加项目】:项目管理-项目列表-添加-输入项目名及描述-确认
【项目添加成员】:项目管理-项目列表-勾选项目-成员管理-添加-搜索成员-选择成员-确认
只有项目添加成员,该成员账号在登录后添加机器时才能选到该项目,添加成功后如下所示:
【添加环境】:项目管理-项目列表-勾选项目-环境管理-添加环境-输入环境名及描述-确认(后面添加数据库时会用到)
添加机器
机器管理-机器列表-添加-输入机器相关信息-确认
机器列表
2.服务器操作
1)服务器状态监控
点击机器列表页ip:port列的机器ip即可查看该机器的系统资源监控
2)SSH终端操作
点击机器列表页各个机器的“终端”即可进行终端命令行界面
3)文件操作
【添加目录或文件】:机器管理-机器列表-点击指定机器的“文件”-添加-输入名称、选择类型、路径-确认
【查看目录】:例如上述添加了服务器的/home目录,查看该目录
【查看文件详情】:选择任一文件,支持查看、下载、删除,例如查看某个文件:
2.数据库操作
1)MySQL
【添加数据库】:DBMS-数据库管理-添加-填写数据库相关信息-确认
添加数据库成功后,即可在数据库列表中,找到对应的数据库,点击查看-数据库名称可查看数据表信息:
【数据库操作】:DBMS-数据库操作,依次选择项目、环境、资源、数据库、表,即可进行相关操作
2)Redis
【新增redis】:Redis-redis管理-添加-填写相关信息-确认,密码没设置可以不填,如果开启防火墙需要放开6379端口。
【数据操作】:Redis-数据操作,依次选择项目、env、redis、库,例如我想添加一个名称为age的key:
查看添加的key:
3)MongoDB
【连接MongoDB】:Mongo-Mongo管理-添加-填写相关信息-确认,需注意uri格式:
- 如果没有用户名和密码直接填写mongodb://ip:端口号,如:mongodb://192.168.1.123:27017 ;
- 如果有用户名和密码,则格式为:mongodb://用户名:密码@ip:端口号,例如mongodb://root:123456@192.168.1.123:27017
【数据操作】:Mongo-Mongo操作,依次选择项目、env、实例、库、表,例如:我想往test111数据库的user表中插入一条数据,内容如下:
查看插入后的数据:
以上就是mayfly-go平台的搭建部署过程,以及简单使用介绍。
相关推荐
- 【推荐】一个开源免费、AI 驱动的智能数据管理系统,支持多数据库
-
如果您对源码&技术感兴趣,请点赞+收藏+转发+关注,大家的支持是我分享最大的动力!!!.前言在当今数据驱动的时代,高效、智能地管理数据已成为企业和个人不可或缺的能力。为了满足这一需求,我们推出了这款开...
- Pure Storage推出统一数据管理云平台及新闪存阵列
-
PureStorage公司今日推出企业数据云(EnterpriseDataCloud),称其为组织在混合环境中存储、管理和使用数据方式的全面架构升级。该公司表示,EDC使组织能够在本地、云端和混...
- 对Java学习的10条建议(对java课程的建议)
-
不少Java的初学者一开始都是信心满满准备迎接挑战,但是经过一段时间的学习之后,多少都会碰到各种挫败,以下北风网就总结一些对于初学者非常有用的建议,希望能够给他们解决现实中的问题。Java编程的准备:...
- SQLShift 重大更新:Oracle→PostgreSQL 存储过程转换功能上线!
-
官网:https://sqlshift.cn/6月,SQLShift迎来重大版本更新!作为国内首个支持Oracle->OceanBase存储过程智能转换的工具,SQLShift在过去一...
- JDK21有没有什么稳定、简单又强势的特性?
-
佳未阿里云开发者2025年03月05日08:30浙江阿里妹导读这篇文章主要介绍了Java虚拟线程的发展及其在AJDK中的实现和优化。阅前声明:本文介绍的内容基于AJDK21.0.5[1]以及以上...
- 「松勤软件测试」网站总出现404 bug?总结8个原因,不信解决不了
-
在进行网站测试的时候,有没有碰到过网站崩溃,打不开,出现404错误等各种现象,如果你碰到了,那么恭喜你,你的网站出问题了,是什么原因导致网站出问题呢,根据松勤软件测试的总结如下:01数据库中的表空间不...
- Java面试题及答案最全总结(2025版)
-
大家好,我是Java面试陪考员最近很多小伙伴在忙着找工作,给大家整理了一份非常全面的Java面试题及答案。涉及的内容非常全面,包含:Spring、MySQL、JVM、Redis、Linux、Sprin...
- 数据库日常运维工作内容(数据库日常运维 工作内容)
-
#数据库日常运维工作包括哪些内容?#数据库日常运维工作是一个涵盖多个层面的综合性任务,以下是详细的分类和内容说明:一、数据库运维核心工作监控与告警性能监控:实时监控CPU、内存、I/O、连接数、锁等待...
- 分布式之系统底层原理(上)(底层分布式技术)
-
作者:allanpan,腾讯IEG高级后台工程师导言分布式事务是分布式系统必不可少的组成部分,基本上只要实现一个分布式系统就逃不开对分布式事务的支持。本文从分布式事务这个概念切入,尝试对分布式事务...
- oracle 死锁了怎么办?kill 进程 直接上干货
-
1、查看死锁是否存在selectusername,lockwait,status,machine,programfromv$sessionwheresidin(selectsession...
- SpringBoot 各种分页查询方式详解(全网最全)
-
一、分页查询基础概念与原理1.1什么是分页查询分页查询是指将大量数据分割成多个小块(页)进行展示的技术,它是现代Web应用中必不可少的功能。想象一下你去图书馆找书,如果所有书都堆在一张桌子上,你很难...
- 《战场兄弟》全事件攻略 一般事件合同事件红装及隐藏职业攻略
-
《战场兄弟》全事件攻略,一般事件合同事件红装及隐藏职业攻略。《战场兄弟》事件奖励,事件条件。《战场兄弟》是OverhypeStudios制作发行的一款由xcom和桌游为灵感来源,以中世纪、低魔奇幻为...
- LoadRunner(loadrunner录制不到脚本)
-
一、核心组件与工作流程LoadRunner性能测试工具-并发测试-正版软件下载-使用教程-价格-官方代理商的架构围绕三大核心组件构建,形成完整测试闭环:VirtualUserGenerator(...
- Redis数据类型介绍(redis 数据类型)
-
介绍Redis支持五种数据类型:String(字符串),Hash(哈希),List(列表),Set(集合)及Zset(sortedset:有序集合)。1、字符串类型概述1.1、数据类型Redis支持...
- RMAN备份监控及优化总结(rman备份原理)
-
今天主要介绍一下如何对RMAN备份监控及优化,这里就不讲rman备份的一些原理了,仅供参考。一、监控RMAN备份1、确定备份源与备份设备的最大速度从磁盘读的速度和磁带写的带度、备份的速度不可能超出这两...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle位图索引 (63)
- oracle批量插入数据 (62)
- oracle事务隔离级别 (53)
- oracle 空为0 (50)
- oracle主从同步 (55)
- oracle 乐观锁 (51)
- redis 命令 (78)
- php redis (88)
- redis 存储 (66)
- redis 锁 (69)
- 启动 redis (66)
- redis 时间 (56)
- redis 删除 (67)
- redis内存 (57)
- redis并发 (52)
- redis 主从 (69)
- redis 订阅 (51)
- redis 登录 (54)
- redis 面试 (58)
- 阿里 redis (59)
- redis 搭建 (53)
- redis的缓存 (55)
- lua redis (58)
- redis 连接池 (61)
- redis 限流 (51)