一站式Linux&数据库管理平台mayfly-go

本文涉及的产品
云原生内存数据库 Tair,内存型 2GB
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
云数据库 MongoDB,通用型 2核4GB
简介: web版linux、mysql、redis、mongo统一管理操作平台。

前言

平时工作过程中,对于远程连接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 2432位),jwtkey等信息在此配置即可。
    建议务必将aes.key(资源密码加密如机器、数据库、redis等密码)与jwt.key(jwt秘钥)两信息使用随机字符串替换。
服务启动&重启:./startup.sh
服务关闭:./shutdown.sh
直接通过 host:ip即可访问项目
初始账号 admin/admin123.

2.配置数据库

1)创建数据库

部署mayfly-go的机器上需要提前安装准备好mysql数据库服务,并创建mayfly-go所使用的数据库

# 登录数据库mysql --host192.168.1.123 --port3307-uroot-pxxxxx# 在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加密keyaes:
  key: 1111111111111111mysql:
# 改为你自己的ip地址和端口号  host: 192.168.1.123:3307
# 改为你自己的用户名和密码  username: root
  password: xxxx
  db-name: mayfly
  config: charset=utf8&loc=Local&parseTime=true  max-idle-conns: 5log:
# 日志等级, 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平台的搭建部署过程,以及简单使用介绍。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
5天前
|
Linux 开发工具
Linux技术资源分享:探索Linux软件包的宝藏:沙皇下载平台体验
Linux技术资源分享:探索Linux软件包的宝藏:沙皇下载平台体验
11 3
|
10天前
|
关系型数据库 MySQL Go
Go语言介绍以及如何在Go语言中操作MySQL数据库
Go语言介绍以及如何在Go语言中操作MySQL数据库
26 3
|
9天前
|
存储 关系型数据库 MySQL
MySQL数据库进阶第一篇(存储引擎与Linux系统上安装MySQL数据库)
MySQL数据库进阶第一篇(存储引擎与Linux系统上安装MySQL数据库)
|
19天前
|
Oracle 关系型数据库 MySQL
深入了解 Linux 命令 `db_stat`:数据库统计信息的获取
本文模拟了 Linux 环境下使用 `db_stat` 命令获取数据库统计信息的场景,实际上`db_stat`是特定数据库系统的自定义工具。文章通过示例展示了如何针对Oracle、PostgreSQL和MySQL使用各自内置命令收集统计信息,强调了权限、性能影响和数据实时性等因素,并指出这些信息对优化数据库管理至关重要。
|
14天前
|
JavaScript Java 测试技术
基于SpringBoot+Vue的《数据库原理及应用》课程平台的详细设计和实现
基于SpringBoot+Vue的《数据库原理及应用》课程平台的详细设计和实现
12 1
|
19天前
|
SQL Oracle 关系型数据库
探索 Linux 命令 `db_archive`:Oracle 数据库归档日志的工具
探索 Linux 中的 `db_archive`,实际与 Oracle 数据库归档日志管理相关。在 Oracle 中,归档日志用于恢复,当在线重做日志满时自动归档。管理员可使用 SQL*Plus 查看归档模式,通过 `RMAN` 进行备份和恢复操作。管理归档日志需谨慎,避免数据丢失。了解归档管理对 Oracle 管理员至关重要,确保故障时能快速恢复数据库。
|
19天前
|
数据可视化 Linux 数据库
探索 Linux 命令 `db_tuner`:优化数据库性能的利器
`db_tuner` 是一个假设的 Linux 工具,用于数据库性能优化,提供状态检查、查询分析、配置调优、索引建议及报告生成等功能。虽然不是真实命令,但类似工具如 `mysqltuner` 可实现这些功能。通过安装和运行 `db_tuner`,DBA 可以提升数据库性能,解决瓶颈问题。
|
19天前
|
存储 关系型数据库 Linux
探索 `db_printlog`:Linux 下的数据库日志打印工具
`db_printlog`是Linux下用于解析和打印Berkeley DB日志文件的命令行工具,帮助用户以可读格式理解数据库事务和系统事件。要使用它,先安装Berkeley DB,然后通过`db_printlog logfilename`命令分析日志。常见选项包括`-h`(显示帮助)、`-v`(详细输出)和`-f`(跟随日志更新)。注意日志文件权限和大小问题,此工具适用于Berkeley DB,其他数据库系统可能有不同解析工具。
|
19天前
|
存储 缓存 Linux
深入理解Linux中的`db_load`命令:数据库加载的利器
`db_load`是Linux下处理Berkeley DB的关键命令,用于将文本数据加载到数据库中。它支持多种文本格式,如键值对和CSV,并具有灵活的选项,如指定数据库类型、缓存大小、日志记录和错误处理。通过`-f`加载文本文件,`-s`设定数据库类型,`-l`设置缓存。本文详细介绍了`db_load`的使用方法和高级特性,并给出案例,如将CSV用户信息加载到Btree数据库。了解并善用`db_load`能提升数据处理效率和安全性。
|
22天前
|
Java 测试技术 数据安全/隐私保护
基于ssm+vue.js+uniapp小程序的《数据库原理及应用》课程平台附带文章和源代码部署视频讲解等
基于ssm+vue.js+uniapp小程序的《数据库原理及应用》课程平台附带文章和源代码部署视频讲解等
10 0
基于ssm+vue.js+uniapp小程序的《数据库原理及应用》课程平台附带文章和源代码部署视频讲解等

热门文章

最新文章