当前位置: 首页 > news >正文

【原创实践】使用 Docker 部署 IntelliJ IDEA(linuxserver/intellij-idea)完整指南

在服务器或无界面 Linux 环境中使用IntelliJ IDEA一直是个痛点。
借助Docker + linuxserver/intellij-idea 镜像,我们可以非常方便地通过浏览器远程使用 IDEA,实现「即开即用、环境隔离」。

本文将详细介绍如何通过一条docker run命令部署 IntelliJ IDEA,并解释每个参数的作用。


一、准备环境

在开始之前,请确保你的系统已经安装:

  • Docker(20.x 及以上)
  • Linux / macOS / Windows(WSL2)

验证 Docker 是否安装成功:

docker -v

二、docker run 启动 IntelliJ IDEA

下面是一条完整、推荐的启动命令:

docker run -d\--name=intellij-idea\-ePUID=1000\-ePGID=1000\-eTZ=Etc/UTC\-p3000:3000\-p3001:3001\-v ./config:/config\--shm-size="4gb"\--restart unless-stopped\linuxserver/intellij-idea:42025.2.5

执行完成后,容器会在后台启动。


三、参数详解(重点)

1️⃣ 容器运行模式

-d
  • 后台运行容器(daemon 模式)
--name=intellij-idea
  • 指定容器名称,方便后续管理

2️⃣ 用户权限映射(非常重要)

-ePUID=1000-ePGID=1000
  • 指定容器内进程使用的用户 ID 和组 ID
  • 避免挂载目录出现权限问题
  • 1000通常是 Linux 默认用户的 UID/GID

你可以通过以下命令查看本机 UID / GID:

id

3️⃣ 时区设置

-eTZ=Etc/UTC
  • 设置容器时区
  • 可按需修改,例如中国大陆可用:
-eTZ=Asia/Shanghai

4️⃣ 端口映射

-p3000:3000 -p3001:3001
  • 3000:IDEA Web UI 访问端口
  • 3001:WebSocket / 辅助服务端口

访问方式示例:

http://localhost:3000/


5️⃣ 数据持久化(配置目录)

-v ./config:/config
  • 将 IDEA 的配置、插件、缓存持久化到宿主机
  • 容器删除后,配置仍然保留
  • 建议使用绝对路径,例如:
-v /data/intellij/config:/config

6️⃣ 共享内存设置(性能关键)

--shm-size="4gb"
  • 提高共享内存大小
  • 强烈建议设置 ≥ 2GB
  • 否则 IDEA 可能出现卡顿、崩溃、白屏等问题

7️⃣ 自动重启策略

--restart unless-stopped
  • Docker 或服务器重启后自动启动
  • 手动docker stop时不会再自动拉起

8️⃣ 使用的镜像版本

linuxserver/intellij-idea:42025.2.5
  • 来自linuxserver.io官方维护
  • 指定版本号,避免 latest 带来的不确定性
  • 可按需替换为其他版本

四、访问 IntelliJ IDEA

启动完成后,浏览器访问:

http://<服务器IP>:3000

首次进入时:

  • 会加载 Web 桌面
  • 可进行 IntelliJ IDEA 初始化
  • 支持安装插件、登录 JetBrains 账号

五、常用 Docker 管理命令

查看容器状态

dockerps

查看日志

docker logs -f intellij-idea

停止 / 启动容器

docker stop intellij-idea docker start intellij-idea

删除容器(不删除配置)

dockerrmintellij-idea

六、适用场景

✔ 远程服务器开发
✔ 云 IDE / 内网开发环境
✔ 多人共享开发主机
✔ 不想在本机安装 IDEA


七、总结

通过 Docker 部署 IntelliJ IDEA:

  • ✅ 环境隔离
  • ✅ 无需本地安装
  • ✅ 支持浏览器访问
  • ✅ 配置可持久化
  • ✅ 适合长期运行
http://www.cnnetsun.cn/news/169214.html

相关文章:

  • 22、电脑硬件安装与使用全解析
  • 23、蓝牙设备、驱动管理与数码照片导入全攻略
  • 28、视频编辑与网络连接全攻略
  • 面对复杂业务,XinServer 给了我技术自信
  • 如何评估Linly-Talker生成视频的真实感?主观测评方法
  • 15、Windows Server DHCP 安装、授权与管理全解析
  • 渗透测试策略覆盖不全 后来才知道用强化学习动态生成攻击路径
  • Linly-Talker模型更新日志:v2.1版本新增五大功能
  • Linly-Talker能否接入企业微信/钉钉?API对接说明
  • 64、Windows 8 TCP/IP网络配置与故障排除指南
  • Linly-Talker支持动态光照渲染,视觉质感再升级
  • 数字人社交机器人:Linly-Talker在陪伴经济中的价值
  • 20、Azure Table 服务:实体操作、分页与序列化详解
  • Linly-Talker如何优化长段落无标点文本的断句策略?
  • Linly-Talker实战教程:如何用AI生成会说话的数字人
  • 46、掌握企业项目管理:从模板构建到资源配置
  • 57、掌握项目管理利器:全面解析项目规划与执行技巧
  • 31、深入解析IIS管理脚本与数据库操作
  • 常见快捷键
  • Linly-Talker支持多种肖像输入格式:证件照、自拍、动漫均可
  • 智慧城市之城市环境智能监管 非法倾倒行为自动识别 环保执法证据采 垃圾倾倒倾倒物品类型识别数据据 垃圾堆识别数据集 公路垃圾识别10315期
  • Chromium143原生支持HLS
  • 玩轮胎仿真不上手?老司机带你飙车。今天咱们用ABAQUS搞点硬核操作,从过盈充气到滚动传涵,手把手教你怎么让虚拟轮胎活起来
  • 当风电遇上“太极推手“:混合储能如何化解功率波动
  • MIPI DSI DPHY FPGA工程源码:Artix7-100t彩条驱动1024*600像...
  • 最近在折腾四旋翼导航时踩了不少坑,发现真正让无人机听话飞行的核心都在代码细节里。今天就拿手头正在调试的飞控项目举例,聊聊怎么用代码让四旋翼实现基础导航
  • 永磁同步电机全速域无传感器控制探索
  • Linly-Talker生成视频的镜头拉近推远动态效果实现
  • SpringBoot+Vue +线上教育培训办公系统管理平台源码【适合毕设/课设/学习】Java+MySQL
  • 36、Windows Server 2008 网络中的打印与网络策略服务介绍