专属域名
文档搜索
轩辕助手
Run助手
邀请有礼
返回顶部
快速返回页面顶部
收起
收起工具栏

ellakcy/moodle Docker 镜像 - 轩辕镜像

moodle
ellakcy/moodle
完整的Moodle安装,包含预配置管理员用户和自动数据库设置功能。
12 收藏0 次下载activeellakcy镜像
🚀专业版镜像服务,面向生产环境设计
中文简介版本下载
🚀专业版镜像服务,面向生产环境设计

docker-moodle

一个安装并运行最新稳定版Moodle的Docker镜像,支持外部MySQL、MariaDB或PostgreSQL数据库,具备自动安装功能并包含默认预定义管理员用户。所有镜像均可通过Docker Hub获取。

构建

使用本仓库构建所需镜像较为繁琐,完整流程在CONTRIBUTING.md文件中有详细描述。

可用镜像

所有可用镜像列表见:[***]

每种镜像变体按数据库支持、版本以及基于Apache还是Alpine FPM进行区分。具体如下:

镜像命名模式PHP执行类型MySQL支持MariaDB支持PostgreSQL支持
mulitbase_apache_^VERSION^apache是是是
mysql_maria_apache_^VERSION^apache是是否
postgresql_apache_^VERSION^apache否否是
mulitbase_alpine_fpm_^VERSION^fpm(运行于Alpine Linux)是是是
mysql_maria_alpine_fpm_^VERSION^fpm(运行于Alpine Linux)是是否
postgresql_alpine_fpm_^VERSION^fpm(运行于Alpine Linux)否否是
mulitbase_fpm_^VERSION^fpm是是是
mysql_maria_fpm_^VERSION^fpm是是否
postgresql_fpm_^VERSION^fpm否否是

^VERSION^为2-3位数字,第一位对应主版本号,其余对应次版本号。例如,mulitbase_apache_39运行Moodle 3.9,mulitbase_apache_310运行Moodle 3.10。

针对最新Moodle版本,还提供以下镜像:

镜像PHP执行类型MySQL支持MariaDB支持PostgreSQL支持
latestapache是是是
mulitbase_apache_latestapache是是是
mysql_maria_apache_latestapache是是否
postgresql_apache_latestapache否否是
mulitbase_alpine_fpm_latestfpm(运行于Alpine Linux)是是是
mysql_maria_alpine_fpm_latestfpm(运行于Alpine Linux)是是否
postgresql_alpine_fpm_latestfpm(运行于Alpine Linux)否否是
mulitbase_fpm_latestfpm是是是
mysql_maria_fpm_latestfpm是是否
postgresql_fpm_latestfpm否否是

针对最新Moodle LTS版本,提供以下镜像:

镜像PHP执行类型MySQL支持MariaDB支持PostgreSQL支持
mulitbase_apache_ltsapache是是是
mysql_maria_apache_ltsapache是是否
postgresql_apache_ltsapache否否是
mulitbase_alpine_fpm_ltsfpm(运行于Alpine Linux)是是是
mysql_maria_alpine_fpm_ltsfpm(运行于Alpine Linux)是是否
postgresql_alpine_fpm_ltsfpm(运行于Alpine Linux)否否是
mulitbase_fpm_ltsfpm是是是
mysql_maria_fpm_ltsfpm是是否
postgresql_fpm_ltsfpm否否是

所有镜像均搭载PHP 7.4。

PHP 8.0镜像

默认PHP版本为7.4,同时为Moodle 3.11、4.0和4.11版本提供PHP 8.0镜像:

镜像命名模式PHP执行类型MySQL支持MariaDB支持PostgreSQL支持
mulitbase_apache_php8.0_^VERSION^apache是是是
mysql_maria_apache_php8.0_^VERSION^apache是是否
postgresql_apache_php8.0_^VERSION^apache否否是
mulitbase_alpine_fpm_php8.0_^VERSION^fpm(运行于Alpine Linux)是是是
mysql_maria_alpine_fpm_php8.0_^VERSION^fpm(运行于Alpine Linux)是是否
postgresql_alpine_fpm_php8.0_^VERSION^fpm(运行于Alpine Linux)否否是
mulitbase_fpm_php8.0_^VERSION^fpm是是是
mysql_maria_fpm_php8.0_^VERSION^fpm是是否
postgresql_fpm_php8.0_^VERSION^fpm否否是

PHP 7.4镜像命名模式如下:

镜像命名模式PHP执行类型MySQL支持MariaDB支持PostgreSQL支持
mulitbase_apache_php7.4_^VERSION^apache是是是
mysql_maria_apache_php7.4_^VERSION^apache是是否
postgresql_apache_php7.4_^VERSION^apache否否是
mulitbase_alpine_fpm_php7.4_^VERSION^fpm(运行于Alpine Linux)是是是
mysql_maria_alpine_fpm_php7.4_^VERSION^fpm(运行于Alpine Linux)是是否
postgresql_alpine_fpm_php7.4_^VERSION^fpm(运行于Alpine Linux)否否是
mulitbase_fpm_php7.4_^VERSION^fpm是是是
mysql_maria_fpm_php7.4_^VERSION^fpm是是否
postgresql_fpm_php7.4_^VERSION^fpm否否是

