Docker基础

Docker学习

docker核心:隔离,每个箱子互相隔离

Docker安装

镜像(imgage)

docker镜像就好比是一个模板,可以通过这个模板来创建容器服务,

tomcat===>run==>tomcat01容器(提供服务器),通过这个镜像可以创建多个容器(最终服务运行或者项目运行就是在容器中)。

容器(contalner):

Docker利用容器技术,独立运行一个或者一个租应用,通过镜像来创建的,启动、停止、删除、基本命令!

目前就可以把这个容器理解为就是一个简易的linux系统

仓库(repository):

仓库就是存放镜像的地方!

仓库分为公用仓库和私有仓库!

Docker Hub(默认是国外的)

阿里云,,,都用容器的服务器(配置镜像加速)

安装Docker
1.环境准备

1.需要会一点点的linux的基础

2.CentOS

3.使用xshell连接远程服务器进行操作

2.环境查看
#系统内核是3.10以上的
[root@VM-0-13-centos ~]# uname -r
3.10.0-957.21.3.el7.x86_64

#系统版本
[root@VM-0-13-centos ~]# cat /etc/os-release
NAME="CentOS Linux"
VERSION="7 (Core)"
ID="centos"
ID_LIKE="rhel fedora"
VERSION_ID="7"
PRETTY_NAME="CentOS Linux 7 (Core)"
ANSI_COLOR="0;31"
CPE_NAME="cpe:/o:centos:centos:7"
HOME_URL="https://www.centos.org/"
BUG_REPORT_URL="https://bugs.centos.org/"

CENTOS_MANTISBT_PROJECT="CentOS-7"
CENTOS_MANTISBT_PROJECT_VERSION="7"
REDHAT_SUPPORT_PRODUCT="centos"
REDHAT_SUPPORT_PRODUCT_VERSION="7"
3.安装
1.卸载旧版本的docker
[root@VM-0-13-centos ~]# yum remove docker \
>                   docker-client \
>                   docker-client-latest \
>                   docker-common \
>                   docker-latest \
>                   docker-latest-logrotate \
>                   docker-logrotate \
>                   docker-engine
Loaded plugins: fastestmirror, langpacks
No Match for argument: docker
No Match for argument: docker-client
No Match for argument: docker-client-latest
No Match for argument: docker-common
No Match for argument: docker-latest
No Match for argument: docker-latest-logrotate
No Match for argument: docker-logrotate
No Match for argument: docker-engine
No Packages marked for removal

#2.需要的安装包
yum install -y yum-utils

#3.设置镜像的仓库
yum-config-manager \
    --add-repo \
    https://download.docker.com/linux/centos/docker-ce.repo #默认是国外的


#推荐使用阿里云的镜像
yum-config-manager \
    --add-repo \
http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

#更新yum软件包索引
yum makecache fast
#4.安装docker相关的 docker-ce社区版 ee企业版
yum install docker-ce docker-ce-cli containerd.io

#5.启动docker
systemctl start docker
#6.使用docker version
查看是否运行成功
#7.启动测试
docker run hello-world
#8.查看一下下载的这个hello-world镜像
[root@VM-0-13-centos ~]# docker images
REPOSITORY    TAG       IMAGE ID       CREATED        SIZE
hello-world   latest    d1165f221234   6 months ago   13.3kB

4.了解卸载docker
#1.卸载依赖
yum remove docker-ce docker-ce-cli containerd.io

#2.删除资源
rm -rf /var/lib/docker
# /var/lib/docker docker默认的工作路径
5.阿里云镜像加速
sudo mkdir -p /etc/docker

sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://ow04lqcv.mirror.aliyuncs.com"]
}
EOF


sudo systemctl daemon-reload

sudo systemctl restart docker
6.回顾Hello World
7.docker底层原理

Docker是一个Client Server结构的系统,Docker的守护进程运行在主机上,通过Socket从客户端访问!

DockerServer接收到Docker-Client的指令,就会执行这个命令。

Docker的常用命令

帮助命令

docker version #显示docker的版本信息
docker info    #显示docker的系统信息,包括镜像和容器的数量
docker 命令 --help #帮助命令

镜像命令

1.#docker images 查看当前启动的docker镜像
REPOSITORY 镜像仓库
TAG 镜像标签
IMAGE ID 镜像ID
CREATED 创建时间
SIZE 大小

