Mailgun Logger是一个基于Phoenix/Elixir构建的简单管理工具,通过Mailgun API定期从Mailgun获取事件并存储到MySQL数据库。由于Mailgun仅提供有限时间的事件存储(免费账户最多三天),该工具解决了事件持久化需求。它会获取最近两天的事件(考虑到部分事件可能延迟进入系统),并通过数据库唯一约束确保仅插入新事件。
重要声明
本应用与Mailgun及其子公司或关联公司无任何关联、授权或背书。Mailgun网站为Mailgun。
本工具并非旨在替代Mailgun提供的优秀在线工具,仅用于简单的事件存储。
Jack + Joe不对您使用本工具的行为负责,也不提供任何持久化保证。免费工具存在一定风险 :)
适用于需要长期保存Mailgun事件日志的用户,尤其是:
Mailgun Logger作为Docker镜像发布,可从Docker Hub获取。
使用以下命令直接运行容器:
bash$ docker run -d -p 5050:5050 \ -e "ML_DB_USER=username" \ -e "ML_DB_PASSWORD=password" \ -e "ML_DB_NAME=mailgun_logger" \ -e "ML_DB_HOST=my_db_host" \ --name mailgun_logger jackjoe/mailgun_logger
创建docker-compose.yml文件:
yamlversion: "3" services: db: image: mysql networks: - webnet environment: - MYSQL_PASSWORD=logger - MYSQL_USER=logger - MYSQL_DATABASE=mailgun_logger - MYSQL_RANDOM_ROOT_PASSWORD=yes volumes: - db_data:/var/lib/mysql web: image: jackjoe/mailgun_logger depends_on: - db entrypoint: ["./wait-for", "db:3306", "--", "./start.sh"] ports: - "5050:5050" networks: - webnet environment: - ML_DB_USER=logger - ML_DB_PASSWORD=logger - ML_DB_NAME=mailgun_logger - ML_DB_HOST=db networks: webnet: external: false volumes: db_data: {}
启动服务:
bash$ docker-compose up
服务启动后访问[***]
本地运行需先配置环境。Mailgun Logger依赖MySQL数据库,通过以下环境变量配置(含默认值):
elixir# config/config.ex config :mailgun_logger, MailgunLogger.Repo, username: System.get_env("ML_DB_USER", "mailgun_logger_ci"), password: System.get_env("ML_DB_PASSWORD", "johndoe"), database: System.get_env("ML_DB_NAME", "mailgun_logger_ci_test"), hostname: System.get_env("ML_DB_HOST", "localhost"),
可导出自定义环境变量或使用默认值,然后运行:
bash# 安装依赖、配置开发证书并启动服务 $ make install
启动项目:
bash# 运行iex -S mix phx.server $ make run
若使用自定义环境变量,建议整理到.env文件,运行前加载:
bash# POSIX系统使用 $ . .env && make run
服务启动后访问[***]
本软件采用MIT许可证授权。
Mailgun Logger是我们的第一个开源项目,我们很高兴将其发布!我们热爱开源,多年来为各类工具贡献过代码,现在终于有了自己的项目!我们自己也在使用它。
查看发布文章。
了解更多项目,欢迎联系。jackjoe.be
来自真实用户的反馈,见证轩辕镜像的优质服务
免费版仅支持 Docker Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
在 Linux 系统配置镜像加速服务
在 Docker Desktop 配置镜像加速
Docker Compose 项目配置加速
Kubernetes 集群配置 Containerd
在宝塔面板一键配置镜像加速
Synology 群晖 NAS 配置加速
飞牛 fnOS 系统配置镜像加速
极空间 NAS 系统配置加速服务
爱快 iKuai 路由系统配置加速
绿联 NAS 系统配置镜像加速
QNAP 威联通 NAS 配置加速
Podman 容器引擎配置加速
HPC 科学计算容器配置加速
ghcr、Quay、nvcr 等镜像仓库
无需登录使用专属域名加速
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429