Docker学习

目录

  • 初识Docker
  • Docker命令
  • Docker应用部署
  • 备份与迁移
  • Dockerfile
  • Docker相关概念
  • Docker服务编排
  • Docker容器数据卷
  • Docker私有仓库

初识Docker

代码会接触的环境:开发环境,测试环境,生产环境

docker是一个开源的应用容器引擎,基于go语言实现。docker可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的Linux机器上,容器完全使用沙箱机制,相互隔离。容器的性能开销极低,从17.03之后分为CE(社区版)和EE(企业版)。

总结:docker是一种容器技术,解决软件跨环境迁移的问题。

安装docker:

docker可以运行在MAC、Windows、CentOS、UBUNTU等操作系统上。docker官网:https://www.docker.com

docker架构:

  • 镜像(Image):Docker 镜像(Image),就相当于是一个 root 文件系统。比如官方镜像 ubuntu:16.04 就包含了完整的一套 Ubuntu16.04 最小系统的 root 文件系统。
  • 容器(Container):镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的类和实例一样,镜像是静态的定义,容器是镜像运行时的实体。容器可以被创建、启动、停止、删除、暂停等。
  • 仓库(Repository):仓库可看成一个代码控制中心,用来保存镜像。

Docker 使用客户端-服务器 (C/S) 架构模式,使用远程API来管理和创建Docker容器。

Docker 容器通过 Docker 镜像来创建。

容器与镜像的关系类似于面向对象编程中的对象与类。

Docker面向对象
容器 对象
镜像

 

 

 默认情况下,从docker hub(https://hub.docker.com)上下载docker镜像,太慢,一般会配置镜像加速器。

docker命令

docker服务相关:

  • 启动docker服务 systemctl start docker
  • 停止docker服务   stop docker 
  • 重启docker服务   restrat docker
  • 查看docker服务状态 systemctl status docker
  • 开机启动docker服务 systemctl enable docker

docker镜像相关命令

  • 查看镜像  docker images  #查看本地所有的镜像  、docker images -q #查看所用镜像的id
  • 搜索镜像  docker search +镜像名称
  • 拉取镜像 docker pull +镜像名称:版本号 如果不知道版本,可以到docker hub搜索对应的镜像查看
  • 删除镜像  docher rmi +imageID  #删除指定本地镜像   docker rmi `docker images -q`#删除所有本地镜像

docker容器相关命令:

  • 查看容器  docker ps #查看正在运行的容器 docker ps -a 查看所有容器
  • 创建容器 docker run -it --name=C1 centos:7   /bin/bash   # 根据镜像创建容器并直接进入容器,退出用exit,推出后容器关闭

                           docker run -id  --name=C2 centos:7 #创建容器,容器后台运行,推出后容器也不关闭

  • 进入容器   docker exec -it c2  (/bin/bash)
  • 启动容器  docker start C2
  • 停止容器 docker stop C2
  • 删除容器  docker rm C1  、docker rm `docker ps -aq`#删除所有容器
  • 查看容器信息  docker inspect C2

 创建并启动容器的参数说明:

docker run 参数

参数说明:

-i:保持容器运行。通常与-t同时使用,加入这两个参数后,容器创建后自动进入容器中,推出容器后,容器自动关闭

-t:为容器重新分配一个伪输入终端,通常与-i一起使用

-d:以守护(后台)模式运行容器,创建一个容器后台运行,需要使用docker exec进入容器,推出后容器不会关闭

-it创建的容器一般为交互式容器,-id创建的容器一般为守护式容器

--name:为创建的容器命名。

Docker容器的数据卷

如何使用Docker数据卷? - 腾讯云开发者社区-腾讯云 (tencent.com)

数据卷的概念及作用:

数据卷是宿主机中的一个目录或文件,当容器目录和数据卷目录绑定后,对方的修改会立即同步,一个数据卷可以被多个容器同时挂载,一个容器可以挂载多个数据卷。

数据卷的作用:容器数据持久化;外部机器和容器间接通信;容器之间数据交换

配置数据卷:

#创建启动容器时,使用-v参数 设置数据卷
docker run ...  -v 宿主机目录(文件):容器目录(文件) ...

注意事项:1,目录必须是绝对路径 2,如果目录不存在,会自动创建 3,可以挂载多个数据卷

eg:docker run -it --name=C1 -v /root/data:/root/data_container centos:7 /bin/bash

配置数据卷容器:

多容器进行数据交换

1,多个容器挂载同一个数据卷

2,数据卷容器

1,#创建启动C3数据卷容器,使用-V参数 设置数据卷
docker run -it --name=c3 -v /volume centos:7 /bin/bash
2,#创建启动C1 C2容器,使用--volumes-from 参数 设置数据卷
docker run -it --name=c1 --volumes-from c3 centos:7 /bin/bash
docker run -it --name=c2 --volumes-from c3 centos:7 /bin/bash

Docker应用部署:

  • MySQL部署
  • Tomcat部署
  • Nginx部署
  • Redis部署

MySQL部署

需求:在Docker容器中部署MySQL,并通过外部mysql客户端操作MySQLServer

实现步骤:

搜索mysql镜像,拉取mysql镜像,创建容器,操作容器中的mysql

操作:端口映射

容器内的网络服务和外部机器不能直接通信

外部机器和宿主机器可以直接通信

宿主机和容器可以直接通信

当容器中的网络服务需要被外部机器访问时,可以将容器中提供服务的端口映射到宿主机端口上,外部机器访问宿主机的该端口,从而间接访问容器的服务。

复制代码
1,#搜索mysql镜像
docker search mysql
2,#拉取mysql镜像
docker pull mysql:5.6
3,#创建容器,设置端口映射、目录映射
# 在/root目录下创建mysql目录用于存储mysql数据信息
mkdir ~/mysql
cd ~/mysql
------------------------------------------------------------------
docker run -id \
-p 3307:3306 \
--name=c_mysql \
-v $PWD/conf:/etc/mysql/conf.d \
-v $PWD/logs:/logs \
-v $PWD/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
mysql:5.6
---------------------------------------------------------------------
- 参数说明:
  - **-p 3307:3306**:将容器的 3306 端口映射到宿主机的 3307 端口。
  - **-v $PWD/conf:/etc/mysql/conf.d**:将主机当前目录下的 conf/my.cnf 挂载到容器的 /etc/mysql/my.cnf。配置目录
  - **-v $PWD/logs:/logs**:将主机当前目录下的 logs 目录挂载到容器的 /logs。日志目录
  - **-v $PWD/data:/var/lib/mysql** :将主机当前目录下的data目录挂载到容器的 /var/lib/mysql 。数据目录
  - **-e MYSQL_ROOT_PASSWORD=123456:**初始化 root 用户的密码。
4,#进入容器,操作mysql
docker exec –it c_mysql /bin/bash
5,#
使用外部机器连接容器中的mysql

 

 

 
复制代码

部署tomcat

需求:在Docker容器中部署Tomcat,并通过外部机器访问Tomcat部署的项目

实现步骤;

搜索tomcat镜像,拉取tomcat镜像,创建容器,部署项目,测试访问

复制代码
#搜索tomcat镜像
docker search tomcat
#拉取tomcat镜像
docker pull tomcat
#创建容器,设置端口映射、目录映射
# 在/root目录下创建tomcat目录用于存储tomcat数据信息
mkdir ~/tomcat
cd ~/tomcat
-------------------------------------------------------------------------
docker run -id --name=c_tomcat \
-p 8080:8080 \
-v $PWD:/usr/local/tomcat/webapps \
tomcat 
------------------------------------------------------------------------
参数说明:

- **-p 8080:8080:**将容器的8080端口映射到主机的8080端口

  **-v $PWD:/usr/local/tomcat/webapps:**将主机中当前目录挂载到容器的webapps
------------------------------------------------------------------------
#使用外部机器访问tomcat

 


 

 
复制代码

部署Nginx

需求:在Docker容器中部署Nignx,并通过外部机器访问Nignx

实现步骤:

 

复制代码
1,搜索nginx镜像
docker search nginx
2,拉取nginx镜像
docker pull nginx
3,创建容器,设置端口映射、目录映射
# 在/root目录下创建nginx目录用于存储nginx数据信息
mkdir ~/nginx
cd ~/nginx
mkdir conf
cd conf
# 在~/nginx/conf/下创建nginx.conf文件,粘贴下面内容
vim nginx.conf
user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;

    include /etc/nginx/conf.d/*.conf;
}

-------------------------------------------------------------------------
docker run -id --name=c_nginx \
-p 80:80 \
-v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf \
-v $PWD/logs:/var/log/nginx \
-v $PWD/html:/usr/share/nginx/html \
nginx
--------------------------------------------------------------------------
- 参数说明:
  - **-p 80:80**:将容器的 80端口映射到宿主机的 80 端口。
  - **-v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf**:将主机当前目录下的 /conf/nginx.conf 挂载到容器的 :/etc/nginx/nginx.conf。配置目录
  - **-v $PWD/logs:/var/log/nginx**:将主机当前目录下的 logs 目录挂载到容器的/var/log/nginx。日志目录

4. 使用外部机器访问nginx

 


 

 
复制代码

部署redis

1,搜索redis镜像
docker search redis
2,拉取redis镜像
docker pull redis:5.0
3,创建容器,设置端口映射
docker run -id --name=c_redis -p 6379:6379 redis:5.0
4,使用外部机器连接redis
./redis-cli.exe -h 192.168.149.135 -p 6379

Dockerfile

  • docker镜像原理
  • dockerfile概念及作用
  • dockerfile关键字
  • 案例

 Docker镜像原理

操作系统组成部分:

  • 进程调度子系统
  • 进程通信子系统
  • 内存管理子系统
  • 设备管理子系统
  • 文件管理子系统
  • 网络通信子系统
  • 作业控制子系统

linux文件系统由bootfs和rootfs两部分组成

bootfs:包含bootloader(引导加载程序)和kernel(内核)

rootfs:root文件系统,包含的就是典型linux系统中的/dev,/proc,/bin,/etc等标准目录和文件

不同的linux发行版,bootfs基本一样,而rootfs不同,如ubuntu,centos等。

 

posted @   存在与虚无  阅读(15)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
点击右上角即可分享
微信分享提示