Docker系列(一)------Docker简介以及简单的使用

Docker系列(一)------Docker简介以及简单的使用

前言

Docker是目前比较主流的容器技术,博主以前也没有使用过,刚好最近在学习SpringBoot的时候了解到了,也就在这里记录学习的要点,方便以后的查阅.

正文

1.Docker简介

Docker是一个开源的应用容器引擎技术,是一个轻量级的容器技术,它支持将软件编译成一个镜像,然后在镜像中做好各种配置,将镜像发布出去,其他的使用者就可以直接使用这个镜像.类似于Windows系统中的Ghost镜像一样.关于Docker的解释,也可以看下图就可以详细的了解:

在这里插入图片描述

2. Docker核心概念

要使用Docker,就要理解下面几个组件:

  • docker主机 :安装了Docker程序的机器(Docker程序直接安装在操作系统上,Windows或者Linux)
  • docker客户端: 连接docker主机进行操作.
  • docker仓库: 用来保存各种打包好的软件镜像(有公用仓库和私有仓库之分)
  • docker镜像: 软件打包而成的镜像,放在docker仓库中.
  • docker容器: 镜像启动后的实例称为一个容器,容器是独立运行的一个或一组应用.

所以使用Docker的步骤如下:

  1. 安装Docker
  2. 从Docker仓库找到对应的软件镜像
  3. 使用Docker运行镜像,生成一个Docker容器.
  4. 停止容器就是停止软件
3.在linux上安装Docker

步骤如下:

1、检查linux内核版本,必须是3.10及以上,如果不是低于这个版本 就要使用命令升级
uname ‐r
2、安装docker
yum install docker
3、输入y确认安装
4、启动docker
[root@localhost ~]# systemctl start docker
[root@localhost ~]# docker ‐v
Docker version 1.12.6, build 3e8e77d/1.12.6
5、开机启动docker
[root@localhost ~]# systemctl enable docker
Created symlink from /etc/systemd/system/multi‐user.target.wants/docker.service to
/usr/lib/systemd/system/docker.service.
6、停止docker
systemctl stop docker
4.Docker常用命令和操作
  1. 镜像操作

    操作命令说明
    检索镜像docker search 关键字 (举例:docker search mysql)相当于我们直接去docker hub上搜索镜像
    拉取镜像docker pull 镜像名:tag (举例:docker pull mysql:5.5):tag是可选的,tag表示标签,一般表示软件的版本,默认是latest
    查看镜像列表docker images查看本地所有的镜像
    删除镜像docker rmi image-id删除指定的本地镜像,这里的imageid是查看镜像时显示的镜像id
  2. 容器操作

    拉取了对应的镜像以后,我们就可以使用docker来生成容器:

    1、搜索镜像
    [root@localhost ~]# docker search tomcat
    2、拉取镜像
    [root@localhost ~]# docker pull tomcat
    3、根据镜像启动容器
    [root@localhost ~]# docker run ‐‐name mytomcat ‐d tomcat:latest
    4、查看运行中的容器
    [root@localhost ~]# docker ps 
    5、 停止运行中的容器
    [root@localhost ~]# docker stop  容器的id
    6、查看所有的容器
    [root@localhost ~]# docker ps ‐a
    7、启动容器
    [root@localhost ~]# docker start 容器id
    8、删除一个容器
    [root@localhost ~]# docker rm 容器id
    9、启动一个做了端口映射的tomcat
    [root@localhost ~]# docker run ‐d ‐p 8888:8080 tomcat
    ‐d:后台运行
    ‐p: 将主机的端口映射到容器的一个端口    主机端口:容器内部的端口
    10、为了演示简单关闭了linux的防火墙
    查看防火墙状态↓
    [root@localhost ~]# service firewalld status 
    关闭防火墙↓
    [root@localhost ~]# service firewalld stop
    11、查看容器的日志
    [root@localhost ~]# docker logs container‐name/container‐id
    更多命令参看
    https://docs.docker.com/engine/reference/commandline/docker/
    可以参考每一个镜像的文档
    
  3. 安装mysql示例

    在安装对应的镜像,启动容器的时候,还是有一些问题要注意的,我们可以在安装的时候查看DockerHub下每一个镜像的文档,在这里我记录一下安卓mysql的步骤以及遇到的一些问题

    当我们使用docker pull mysql拉取了对应的镜像以后,如使用docker run ‐‐name mysql01 ‐d mysql的方式启动容器,我们会发现容器没有启动起来,我们使用docker logs 镜像id来查看日志,发现启动mysql时报错了:

    [root@localhost ~]# docker logs 42f09819908b
    error: database is uninitialized and password option is not specified
      You need to specify one of MYSQL_ROOT_PASSWORD, MYSQL_ALLOW_EMPTY_PASSWORD and
    MYSQL_RANDOM_ROOT_PASSWORD;
    

    可以看到,报错提示我们需要携带参数,来指定mysql的root密码,因此,正确启动mysql的镜像的姿势是这样的:

    [root@localhost ~]# docker run ‐‐name mysql01 ‐e MYSQL_ROOT_PASSWORD=123456 ‐d mysql
    

    我们还可以直接做好端口映射:

    [root@localhost ~]# docker run ‐p 3306:3306 ‐‐name mysql02 ‐e MYSQL_ROOT_PASSWORD=123456 ‐d mysql
    

    除了这些操作,我们在实际的使用中,可能会需要自定义配置,通过查看官方的文档,也有方法来实现这个功能.

    [root@localhost ~]# docker run ‐‐name mysql03 ‐v /conf/mysql:/etc/mysql/conf.d ‐e MYSQL_ROOT_PASSWORD=my‐secret‐pw ‐d mysql:tag
    //把主机的/conf/mysql文件夹挂载到 mysqldocker容器的/etc/mysql/conf.d文件夹里面
    改mysql的配置文件就只需要把mysql配置文件放在自定义的文件夹下(/conf/mysql)
    

    还可以在启动时指定mysql的一些参数:

    [root@localhost ~]# docker run ‐‐name some‐mysql ‐e MYSQL_ROOT_PASSWORD=my‐secret‐pw ‐d mysql:tag ‐‐character‐set‐server=utf8mb4 ‐‐collation‐server=utf8mb4_unicode_ci
    

连接使用navicat报错1521 是因为加密方式的问题,可以使用下面的方式来解决:

mysql> ALTER user 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';  
Query OK, 0 rows affected (0.01 sec)  
mysql>   
mysql> FLUSH PRIVILEGES;  
Query OK, 0 rows affected (0.01 sec)  
  
mysql> 

5. 小问题
  • 在进行表结构复制,运行SQL文件时,报错:Got a packet bigger than 'max_allowed_packet' bytes,并且终止导入
  • 原因: 项目中是把附件转换成byte数组,存入数据库类型为mediumblob的字段中。由于附件较多,导致单表数据量较大,于是大体定位到mysql会对单表数据量较大的SQL做限制。
  • 解决: 首先要进入mysql控制台,如果是Docker容器启动的mysql,可以使用以下命令进入控制台
    docker exec -it 容器ID bash,首先使用上面这个命令进入具体的容器内部,然后就可以使用mysql的命令来连接控制台:mysql -uroot -p,进入到控制台以后使用命令show VARIABLES like '%max_allowed_packet%';查看max_allowed_packet最大允许包
mysql> show VARIABLES like '%max_allowed_packet%';
+--------------------------+------------+
| Variable_name            | Value      |
+--------------------------+------------+
| max_allowed_packet       | 1024       |
| slave_max_allowed_packet | 1073741824 |
+--------------------------+------------+

可以看到,这里只有1M,显然是不够的,我们可以临时增大这个值,以正常的运行sql文件,方法如下:

  1. 运行命令set global max_allowed_packet = 102400;修改一下这个值
  2. 然后退出mysql控制台再进入,这里如果不退出的话,这个值是不会改变的
  3. 再进来以后查看一下改值,会发现已经改变了
mysql> show VARIABLES like '%max_allowed_packet%';
+--------------------------+------------+
| Variable_name            | Value      |
+--------------------------+------------+
| max_allowed_packet       | 1024       |
| slave_max_allowed_packet | 1073741824 |
+--------------------------+------------+

现在就可以正常的运行我们的SQL文件了.
需要注意的是,以上方式只是临时修改这个值,重启mysql服务以后会重置为原来的值,如果想要用永久修改,可使用以下方法:
修改my.ini文件,在[mysqld]部分加入 max_allowed_packet=大小,这里注意不要在后面加;,修改以后重启,就可以永久生效

总结

关于Docker的使用,就记录这么多,以后如果有其他的知识点或者难点,会在这个系列里面记下来~~~

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值