• 注册
    • 登录
    • 版块
    • 热门
    • Metabase官网
    • 社区汉化版
    • 达之云

    Metabase二次开发教程-01-准备工作

    Metabase二次开发教程
    1
    1
    3668
    正在加载更多帖子
    • 从旧到新
    • 从新到旧
    • 最多赞同
    回复
    • 在新帖中回复
    登录后回复
    此主题已被删除。只有拥有主题管理权限的用户可以查看。
    • D
      dazdata 最后由 dazdata 编辑

      一、开发概述

      Metabase采用前后端分离的方式构建,前端使用react搭建页面,后端使用clojure提供REST API接口,详见 API Document;
      Metabase提供了官方文档Developers Guide,对开发环境和运行方式进行了简要说明;
      本文档主要侧重于Clojure部分,前端涉及技术栈比较主流,网上各种文章分析也很全面,就不重复讨论了。

      二、Clojure学习

      Clojure比较冷门,网上学习资料也比较少,因此以官方文档和英文资料为主,一下为一些学习资源:

      • 中文基础教程 主要涵盖了基本语法的教程,内容不多,适合起步阅读;
      • 官方基础教程 同样是基础语法教程,内容不多,英文版;
      • Clojars Clojure的依赖仓库,类似于java的Maven Repository;
      • ClojureDocs Clojuer语法检索,比如输入 map 会检索出map的用法和多个使用示例,非常好用
      • 4Clojure 包含156道Clojure入门练习题,对于快速掌握语法很有帮助

      三、clojure开发配置

      官方网站对Clojure安装进行了说明,详见Getting Started
      个人总结的安装步骤包括:

      • 在Mac上安装Clojure建议使用Homebrew,一键安装简单方便。
        Homebrew官方网站有详细的安装指引,但出于大家都懂的原因,国内没办法按流程安装,网上能搜到各种攻略,但第一次配置还是比较艰难的,推荐使用金牛肖马分享的安装脚本,流程清晰操作简单,链接 Homebrew国内安装

      • 安装Leiningen,可以理解为可以理解为Clojure用的Maven,必不可少的包管理工具,也是Clojure官网推荐的,Leiningen官网

      Leiningen官网推荐的安装方式是下载脚本并在本地运行,脚本运行时要多次访问github,出于大家都懂的原因,需要先解决github访问的问题;
      
      github访问不了的主要方式是DNS地址污染,因此可以通过在本地hosts文件中绑定IP地址的方式解决,网上教程也很多,自行百度即可;
      请注意github的IP在2020年中变化过一次,因此早期的教程可能不起作用,最好是自己先手动查一下最新的IP地址
      
      • 安装Cursive,运行在Idea中的Clojure语言插件,直接在Idea中搜索安装即可,使用教程可查阅Cursive官网
      网上有些文档会建议安装cursive和leiningen两个插件,其实只安装cursive就够了,安装了leiningen反而会冲突报错;
      Clojure项目在Idea中若直接通过Idea中File → Open的方式打开会报错,因为Cursive需要在第一次导入项目时先建索引,因此要通过 File → New → Project from Existing Sources 的方式导入;
      直接在Idea中新建的项目和已经建好索引的项目可以直接打开,不需要每次打开时都重建索引;
      右键点击 project.clj 文件,选择 Run ‘REPL for XXX’ 将在Idea中运行REPL,优势是可以使用快捷键实时将代码导入到REPL中,非常灵活
      Ideal屏幕右下方 structural style 建议选择 Parinfer,自动匹配括号,极其方便
      

      四、常用指令

      lein使用
      leiningen常用命令(需要于project.clj文件所在目录下执行)

      lein deps   # 手动下载项目依赖,若跳过该指令运行项目前也会自动下载依赖
      lein run 以 project.clj  # 中配置的 :main 作为运行入口,运行 -main 方法
      lein ring server  # 执行lein-ring插件配置,运行服务端
      lein new project_name # 按照默认模版,创建名为 project_name 的新任务
      

      五、开发运行

      官方推荐:yarn build-hot 启动前端, lein run 启动后端
      前后端均启动后,访问 http://localhost:3000/ 可进行页面操作(注意不是访问8080)
      metabase默认使用内嵌h2存储元数据,但推荐在生产环境迁移到MySQL或PostgreSQL

      若希望将h2数据迁移到MySQL,可参阅 官方文档 ,启动代码如下:

      MB_DB_TYPE=mysql MB_DB_HOST=172.0.0.1 MB_DB_PORT=3306 MB_DB_USER=username MB_DB_DBNAME=metabase MB_DB_PASS=password lein run load-from-h2
      

      即使换成迁移,下次启动时仍会默认采用h2数据库,使用MySQL数据库仍需要配置参数:

      MB_DB_TYPE=mysql MB_DB_HOST=172.0.0.1 MB_DB_PORT=3306 MB_DB_USER=username MB_DB_DBNAME=metabase MB_DB_PASS=password lein run
      

      转载自:https://blog.csdn.net/weixin_43821438/article/details/111152343

      1 条回复 最后回复 回复 引用 0
      • First post
        Last post

      Powered by MetabaseCN | 提供专业Metabase培训 | QQ群:799286435 微信:MetabaseCN

      鄂ICP备20010758号