
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
Dockerfile链接历史支持标签的Dockerfile链接可查看https://github.com/igor-baiborodine/docker-liferay-portal-ce/blob/master/readme/previously-supported-tags.md%E3%80%82
Liferay Portal是一个开源门户框架,用于构建Web应用、网站和门户,同时提供集成CMS功能,可作为企业集成平台使用。
[***]
!https://github.com/igor-baiborodine/docker-liferay-portal-ce/blob/master/readme/logo.png?raw=true
Logo © Liferay, Inc.
liferay-portal实例console$ docker run --name <容器名称> -d ibaiborodine/liferay-portal-ce:<标签>
其中<容器名称>是你为容器分配的名称,<标签>指定所需的Liferay Portal CE版本。请参考上述标签列表选择合适的标签。
默认配置包含嵌入式Hypersonic数据库和Elasticsearch实例,请注意此设置不适用于生产环境。
你可以通过浏览器访问http://容器IP:8080测试。获取容器IP地址的命令:
console$ docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' <容器名称>
或通过主机端口80访问:
console$ docker run --name <容器名称> -p 80:8080 -d ibaiborodine/liferay-portal-ce:<标签>
然后在浏览器中访问http://localhost:80或http://主机IP:80。
若需以调试模式启动实例:
console$ docker run --name <容器名称> -d ibaiborodine/liferay-portal-ce:<标签> catalina.sh jpda run
docker-compose启动liferay-portal的docker-compose.yml示例:
yamlversion: '3.7' services: liferay: image: docker.xuanyuan.run/ibaiborodine/liferay-portal-ce environment: LIFERAY_SETUP_PERIOD_WIZARD_PERIOD_ENABLED: "false" LIFERAY_TERMS_PERIOD_OF_PERIOD_USE_PERIOD_REQUIRED: "false" LIFERAY_USERS_PERIOD_REMINDER_PERIOD_QUERIES_PERIOD_ENABLED: "false" LIFERAY_USERS_PERIOD_REMINDER_PERIOD_QUERIES_PERIOD_CUSTOM_PERIOD_QUESTION_PERIOD_ENABLED: "false" ports: - "80:8080"
执行docker-compose -f docker-compose.yml up,等待初始化完成后,访问http://localhost:80或http://主机IP:80。
更多docker-compose示例:https://github.com/igor-baiborodine/docker-liferay-portal-ce/blob/master/compose/liferay-mysql/docker-compose.yml%E3%80%81https://github.com/igor-baiborodine/docker-liferay-portal-ce/blob/master/compose/liferay-mysql-elasticsearch/docker-compose.yml
console$ docker run --rm -it ibaiborodine/liferay-portal-ce:<标签> version.sh | grep 'Server version'
使用docker exec命令可在容器内执行命令。以下命令将进入liferay-portal容器的bash shell:
console$ docker exec -it <容器名称> bash
通过docker logs命令查看Liferay Portal日志:
console$ docker logs -f <容器名称>
你可以通过环境变量覆盖https://github.com/liferay/liferay-portal/blob/master/portal-impl/src/portal.properties%E4%B8%AD%E7%9A%84%E9%85%8D%E7%BD%AE%EF%BC%8C%E4%BE%8B%E5%A6%82%EF%BC%9A
properties# # 首次启动门户时是否显示设置向导 # # 环境变量:LIFERAY_SETUP_PERIOD_WIZARD_PERIOD_ENABLED # setup.wizard.enabled=true
要覆盖setup.wizard.enabled属性,启动容器时设置环境变量LIFERAY_SETUP_PERIOD_WIZARD_PERIOD_ENABLED为false:
console$ docker run --name <容器名称> -p 80:8080 -it \ --env LIFERAY_SETUP_PERIOD_WIZARD_PERIOD_ENABLED=false ibaiborodine/liferay-portal-ce:<标签>
环境变量也可通过docker-compose.yml(见上述示例)或扩展镜像(见下文示例)设置。
该镜像未包含显式健康检查。你可以使用--health-*选项添加健康检查:
console$ docker run --name <容器名称> -d \ --health-cmd='curl -fsS "http://localhost:8080/c/portal/layout" || exit 1' \ --health-start-period=1m \ --health-interval=1m \ --health-retries=3 \ ibaiborodine/liferay-portal-ce:<标签>
关于为何未默认定义HEALTHCHECK及如何实现自定义健康检查的详细说明,请查看https://github.com/docker-library/faq#healthcheck%E3%80%82
该镜像暴露可选VOLUME以支持向运行中的容器部署模块。步骤如下:
/my/own/deploydir)。console$ docker run --name <容器名称> -v /my/own/deploydir:/opt/liferay/deploy -d ibaiborodine/liferay-portal-ce:<标签>
-v /my/own/deploydir:/opt/liferay/deploy将主机目录/my/own/deploydir挂载到容器内/opt/liferay/deploy,容器会自动扫描该目录以部署布局模板、Portlet和主题。
默认情况下,Liferay Portal使用Simple File Store存储文档和媒体文件,默认根目录为LIFERAY_HOME/data/document_library。
你可以将主机目录挂载到容器内以持久化存储:
/my/own/liferaydatadir)。console$ docker run --name <容器名称> -v /my/own/liferaydatadir:/opt/liferay/data/document_library -d ibaiborodine/liferay-portal-ce:<标签>
注意:存储文件时请勿使用默认内存数据库(H2),应配置外部数据源(如MySQL)。
若需覆盖默认配置,可在派生镜像中指定环境变量:
dockerfileFROM docker.xuanyuan.run/ibaiborodine/liferay-portal-ce:<标签> ENV LIFERAY_SETUP_PERIOD_WIZARD_PERIOD_ENABLED false ENV LIFERAY_TERMS_PERIOD_OF_PERIOD_USE_PERIOD_REQUIRED false ENV LIFERAY_USERS_PERIOD_REMINDER_PERIOD_QUERIES_PERIOD_ENABLED false ENV LIFERAY_USERS_PERIOD_REMINDER_PERIOD_QUERIES_PERIOD_CUSTOM_PERIOD_QUESTION_PERIOD_ENABLED false
通过LIFERAY_BASE环境变量(默认/etc/opt/liferay)定义的可选VOLUME可自定义实例:
/my/own/liferaybasedir)。console$ docker run --name <容器名称> -v /my/own/liferaybasedir:/etc/opt/liferay -d ibaiborodine/liferay-portal-ce:<标签>
主机目录中的所有文件和子目录会在容器启动时复制到LIFERAY_HOME。例如:
portal-ext.properties到/my/own/liferaybasedir以添加自定义配置。setenv.sh到/my/own/liferaybasedir/tomcat/bin以覆盖Tomcat配置。通过挂载/docker-entrypoint-initliferay.d目录可在Liferay启动前执行脚本:
/my/own/liferayinitdir)。console$ docker run --name <容器名称> -v /my/own/liferayinitdir:/docker-entrypoint-initliferay.d -d ibaiborodine/liferay-portal-ce:<标签>
主机目录中的所有Shell脚本会在Liferay启动前执行。
ibaiborodine/liferay-portal-ce:<version>-<jdk>-buster基于Debian Linux(当前为Buster版本)的默认镜像,适用于大多数场景。
ibaiborodine/liferay-portal-ce:<version>-<jdk>-alpine基于Alpine Linux的镜像,体积更小(约5MB基础镜像),适合对镜像大小有严格要求的场景。需注意Alpine使用musl libc而非glibc,部分软件可能存在兼容性问题。
本库(Liferay Portal Community Edition)是自由软件,你可根据GNU Lesser General Public License(LGPL)2.1版或后续版本的条款重新分发或修改它。
本库不提供任何担保,包括但不限于适销性、特定用途适用性或非侵权担保。详情请查看LGPL许可证。
你应已收到LGPL许可证副本,若未收到,请致函:
textFree Software Foundation, Inc. 51 Franklin Street, Fifth Floor Boston, MA 02110-1301 USA
与所有Docker镜像一样,本镜像可能包含其他软件(如基础发行版的Bash等),这些软件可能受其他许可证约束。
使用预构建镜像时,用户需确保符合所有包含软件的相关许可证要求。
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务