Docker 的安装
Docker 是一个开源的商业产品,有两个版本:社区版(Community Edition,缩写为 CE)和企业版(Enterprise Edition,缩写为 EE)。
Docker CE 的安装请参考官方文档,我们这里以CentOS为例:
1、Docker 要求 CentOS 系统的内核版本高于 3.10
通过 uname -r 命令查看你当前的内核版本
uname -r
2、使用 root 权限登录 Centos。确保 yum 包更新到最新。
yum -y update
3、卸载旧版本(如果安装过旧版本的话)
sudo yum remove -y docker*
4、安装需要的软件包, yum-util 提供 yum-config-manager 功能
yum install -y yum-utils
5、设置yum源,并更新 yum 的包索引
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
yum makecache fast
6、可以查看所有仓库中所有docker版本,并选择特定版本安装
yum list docker-ce --showduplicates | sort -r
7、安装docker
yum install -y docker-ce-3:26.1.4-1.el7.x86_64 # 指定安装版本
8、启动并加入开机启动
systemctl start docker
systemctl enable docker
9、验证安装是否成功(有client和service两部分表示docker安装启动都成功了)
docker version
10、卸载docker
yum remove -y docker*
rm -rf /etc/systemd/system/docker.service.d
rm -rf /var/lib/docker
rm -rf /var/run/docker
Docker常用命令
镜像相关命令
1、列出镜像
docker image ls
2、拉取镜像(会从 Docker Hub 的仓库中下载镜像)
docker pull 镜像名称[:tag]
docker pull java:8
3、删除本地镜像
docker image rm 镜像名或镜像id
容器相关命令
1、运行容器
docker run [option] 镜像名 [向启动容器中传入的命令]
常用可选参数说明:
-d:代表后台运行容器
-p 宿主机端口:容器端口:为了映射当前Linux的端口和容器的端口
--name 为创建的容器命名
-e 为容器设置环境变量
--network=host 表示将主机的网络环境映射到容器中,容器的网络与主机相同
2、查看容器
docker ps [-a]
-a:查看全部的容器,包括没有运行
3、 查看容器日志
docker logs -f 容器id
4、 进入容器内容部
docker exec -it 容器id /bin/bash
5、容器与宿主机相互复制文件
# 将宿主机的文件复制到容器内部
docker cp 文件名称 容器id:容器内部路径
# 从容器里面拷贝文件到宿主机
docker cp 容器id:文件在容器内的路径 宿主机路径
6、启动、停止容器
# 启动停止的容器
docker start 容器id
# 停止指定的容器
docker stop 容器id
# 停止全部容器
docker stop $(docker ps -qa)
# 删除指定容器(删除容器前,需要先停止容器)
docker rm 容器id
7、将容器保存为镜像
docker commit 容器名 镜像名
8、镜像备份与迁移
可以通过save命令将镜像打包成文件,拷贝给别人使用
docker save -o 保存的文件名 镜像名
docker save -o ./ubuntu.tar ubuntu
在拿到镜像文件后,可以通过load方法,将镜像加载到本地
docker load -i ./ubuntu.tar
使用Dockerfile构建微服务镜像
Dockerfile是一个文本文件,其中包含了若干条指令,指令描述了构建镜像的细节
如下为Dockerfile的语言:
from: 指定当前自定义镜像依赖的环境
copy: 将相对路径下的内容复制到自定义镜像中
workdir: 声明镜像的默认工作目录
run: 执行的命令,可以编写多个
cmd: 需要执行的命令(在workdir下执行的,cmd可以写多个,只以最后一个为准)
目标:将 5G定制网的微服务,打包成1个镜像文件
1、在微服务的目录新建一个 Dockerfile 的文件,在里面增加如下内容:
# 使用 jdk8 作为基础镜像
FROM jdk8:8u51
# 设置工作目录
WORKDIR /app
# 复制所有微服务的JAR文件到容器中
COPY ./cyberwing-common/cyberwing-common.jar /app/cyberwing-common/
COPY ./cyberwing-common/application.yml /app/cyberwing-common/
COPY ./capitek-upms/application-dev.yml /app/capitek-upms/
COPY ./capitek-upms/upms.jar /app/capitek-upms/
# 暴露端口
EXPOSE 8120 8102
ENV JAVA_OPTS "-Xms512m -Xmx512m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/var/log/ -Dfile.encoding=utf-8"
ENTRYPOINT java ${JAVA_OPTS} -jar /app/cyberwing-common/cyberwing-common.jar --spring.config.location=/app/cyberwing-common/application.yml & \
java ${JAVA_OPTS} -jar /app/capitek-upms/upms.jar --spring.config.location=/app/capitek-upms/application-dev.yml --jasypt.encryptor.password=capitekor & \
wait
2、在Dockerfile所在路径执行以下命令构建镜像:
docker build -t my-app .
# -t 指定镜像名字,(.)表示Dockerfile文件所在路径
3、运行容器
docker run -d -p 18899:8899 --name my-app my-app
4、如果希望在运行容器时覆盖环境变量的值,可以在 docker run 命令中使用 -e 标志来传递环境变量
首先改写微服务的配置文件,将配置中统一设置的 Mysql、redis 这些配置项改为 变量 形式
docker run -d \
-p 18120:8120 \
-p 18102:8102 \
--name my-app \
-e DATABASE_URL="172.18.1.212" \
-e DATABASE_PORT="3306" \
-e DATABASE_NAME="cyberwing_v1.4_zdyfy" \
-e DATABASE_USERNAME="ENC(FYthkcvukQtU+nbm+5lCtg==)" \
-e DATABASE_PASSWORD="ENC(JUzm26YzVxf8CsmiqLiHAg==)" \
my-app