2.#docker search 镜像名
#查询某个镜像
[root@VM-0-13-centos ~]# docker search mysql
NAME                              DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED
mysql                             MySQL is a widely used, open-source relation…   11413     [OK]       
mariadb                           MariaDB Server is a high performing open sou…   4338      [OK]       

3.#docker search --help 关于search的命令的帮助文档

4.#docker pull 下载镜像
docker pull mysql

5.#通过指定版本下载
[root@VM-0-13-centos ~]# docker pull mysql:5.7
5.7: Pulling from library/mysql
a330b6cecb98: Pull complete 
9c8f656c32b8: Pull complete 
88e473c3f553: Pull complete 
062463ea5d2f: Pull complete 
daf7e3bdf4b6: Pull complete 
1839c0b7aac9: Pull complete 
cf0a0cfee6d0: Pull complete 
fae7a809788c: Pull complete 
dae5a82a61f0: Pull complete 
7063da9569eb: Pull complete 
51a9a9b4ef36: Pull complete 


6.#删除镜像 docker rmi -f 
#删除指定的容器
[root@VM-0-13-centos ~]# docker rmi -f 1d7aba917169
#删除多个容器
[root@VM-0-13-centos ~]# docker rmi -f 镜像id 镜像id 镜像id
#删除全部容器
[root@VM-0-13-centos ~]# docker rmi -f $(docker images -aq)

容器命令

说明:我们有了镜像才可以创建容器,linux,下载一个centos镜像来测试学习

docker pull centos

新建容器并启动

docker run [] iamge

#参数说明
--name="Name" 容器名字tomcat01 tomcat02 用来区分容器
-d            后台方式运行
-it           使用交互方式运行,进入容器查看内容
  -p 主机端口:容器端口(常用)
-p            指定容器的端口号 -p 8080:8080
-P            随机指定端口
#测试 启动并进入容器
[root@VM-0-13-centos ~]# docker run -it centos /bin/bash
[root@6238108cca4b /]# 
#exit 退出当前容器

列出当前运行的镜像

# docker ps  列出当前运行的镜像
# docker ps -a 列出所有的容器
# -n=? 显示最近创建的容器
# -q 只显示编号

退出容器

exit #直接容器停止并退出
Ctrl+P+Q #容器停止退出

删除容器

docker rm                        #容器id 容器 不能删除正在运行的容器,如果强制删除 rm -f
docker rm -f $(docker ps -aq)    #删除所有的容器
docker ps -a -q|xargs docker rm  #删除所有的容器

启动和停止容器的操作

docker start 容器id      #启动容器  
docker restart 容器id    #重启容器
docker stop 容器id       #停止当前正在运行的容器
docker kill 容器id       #强制停止当前容器

常用其他命令

后台启动容器

#docker run -d 镜像名
[root@VM-0-13-centos ~]# docker run -d centos
3691fc9abc0f1a84da457b8111ae32ffd78846c0086d8393cd0e3f2abbabca9f

#问题docker ps 发现centos停止了

#常见的坑:docker容器使用后台运行,就必须要有一个前台进程,docker发现没有应用,就会自动停止2、
#nginx 容器启动后,发现自己吗,没有提供服务,就会立刻停止,就是没有程序了

查看日志命令

#docker logs -f -t --tail 容器id

查看容器中的进程信息

#docker top 849fcb2fb504 容器id
[root@VM-0-13-centos ~]# docker top 849fcb2fb504
UID    PID        PPID         C          STIME         TTY          TIME          CMD
root   30973      30955        0          15:23        pts/0       00:00:00       /bin/bash

查看镜像的元数据