支持的数据库版本

镜像支持以下数据库版本:

  • Postgresql: 11或更早
  • Mysql: 5.7
  • Mariadb: 10.2

构建周期与版本

我们旨在每周提供更新的镜像。每个构建镜像均以_YmdHi格式标记构建日期,无构建日期的为最新构建。例如,mysql_maria_apache_latest是最新构建镜像,mysql_maria_apache_latest_202108112012是2021-08-11 20:12构建的镜像。可在Docker Hub的标签部分查看最新或旧版本构建。

运行

我们还开发了docker-compose解决方案,强烈建议使用该方案。

此外,若上述方案不符合需求,强烈建议创建docker-compose.yml并使用docker-compose运行。

手动运行镜像
Apache基础解决方案

创建Moodle新实例:

  • ... 使用MySQL:

    bash
    docker run -d --name DB -e MYSQL_DATABASE=moodle -e MYSQL_RANDOM_ROOT_PASSWORD=yes -e MYSQL_ONETIME_PASSWORD=yes -e MYSQL_USER=^数据库用户名^ -e MYSQL_PASSWORD=^数据库密码^ mysql:5.7
    docker run -d -P --name moodle --link DB:DB -e MOODLE_DB_HOST=DB -e MOODLE_URL=[***] -p 8080:80 ellakcy/moodle:mysql_maria_apache_^VERSION^
    

    注意 目前由于MySQL用户认证方式,仅支持5.7及更早版本的MySQL。

  • ... 使用MariaDB:

    bash
    docker run -d --name DB -e MYSQL_DATABASE=^数据库名^ -e MYSQL_RANDOM_ROOT_PASSWORD=yes -e MYSQL_ONETIME_PASSWORD=yes -e MYSQL_USER=^数据库用户名^ -e MYSQL_PASSWORD=^数据库密码^ mariadb:10.2
    docker run -d -P --name moodle --link DB:DB -e MOODLE_DB_HOST=DB -e MOODLE_URL=[***] -e MOODLE_DB_TYPE="mariadb" -p 8080:80 ellakcy/moodle:mysql_maria_apache_^VERSION^
    

    注意 基于与MySQL相同的原因,请使用10.2及更早版本的MariaDB。

  • ... 使用PostgreSQL:

    bash
    docker run --name=DB -e POSTGRES_USER=^数据库用户名^ -e POSTGRES_PASSWORD=^数据库密码^ -e POSTGRES_DB=^数据库名^ -d postgres
    docker run -d -P --name moodle --link DB:DB -e MOODLE_DB_HOST=DB -e MOODLE_URL=[***] -e MOODLE_DB_TYPE="pgsql" -p 8080:80 ellakcy/moodle:postgresql_apache_^VERSION^
    

之后可在浏览器中访问以下URL开始使用:

[***]

注意:如需持久化数据,请在数据库和Moodle容器中均使用卷。 注意2:^VERSION表示Moodle版本。最新LTS版本使用lts,最新非LTS版本使用latest。

Alpine FPM基础解决方案

FPM解决方案建议使用docker-compose。生产环境推荐使用仓库[***]

环境变量

可使用以下额外环境变量(通过docker run命令的-e选项):

默认用户设置环境变量

安装过程中会生成默认用户。请在安装时提供不同的凭据。

变量名默认值描述
MOODLE_URL[***]网站访问URL
MOODLE_ADMINadmin默认管理员用户名
MOODLE_ADMIN_PASSWORDAdmin~1234默认管理员密码 - 生产环境请修改
MOODLE_ADMIN_EMAIL***默认管理员***
数据库设置环境变量
变量名默认值描述
MOODLE_DB_HOST数据库访问URL
MOODLE_DB_PASSWORD数据库密码
MOODLE_DB_USER数据库用户名
MOODLE_DB_NAME数据库名
MOODLE_DB_PORT数据库访问端口
邮件设置环境变量
变量名默认值描述
MOODLE_EMAIL_TYPE_QMAILfalse是否使用qmail作为邮件传输代理(MTA)
MOODLE_EMAIL_HOSTSMTP服务器主机。未提供则不发送邮件
反向代理环境变量
变量名默认值描述
MOODLE_REVERSE_LBfalseMoodle是否运行在负载均衡器后
MOODLE_SSLfalseMoodle是否运行在启用SSL的负载均衡器后
卷

可使用以下卷:

  • /var/moodledata - 存储所有数据
  • /var/www/html - 包含Moodle源代码,供Nginx使用

使用SSL反向代理

通过Nginx

如需使用Nginx作为反向HTTP代理,建议使用以下配置:

nginx
server {
  listen  449 ssl;
  server_name  ^你的域名^;

  ssl_certificate     ^证书路径^;
  ssl_certificate_key ^密钥路径^;
  ssl_protocols       TLSv1 TLSv1.1 TLSv1.2;
  ssl_ciphers         HIGH:!aNULL:!MD5;

  location / {
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection 'upgrade';

        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_cache_bypass $http_upgrade;

        # 如需其他端口,请替换以下值
        proxy_pass http://^本地URL和端口^;
  }
}

其中:

  • ^你的域名^:Moodle可用的域名,需与MOODLE_URL环境变量的值相同。
  • ^本地URL和端口^:反向代理转发请求的URL。
  • ^证书路径^、^密钥路径^:证书及其密钥的路径。

如上述配置所示,根据此问题,反向代理不提供HTTP Host头。

同时需将Docker环境变量MOODLE_REVERSE_LB和MOODLE_SSL设置为true。

注意事项

Moodle相关

以下内容未处理、未考虑或需要进一步工作:

  • Moodle定时任务(应从定时任务容器调用)
  • 日志处理(标准输出?)
  • 邮件(是否能发送?)
Docker相关

如遇到以下错误:

UnixHTTPConnectionPool(host='localhost', port=None): Read timed out. (read timeout=60)

请导出以下环境变量:

bash
export DOCKER_CLIENT_TIMEOUT=120
export COMPOSE_HTTP_TIMEOUT=120

credits

本项目是jmhardison/docker-moodle的分支。

查看更多 moodle 相关镜像 →
bitnami/moodle logo
bitnami/moodle
by VMware
认证
Bitnami提供的Moodle安全镜像,用于快速部署安全、预配置的开源学习管理系统。
19810M+ pulls
上次更新:4 个月前
bitnamicharts/moodle logo
bitnamicharts/moodle
by VMware
认证
Bitnami提供的用于部署Moodle™ LMS的Helm图表,可在Kubernetes集群上快速搭建开源在线学习管理系统,支持模块化配置与数据库集成。
1100K+ pulls
上次更新:4 个月前
lthub/moodle logo
lthub/moodle
by lthub
Moodle是一款免费开源的学习管理系统
65M+ pulls
上次更新:27 天前
bitnamilegacy/moodle logo
bitnamilegacy/moodle
by bitnamilegacy
Bitnami旧版镜像(不再更新),包含所有现有容器镜像的备份,仅用于临时迁移目的,未来可能被移除。
110K+ pulls
上次更新:4 个月前

轩辕镜像配置手册

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式

登录仓库拉取

通过 Docker 登录认证访问私有仓库

Linux

在 Linux 系统配置镜像服务

Windows/Mac

在 Docker Desktop 配置镜像

Docker Compose

Docker Compose 项目配置

K8s Containerd

Kubernetes 集群配置 Containerd

K3s

K3s 轻量级 Kubernetes 镜像加速

宝塔面板

在宝塔面板一键配置镜像

群晖

Synology 群晖 NAS 配置

飞牛

飞牛 fnOS 系统配置镜像

极空间

极空间 NAS 系统配置服务

爱快路由

爱快 iKuai 路由系统配置

绿联

绿联 NAS 系统配置镜像

威联通

QNAP 威联通 NAS 配置

Podman

Podman 容器引擎配置

Singularity/Apptainer

HPC 科学计算容器配置

其他仓库配置

ghcr、Quay、nvcr 等镜像仓库

专属域名拉取

无需登录使用专属域名

需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单

镜像拉取常见问题

轩辕镜像免费版与专业版有什么区别?

免费版仅支持 Docker Hub 访问,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。

轩辕镜像支持哪些镜像仓库?

专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等;免费版仅支持 docker.io。

流量耗尽错误提示

当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。

410 错误问题

通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。

manifest unknown 错误

先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。

镜像拉取成功后,如何去掉轩辕镜像域名前缀?

使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。

查看全部问题→

用户好评

来自真实用户的反馈,见证轩辕镜像的优质服务

oldzhang的头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
ellakcy/moodle
官方博客Docker 镜像使用技巧与技术博客
热门镜像查看热门 Docker 镜像推荐
一键安装一键安装 Docker 并配置镜像源
提交工单
免费获取在线技术支持请 提交工单,官方QQ群:13763429 。
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
免费获取在线技术支持请提交工单,官方QQ群: 。
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
官方邮箱:点击复制邮箱
©2024-2026 源码跳动
官方邮箱:点击复制邮箱Copyright © 2024-2026 杭州源码跳动科技有限公司. All rights reserved.
轩辕镜像 官方专业版 Logo
轩辕镜像轩辕镜像官方专业版
首页个人中心搜索镜像
交易
充值流量我的订单
工具
提交工单镜像收录一键安装
Npm 源Pip 源Homebrew 源
帮助
常见问题
其他
关于我们网站地图

官方QQ群: 13763429