侧边栏壁纸
  • 累计撰写 129 篇文章
  • 累计创建 13 个标签
  • 累计收到 0 条评论

目 录CONTENT

文章目录

【openGauss】在windows中使用容器化的mogeaver

DarkAthena
2022-09-07 / 0 评论 / 0 点赞 / 716 阅读 / 4460 字

前言

这是一个对目前某些暂时在linux专享的功能,在windows上实现的探索,不建议在生产中使用。

思路

  1. 目前windows10/11上支持搭建docker环境,而不需要使用linux虚拟机
  2. windows上的docker可以借用VcXsrv或xming等X11工具,来将容器中的图形化界面显示到windows上
  3. mogeaver的linux版本是用的gtk做的GUI

所以,理论上,我们可以找个操作系统的docker镜像,装好gtk和jdk环境,把linux版本的mogeaver放进去,然后在windows上用VcXsrv设置一个显示器,启动容器,把容器的dispaly设置到windows上,就能在windows上使用linux版本的mogeaver了。

需要解决的问题

  1. 最好能找到一个带gtk环境的docker镜像,这样就不需要自己从头开始构建了(之前没接触过gtk开发,为了省时间。。。)
  2. 一般精简的docker镜像是没有中文字体支持的,因此mogeaver就也不能显示中文字体,而国内的windows的用户应该还是更愿意使用中文界面
  3. 默认在mogeaver中设置好gs_dump/gsql等客户端工具的目录,减少用户配置环境的操作
  4. 用户配置文件信息需要持久化到宿主机上,防止下次启动容器配置丢失
  5. 最好每次在用mogeaver时创建容器,关闭的时候自动删除容器,节约资源
  6. 默认yum仓库源有时候无法连接,需要有个备用源,否则可能构建镜像失败

半成品

项目地址:
https://gitee.com/darkathena/mogeaver-docker


使用说明

  1. 先确保本地windows已安装docker-desktop,并已经启动该服务

https://www.docker.com/get-started/

  1. 下载VcXsrv

https://sourceforge.net/projects/vcxsrv/

  1. 安装VcXsrv,一路下一步,然后打开XLaunch,一路下一步
  2. 下载mogdb和mogeaver压缩包,放到本文件夹
wget https://cdn-mogdb.enmotech.com/mogeaver/22.1.5/mogeaver-ce-22.1.5-linux.gtk.x86_64.tar.gz
wget https://cdn-mogdb.enmotech.com/mogdb-media/3.0.1/MogDB-3.0.1-CentOS-x86_64.tar.gz
  1. 进入本目录,执行构建镜像命令
docker build -t mogeaver-docker:latest .
  1. 构建完成后,执行run_mogeaver.bat即可启动mogeaver

个性化修改说明

  1. 默认用户配置路径在 d:\MogeaverData ,可以通过修改run_mogeaver.bat文件变更
  2. 默认gs_dump导出文件路径在 d:\dump_data ,可以通过修改run_mogeaver.bat文件变更
  3. 如果需要中文字体支持,请取消dockerfile中关于“Chinese font support”部分的注释
  4. 如果需要更换国内yum源,请取消dockerfile中关于“change yum repo”部分的注释

特点

  1. 已集成openGauss客户端命令行工具,比如gsql/gs_dump等,可以通过mogeaver相关功能调用
  2. 关闭程序即删除容器,节省内存资源

使用截图

  1. 构建
    image-1662550269020
  2. 软件打开界面
    image-1662550350017
  3. 执行备份
    image-1662550519565
    image-1662550700045
  4. 生成的文件
    image-1662550744841

遗留问题

由于不明原因,一段时间不操作,容器版本的程序就会闪退。。。

后记

在做这个东西的时候,了解到了目前很多东西都可以容器化,后来又想到了,能不能封装一个gs_dump.exe调用linux容器中的gs_dump,这样就能用windows版本的mogeaver来调用gs_dump了。以后有时间再看怎么弄吧。

0
  1. 支付宝打赏

    qrcode alipay
  2. 微信打赏

    qrcode weixin
博主关闭了所有页面的评论