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的步骤如下:
- 安装Docker
- 从Docker仓库找到对应的软件镜像
- 使用Docker运行镜像,生成一个Docker容器.
- 停止容器就是停止软件
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常用命令和操作
-
镜像操作
操作 命令 说明 检索镜像 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 -
容器操作
拉取了对应的镜像以后,我们就可以使用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/ 可以参考每一个镜像的文档
-
安装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文件,方法如下:
- 运行命令
set global max_allowed_packet = 102400;
修改一下这个值 - 然后退出mysql控制台再进入,这里如果不退出的话,这个值是不会改变的
- 再进来以后查看一下改值,会发现已经改变了
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的使用,就记录这么多,以后如果有其他的知识点或者难点,会在这个系列里面记下来~~~