#docker inspect容器id 
#docker inspect 1bc0b9651e53
[root@VM-0-13-centos ~]# docker inspect 1bc0b9651e53
[
    {
        "Id": "1bc0b9651e53db1a6e675dbe5be668aacf954b1faf693d3c9faf902fc9c0f803",
        "Created": "2021-09-17T01:09:41.244377845Z",
        "Path": "/bin/bash",
        "Args": [],
        "State": {
            "Status": "running",
            "Running": true,
            "Paused": false,
            "Restarting": false,
            "OOMKilled": false,
            "Dead": false,
            "Pid": 20221,
            "ExitCode": 0,
            "Error": "",
            "StartedAt": "2021-09-17T01:09:41.536307522Z",
            "FinishedAt": "0001-01-01T00:00:00Z"
        },
        "Image": "sha256:5d0da3dc976460b72c77d94c8a1ad043720b0416bfc16c52c45d4847e53fadb6",
        "ResolvConfPath": "/var/lib/docker/containers/1bc0b9651e53db1a6e675dbe5be668aacf954b1faf693d3c9faf902fc9c0f803/resolv.conf",
        "HostnamePath": "/var/lib/docker/containers/1bc0b9651e53db1a6e675dbe5be668aacf954b1faf693d3c9faf902fc9c0f803/hostname",
        "HostsPath": "/var/lib/docker/containers/1bc0b9651e53db1a6e675dbe5be668aacf954b1faf693d3c9faf902fc9c0f803/hosts",
        "LogPath": "/var/lib/docker/containers/1bc0b9651e53db1a6e675dbe5be668aacf954b1faf693d3c9faf902fc9c0f803/1bc0b9651e53db1a6e675dbe5be668aacf954b1faf693d3c9faf902fc9c0f803-json.log",
        "Name": "/dreamy_ishizaka",
        "RestartCount": 0,
        "Driver": "overlay2",
        "Platform": "linux",
        "MountLabel": "",
        "ProcessLabel": "",
        "AppArmorProfile": "",
        "ExecIDs": null,
        "HostConfig": {
            "Binds": null,
            "ContainerIDFile": "",
            "LogConfig": {
                "Type": "json-file",
                "Config": {}
            },
            "NetworkMode": "default",
            "PortBindings": {},
            "RestartPolicy": {
                "Name": "no",
                "MaximumRetryCount": 0
            },
            "AutoRemove": false,
            "VolumeDriver": "",
            "VolumesFrom": null,
            "CapAdd": null,
            "CapDrop": null,
            "CgroupnsMode": "host",
            "Dns": [],
            "DnsOptions": [],
            "DnsSearch": [],
            "ExtraHosts": null,
            "GroupAdd": null,
            "IpcMode": "private",
            "Cgroup": "",
            "Links": null,
            "OomScoreAdj": 0,
            "PidMode": "",
            "Privileged": false,
            "PublishAllPorts": false,
            "ReadonlyRootfs": false,
            "SecurityOpt": null,
            "UTSMode": "",
            "UsernsMode": "",
            "ShmSize": 67108864,
            "Runtime": "runc",
            "ConsoleSize": [
                0,
                0
            ],
            "Isolation": "",
            "CpuShares": 0,
            "Memory": 0,
            "NanoCpus": 0,
            "CgroupParent": "",
            "BlkioWeight": 0,
            "BlkioWeightDevice": [],
            "BlkioDeviceReadBps": null,
            "BlkioDeviceWriteBps": null,
            "BlkioDeviceReadIOps": null,
            "BlkioDeviceWriteIOps": null,
            "CpuPeriod": 0,
            "CpuQuota": 0,
            "CpuRealtimePeriod": 0,
            "CpuRealtimeRuntime": 0,
            "CpusetCpus": "",
            "CpusetMems": "",
            "Devices": [],
            "DeviceCgroupRules": null,
            "DeviceRequests": null,
            "KernelMemory": 0,
            "KernelMemoryTCP": 0,
            "MemoryReservation": 0,
            "MemorySwap": 0,
            "MemorySwappiness": null,
            "OomKillDisable": false,
            "PidsLimit": null,
            "Ulimits": null,
            "CpuCount": 0,
            "CpuPercent": 0,
            "IOMaximumIOps": 0,
            "IOMaximumBandwidth": 0,
            "MaskedPaths": [
                "/proc/asound",
                "/proc/acpi",
                "/proc/kcore",
                "/proc/keys",
                "/proc/latency_stats",
                "/proc/timer_list",
                "/proc/timer_stats",
                "/proc/sched_debug",
                "/proc/scsi",
                "/sys/firmware"
            ],
            "ReadonlyPaths": [
                "/proc/bus",
                "/proc/fs",
                "/proc/irq",
                "/proc/sys",
                "/proc/sysrq-trigger"
            ]
        },
        "GraphDriver": {
            "Data": {
                "LowerDir": "/var/lib/docker/overlay2/99adcb5c5d63af7245a8ef708fcc2a67de4e6e0407b750ee089dde7dbe301f7a-init/diff:/var/lib/docker/overlay2/dabc1d77e4f3d5eda50be93e71259080abcf8262c7982715affc28e16701d36b/diff",
                "MergedDir": "/var/lib/docker/overlay2/99adcb5c5d63af7245a8ef708fcc2a67de4e6e0407b750ee089dde7dbe301f7a/merged",
                "UpperDir": "/var/lib/docker/overlay2/99adcb5c5d63af7245a8ef708fcc2a67de4e6e0407b750ee089dde7dbe301f7a/diff",
                "WorkDir": "/var/lib/docker/overlay2/99adcb5c5d63af7245a8ef708fcc2a67de4e6e0407b750ee089dde7dbe301f7a/work"
            },
            "Name": "overlay2"
        },
        "Mounts": [],
        "Config": {
            "Hostname": "1bc0b9651e53",
            "Domainname": "",
            "User": "",
            "AttachStdin": true,
            "AttachStdout": true,
            "AttachStderr": true,
            "Tty": true,
            "OpenStdin": true,
            "StdinOnce": true,
            "Env": [
                "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
            ],
            "Cmd": [
                "/bin/bash"
            ],
            "Image": "centos",
            "Volumes": null,
            "WorkingDir": "",
            "Entrypoint": null,
            "OnBuild": null,
            "Labels": {
                "org.label-schema.build-date": "20210915",
                "org.label-schema.license": "GPLv2",
                "org.label-schema.name": "CentOS Base Image",
                "org.label-schema.schema-version": "1.0",
                "org.label-schema.vendor": "CentOS"
            }
        },
        "NetworkSettings": {
            "Bridge": "",
            "SandboxID": "66ec8b453054a132bb396a756fd2815f13bf566638e7484b7c23429f3c67cec9",
            "HairpinMode": false,
            "LinkLocalIPv6Address": "",
            "LinkLocalIPv6PrefixLen": 0,
            "Ports": {},
            "SandboxKey": "/var/run/docker/netns/66ec8b453054",
            "SecondaryIPAddresses": null,
            "SecondaryIPv6Addresses": null,
            "EndpointID": "26094911cb8670b7ffc961c57235c04097cd424073ab0b44f66f52df6d370d22",
            "Gateway": "172.18.0.1",
            "GlobalIPv6Address": "",
            "GlobalIPv6PrefixLen": 0,
            "IPAddress": "172.18.0.2",
            "IPPrefixLen": 16,
            "IPv6Gateway": "",
            "MacAddress": "02:42:ac:12:00:02",
            "Networks": {
                "bridge": {
                    "IPAMConfig": null,
                    "Links": null,
                    "Aliases": null,
                    "NetworkID": "7462f9b9b2b32bf0a4d37c4a915e659d289bc9db73bbdf5c5666ae5a255c0b58",
                    "EndpointID": "26094911cb8670b7ffc961c57235c04097cd424073ab0b44f66f52df6d370d22",
                    "Gateway": "172.18.0.1",
                    "IPAddress": "172.18.0.2",
                    "IPPrefixLen": 16,
                    "IPv6Gateway": "",
                    "GlobalIPv6Address": "",
                    "GlobalIPv6PrefixLen": 0,
                    "MacAddress": "02:42:ac:12:00:02",
                    "DriverOpts": null
                }
            }
        }
    }
]

进入当前正在运行的容器

#我们通常容器都是使用后台方式运行的,需要进入容器,修改一些配置

#命令
#docker exec -it 容器id bashShell
#命令一
[root@VM-0-13-centos ~]# docker exec -it 1bc0b9651e53 /bin/bash
[root@1bc0b9651e53 /]# ls
bin  dev  etc  home  lib  lib64  lost+found  media  mnt  opt  proc  root  run  sbin  srv  
[root@1bc0b9651e53 /]# ps -ef
UID        PID  PPID  C STIME TTY          TIME CMD
root         1     0  0 01:09 pts/0    00:00:00 /bin/bash
root        16     0  0 01:15 pts/1    00:00:00 /bin/bash
root        31    16  0 01:16 pts/1    00:00:00 ps -ef
#命令二
#docker attach 容器id
[root@VM-0-13-centos ~]# docker attach 1bc0b9651e53 
[root@1bc0b9651e53 /]# ls
bin  dev  etc  home  lib  lib64  lost+found  media  mnt  opt  proc  root  run  sbin  srv  

# docker exec  #进入容器后开启一个新的终端,可以在里面操作(常用)
# docker attach #进入容器正在执行的终端,不会启动新的进程!

从容器内拷贝文件到主机

docker cp 容器id:容器内部路径 目的主机的路径

Docker 安装Nginx

#搜索nginx 
docker search nginx
#拉取镜像
docker pull nginx
#启动镜像
-d 后台运行
--name为容器起名 
-p 暴露端口 宿主机端口:容器内部端口
[root@VM-0-13-centos home]# docker run -d --name nginx01 -p:3344:80 nginx
dde10516a4abb8d6a744b5a6d6584ecf68dbfc1c34e91d6697a3bd9e0199868d

#进入容器
[root@VM-0-13-centos home]# docker exec -it nginx01 /bin/bash

Docker装Tomcat

#官方的使用
docker run -it --rm tomcat:9.0
#我们之前的启动都是后台启动,停止了容器之后,容器还是可以查到 docker run -it --rm 一般用来测试,用完及删除

#下载启动
docker pull tomcat

#启动运行
docker run -d -p 8888:8080 -name tomcat01 tomcat
#进入容器
docker exec -it tomcat /bin/bash

部署es+kibana

#es 暴露的端口很多
#es 十分的耗内存
#es 的数据一般需要放置到安全目录!挂载
# --net somenetword?网络配置

#启动elasticsearch
docker run -d --name elasticsearch  -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" elasticsearch:7.6.2
#启动elasticsearch占内存 太卡

#查看服务状态
docker stats

#赶紧关闭,增加内存的限制,修改配置文件 -e 环境配置修改
docker run -d --name elasticsearch  -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" -e ES_JAVA_OPTS="-Xms64m -Xms512m" elasticsearch:7.6.2

可视化

什么是portainer?

Docker图形化界面管理工具!提供一个后台面板供我们操作

docker run -d -p 8080:9000 \
--restart=always -v /var/run/docker.sock:/var/run/docker.sock --privileged=true portainer/portainer

commit镜像

docker commit 提交容器成为一个新的副本

#命令和git原理一样
docker commit -m="提交的描述信息" -a="作者" 容器id 目标镜像名:[TAG]

实战测试

#启动一个默认的tomcat

#发现这个默认的tomcat是没有webapps应用,镜像的原因,官方默认没有

#自己把基本文件拷贝进去
cp webapps.dist/* webapps

#将我们操作过的容器通过commit提交一个镜像
[root@VM-0-13-centos ~]# docker commit -a="chaochao" -m="add webapps app" eaefa4a59d70 tomcat01:1.0.0

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-fDr2Kijf-1631871858307)(C:\Users\liu\AppData\Roaming\Typora\typora-user-images\image-20210917154811396.png)]

容器数据卷

什么是容器数据卷

docker的理念回顾

#需求: 数据可持续化
#需求: MySQL数据可以存储在本地
#总结:容器的持久化和同步操作!容器间也是可以数据共享!

使用数据卷

#方式一:直接使用命令来挂载 -v 类似于双向绑定 
#实现数据同步
[root@VM-0-13-centos /]# docker run -it -v /home/ceshi:/home centos /bin/bash

的副本

#命令和git原理一样
docker commit -m=“提交的描述信息” -a=“作者” 容器id 目标镜像名:[TAG]


实战测试

````shell
#启动一个默认的tomcat

#发现这个默认的tomcat是没有webapps应用,镜像的原因,官方默认没有

#自己把基本文件拷贝进去
cp webapps.dist/* webapps

#将我们操作过的容器通过commit提交一个镜像
[root@VM-0-13-centos ~]# docker commit -a="chaochao" -m="add webapps app" eaefa4a59d70 tomcat01:1.0.0

[外链图片转存中…(img-fDr2Kijf-1631871858307)]

容器数据卷

什么是容器数据卷

docker的理念回顾

#需求: 数据可持续化
#需求: MySQL数据可以存储在本地
#总结:容器的持久化和同步操作!容器间也是可以数据共享!

使用数据卷

#方式一:直接使用命令来挂载 -v 类似于双向绑定 
#实现数据同步
[root@VM-0-13-centos /]# docker run -it -v /home/ceshi:/home centos /bin/bash
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值