百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 优雅编程 > 正文

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

sinye56 2024-11-18 16:40 7 浏览 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平台的搭建部署过程,以及简单使用介绍。

相关推荐

程序员:JDK的安装与配置(完整版)_jdk的安装方法

对于Java程序员来说,jdk是必不陌生的一个词。但怎么安装配置jdk,对新手来说确实头疼的一件事情。我这里以jdk10为例,详细的说明讲解了jdk的安装和配置,如果有不明白的小伙伴可以评论区留言哦下...

Linux中安装jdk并配置环境变量_linux jdk安装教程及环境变量配置

一、通过连接工具登录到Linux(我这里使用的Centos7.6版本)服务器连接工具有很多我就不一一介绍了今天使用比较常用的XShell工具登录成功如下:二、上传jdk安装包到Linux服务器jdk...

麒麟系统安装JAVA JDK教程_麒麟系统配置jdk

检查检查系统是否自带java在麒麟系统桌面空白处,右键“在终端打开”,打开shell对话框输入:java–version查看是否自带java及版本如图所示,系统自带OpenJDK,要先卸载自带JDK...

学习笔记-Linux JDK - 安装&配置

前提条件#检查是否存在JDKrpm-qa|grepjava#删除现存JDKyum-yremovejava*安装OracleJDK不分系统#进入安装文件目...

Linux新手入门系列:Linux下jdk安装配置

本系列文章是把作者刚接触和学习Linux时候的实操记录分享出来,内容主要包括Linux入门的一些理论概念知识、Web程序、mysql数据库的简单安装部署,希望能够帮到一些初学者,少走一些弯路。注意:L...

测试员必备:Linux下安装JDK 1.8你必须知道的那些事

1.简介在Oracle收购Sun后,Java的一系列产品就被整合到Oracle官网中,打开官网乍眼一看也不知道去哪里下载,还得一个一个的摸索尝试,而且网上大多数都是一些Oracle收购Sun前,或者就...

Linux 下安装JDK17_linux 安装jdk1.8 yum

一、安装环境操作系统:JDK版本:17二、安装步骤第一步:下载安装包下载Linux环境下的jdk1.8,请去官网(https://www.oracle.com/java/technologies/do...

在Ubuntu系统中安装JDK 17并配置环境变量教程

在Ubuntu系统上安装JDK17并配置环境变量是Java开发环境搭建的重要步骤。JDK17是Oracle提供的长期支持版本,广泛用于开发Java应用程序。以下是详细的步骤,帮助你在Ubuntu系...

如何在 Linux 上安装 Java_linux安装java的步骤

在桌面上拥抱Java应用程序,然后在所有桌面上运行它们。--SethKenlon(作者)无论你运行的是哪种操作系统,通常都有几种安装应用程序的方法。有时你可能会在应用程序商店中找到一个应用程序...

Windows和Linux环境下的JDK安装教程

JavaDevelopmentKit(简称JDK),是Java开发的核心工具包,提供了Java应用程序的编译、运行和开发所需的各类工具和类库。它包括了JRE(JavaRuntimeEnviro...

linux安装jdk_linux安装jdk软连接

JDK是啥就不用多介绍了哈,外行的人也不会进来看我的博文。依然记得读大学那会,第一次实验课就是在机房安装jdk,编写HelloWorld程序。时光飞逝啊,一下过了十多年了,挣了不少钱,买了跑车,娶了富...

linux安装jdk,全局配置,不同用户不同jdk

jdk1.8安装包链接:https://pan.baidu.com/s/14qBrh6ZpLK04QS8ogCepwg提取码:09zs上传文件解压tar-zxvfjdk-8u152-linux-...

运维大神教你在linux下安装jdk8_linux安装jdk1.7

1.到官网下载适合自己机器的版本。楼主下载的是jdk-8u66-linux-i586.tar.gzhttp://www.oracle.com/technetwork/java/javase/downl...

window和linux安装JDK1.8_linux 安装jdk1.8.tar

Windows安装JDK1.8的步骤:步骤1:下载JDK打开浏览器,找到JDK下载页面https://d.injdk.cn/download/oraclejdk/8在页面中找到并点击“下载...

最全的linux下安装JavaJDK的教程(图文详解)不会安装你来打我?

默认已经有了linux服务器,且有root账号首先检查一下是否已经安装过java的jdk任意位置输入命令:whichjava像我这个已经安装过了,就会提示在哪个位置,你的肯定是找不到。一般我们在...

取消回复欢迎 发表评论: