通俗易懂的Docker基础和实战

通俗易懂的Docker基础和实战

Docker基本概念

Docker的优势

统一标准

  • 应用构建
    • 不同软件有不同的环境,规定一个统一格式,这样在使用应用更快速的构建,像windows中执行.exe文件一样
  • 应用分享
    • 只要建立了统一标准,利于分享与传播,如世界货币的美金标准
  • 应用运行
    • 只要安装docker环境,直接一条命令运行应用

资源隔离

  • 容器化
    • 通过实现容器化,导致硬件资源、软件资源相互隔离

Docker的架构

通俗易懂的Docker基础和实战_第1张图片

  • Docker_Host:

    • 安装Docker的主机
  • Docker Daemon:

    • 运行在Docker主机上的Docker后台进程
  • Client:

    • 操作Docker主机的客户端(命令行、UI等)
  • Registry:

    • 镜像仓库
    • Docker Hub
  • Images:

    • 镜像,带环境打包好的程序,可以直接启动运行
  • Containers:

    • 容器,由镜像启动起来正在运行中的程序

装好Docker,然后去 软件市场(Registry) 寻找镜像(Images),下载并运行,应用以容器状态运行

Docker的安装

使用centos7完成本次docker所有操作

  1. 移除以前相关docker包
sudo yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine
  1. 配置yum源
sudo yum install -y yum-utils
sudo yum-config-manager \
--add-repo \
http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
  1. 安装docker
sudo yum install -y docker-ce docker-ce-cli containerd.io
  1. 启动
systemctl enable docker --now
  1. 配置加速
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://3n4m4jry.mirror.aliyuncs.com"],
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

Docker 命令实战

找镜象

去DockerHub 找镜像

docker pull nginx  #下载最新版

镜像名:版本名(标签)

docker pull nginx:1.23.1


docker pull redis  #下载最新
docker pull redis:6.2.4

## 下载来的镜像都在本地
docker images  #查看所有镜像

redis = redis:latest

docker rmi 镜像名:版本号/镜像id

启动容器

启动nginx应用容器,并映射88端口,测试的访问

docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

【docker run  设置项   镜像名  】 镜像启动运行的命令(镜像里面默认有的,一般不会写)

# -d:后台运行
# --restart=always: 开机自启
docker run --name=mynginx   -d  --restart=always -p  88:80   nginx




# 查看正在运行的容器
docker ps
# 查看所有
docker ps -a
# 删除停止的容器
docker rm  容器id/名字
docker rm -f mynginx   #强制删除正在运行中的

#停止容器
docker stop 容器id/名字
#再次启动
docker start 容器id/名字

#应用开机自启
docker update 容器id/名字 --restart=always

修改容器内容

修改默认的index.html 页面

进入容器内部修改

# 进入容器内部的系统,修改容器内容
docker exec -it 容器id  /bin/bash

挂载数据到外部修改

docker run --name=mynginx   \
-d  --restart=always \
-p  88:80 -v /data/html:/usr/share/nginx/html:rw  \
nginx

# 修改页面只需要去 主机的 /data/html
其中rw 参数代表读写 有ro

提交改变

将自己修改好的镜像提交

docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]

docker commit -a "Hillky" -m "第一次提交" 4fbe2003b6da demo1

镜像分享

镜像保存成文件

# 将镜像保存成压缩包
docker save -o abc.tar demo1

# 别的机器加载这个镜像
docker load -i abc.tar


# 离线安装

推送至远程仓库

推送镜像到docker hub;应用市场

# 现在dockerHub建立仓库


# 把旧镜像的名字,改成仓库要求的新版名字
docker tag demo1 hillky/hellonignx:v1.0

# 登录到docker hub
docker login       


docker logout(推送完成镜像后退出)

# 推送
docker push hillky/hellonignx:v1.0


# 别的机器下载
docker pull hillky/hellonignx:v1.0

额外补充

docker logs 容器名/id   排错

docker exec -it 容器id /bin/bash


# docker 经常修改nginx配置文件
docker run -d -p 80:80 \
-v /data/html:/usr/share/nginx/html:ro \
-v /data/conf/nginx.conf:/etc/nginx/nginx.conf \
--name mynginx-02 \
nginx


#把容器指定位置的东西复制出来 
docker cp 5eff66eec7e1:/etc/nginx/nginx.conf  /data/conf/nginx.conf
#把外面的内容复制到容器里面
docker cp  /data/conf/nginx.conf  5eff66eec7e1:/etc/nginx/nginx.conf

进阶实战

编写自己的应用

编写一个HelloWorld应用 利用redis统计网站访问数量

参考代码 : 源码地址

将应用打包成镜像

编写Dockerfile将自己的应用打包镜像

以前

Java为例

  • SpringBoot打包成可执行jar
  • 把jar包上传给服务
  • 服务器运行java -jar
现在

所有机器都安装Docker,任何应用都是镜像,所有机器都可以运行

怎么打包-Dockerfile
FROM openjdk:8-jdk-slim
LABEL maintainer=leifengyang

COPY target/*.jar   /app.jar

ENTRYPOINT ["java","-jar","/app.jar"]
docker build -t java-demo:v1.0 .

启动容器

启动应用容器

docker run -d -p 8080:8080 --name myjava-app java-demo:v1.0 

分享容器

# 登录docker hub
docker login

#给旧镜像起名
docker tag java-demo:v1.0  hillky/docker-demo:v1.0

# 推送到docker hub
docker push  hillky/docker-demo:v1.0

# 别的机器
docker pull hillky/docker-demo:v1.0

# 别的机器运行
docker run -d -p 8080:8080 --name myjava-app docker-demo:v1.0 

部署中间件

部署一个Redis+应用,尝试应用操作Redis产生数据

docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

#redis使用自定义配置文件启动
# 修改配置文件,加入密码访问 详情可以查看redis官方配置文档(requirepass abc123 )

docker run -v /data/redis/redis.conf:/etc/redis/redis.conf \
-v /data/redis/data:/data \
-d --name myredis \
-p 6379:6379 \
redis:6.2.7  redis-server /etc/redis/redis.conf

你可能感兴趣的:(docker,容器,运维)