文章目录
- 一、前置准备
- 二、Docker 服务端配置
- 1. 配置 Docker 远程连接端口
- 三、Idea 客户端连接 Docker
- 1. 安装插件并重启 Idea
- 2. 连接远程 Docker
- 四、使用 Idea 的 Docker 插件操作镜像和容器,并完成一键发布
- 1. Docker Image 方式
- - 新建连接
- - 使用服务器上的 Docker
- - 容器操作
- - 镜像操作
- - 镜像拉取
- - 容器创建与运行
- 2. Dockerfile 方式
- - 准备测试项目
- - 创建 Dockerfile
- - 创建 Dockerfile 配置
- - 运行结果
- 3. Docker-Compose 方式
一、前置准备
要开始使用 Docker,请参考以下入门指南:Docker 入门
二、Docker 服务端配置
1. 配置 Docker 远程连接端口
首先,新建或修改 /etc/systemd/system/docker.service.d/override.conf
文件,确保其内容如下:
## Add this to the file for the docker daemon to use different ExecStart parameters (more things can be added here)
[Service]
ExecStart=
ExecStart=/usr/bin/dockerd
接着,在 /etc/docker/daemon.json
文件中(如果没有则新建),添加以下内容。请使用您自己的镜像地址,不必强制使用示例中的地址:
{
"registry-mirrors": ["https://2v6jvius.mirror.aliyuncs.com"],
"hosts": [
"unix:///var/run/docker.sock",
"tcp://0.0.0.0:2375"
]
}
然后重启 Docker 服务:
systemctl daemon-reload
systemctl restart docker
通过以下命令检查端口是否成功开放:
ss -tuln | grep 2375
如果看到类似以下的输出,说明端口开放成功:
tcp6 0 0 :::2375 :::* LISTEN 8511/dockerd
💡 注意:请务必在腾讯云控制台中开放 2375 端口,同时务必限制访问来源。等到添加了证书后再完全开放。如果不清楚这点,建议暂停后续操作,特别是如果是在阿里云公网机器上,容易受到攻击。
接下来,输入以下命令以确认 Docker 端口暴露成功:
docker -H 121.204.196.203 ps
若能显示 Docker 的基本信息,说明端口暴露成功。关于更安全地开启 Docker 远程访问,请参考 CA 认证的配置。链接: docker安全连接
三、Idea 客户端连接 Docker
1. 安装插件并重启 Idea
在 IDEA 中安装 Docker 插件,并重启 IDE:
2. 连接远程 Docker
- 编辑配置
- 填入远程 Docker 地址
- 连接成功后,会列出远程 Docker 容器和镜像
成功连接后,可以看到远程 Docker 的容器和镜像:
为了确保安全,需要进行认证配置,详情请参考:链接: docker安全连接
四、使用 Idea 的 Docker 插件操作镜像和容器,并完成一键发布
1. Docker Image 方式
Docker Image 方式主要用于在 IDEA 中操作远程服务器上的 Docker 镜像和监控容器信息。
- 新建连接
在 IDEA 的设置中(File -> Settings -> Docker),新建连接:
- 使用服务器上的 Docker
- 容器操作
在 IDEA 中可以进行容器的各种操作:
- 镜像操作
拉取镜像:
对已有镜像的操作:
- 镜像拉取
注意,写 Docker 镜像地址时,需要在镜像名称后面指定版本号。如果不指定,IDEA 会默认使用 latest
:
如遇到拉取超时的情况,可以配置国内镜像源,如阿里云的加速器:
- 容器创建与运行
创建并运行 Docker 容器:
新的 IDEA 版本可能需要额外的参数配置:
创建成功后,可以在服务器上查看新创建的容器:
进行容器的重启、停止和删除等操作:
总的来说,
Docker Image
插件将服务器上的命令行操作可视化,简化了操作过程。
2. Dockerfile 方式
有关 Dockerfile 的介绍,请参考这篇文章:Dockerfile 介绍
- 准备测试项目
创建一个测试项目:
@Controller
public class HelloController {
@GetMapping("hello")
@ResponseBody
public String hello() {
return "hello world" + new SimpleDateFormat(" [yyyy-mm-dd HH:mm:ss]").format(new Date());
}
}
server.port=8085
- 创建 Dockerfile
在工程的 pom.xml
文件所在目录下创建名为 Dockerfile
的文件,内容如下:
# 基础镜像,使用 Alpine 操作系统,OpenJDK 8u201
FROM java:openjdk-8-jdk-alpine
# 作者
MAINTAINER Ximenes <xxxxxxxxx@gmail.com>
# 系统编码
ENV LANG=C.UTF-8 LC_ALL=C.UTF-8
# 声明一个挂载点,容器内此路径会对应宿主机的某个文件夹
VOLUME /tmp
# 应用构建成功后的 jar 文件被复制到镜像内,名字也改成了 app.jar
ADD target/*.jar app.jar
# 设置 Alpine 系统时区
ENV TZ=Asia/Shanghai
RUN ln -snf /usr/share/zoneinfo/${TZ} /etc/localtime && echo ${TZ
} > /etc/timezone
# 暴露端口
EXPOSE 8085
# 启动容器时的进程
ENTRYPOINT [ "java", "-Djava.security.egd=file:/dev/./urandom", "-jar", "/app.jar" ]
- 创建 Dockerfile 配置
如图所示,创建一个 Dockerfile 配置:
根据下图中的说明进行设置,确保每个步骤都被执行:
在"Run Maven Goal"中输入 clean package
,表示每次构建镜像之前都会清理并重新编译构建:
- 运行结果
成功构建并部署镜像后,可以在 Docker 上运行容器:
在浏览器访问地址 http://192.168.3.250/hello
,可以看到应用在容器中正常运行:
修改源代码并再次发布镜像即可看到修改后的结果。
3. Docker-Compose 方式
关于 Docker-Compose 的介绍,请参考这篇文章:Docker-Compose 介绍。主要功能是:通过 docker-compose.yml 文件编排运行容器
。