文章目录
玩转Docker
一、准备Docker环境
安装
设置存储库
- 安装所需的软件包。yum-utils提供了yum-config-manager 效用,并device-mapper-persistent-data和lvm2由需要 devicemapper存储驱动程序。
$ sudo yum install -y yum-utils device-mapper-persistent-data lvm2
- 使用以下命令来设置稳定的存储库。
$ sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
安装DOCKER ENGINE-社区
安装最新版本的Docker Engine-Community和containerd
$ sudo yum install docker-ce docker-ce-cli containerd.io
尝试启动Docker。
$ sudo systemctl start docker
通过运行hello-world 映像来验证是否正确安装了Docker Engine-Community。
$ sudo docker run hello-world
首次运行sudo docker run hello-world会出现找不到image 'hello-world:latest’的情况,不过很快docker会自动从Docker Hub上获取到最新的Hello World镜像,下载到了本地。

再次运行上述命令,运行成功。

至此,Docker的环境准备已完成!
二、Docker 基本操作
运行镜像
# docker run -it ubuntu bash
注意:在这里我下载速度比较慢,所以我参考了网上的方法把镜像换成了阿里云的镜像,参考自:docker下载镜像太慢的解决方案
运行结果:

显示本地镜像库内容
# docker images
运行结果:

获得帮助
# docker --help
运行结果:

显示运行中容器
# docker ps
运行结果:

显示所有容器(包含已中止)
# docker ps -a
运行结果:

继续运行原容器并进入
下面的nostalgic_haslett可以是任意已中止的容器,通过# docker ps -a可以查看。
# docker restart nostalgic_haslett
# docker ps
# docker attach nostalgic_haslett
运行结果:

三、MySQL与容器化
拉取 MySQL 镜像
# docker pull mysql:5.7

构建docker镜像练习
录入内容
# mkdir mydock && cd mydock
# vi dockerfile
录入以下内容:
FROM ubuntu
ENTRYPOINT ["top", "-b"]
CMD ["-c"]
构建镜像
# docker build . -t hello
运行结果:

运行镜像
# docker run -it --rm hello -H
运行结果:

使用MySQL容器
启动服务器
启动服务器,并查看是否启动成功。
# sudo docker run -p 3306:3306 --name mysql2 -e MYSQL_ROOT_PASSWORD=root -d mysql:5.7
# docker ps
运行结果:

启动 MySQL 客户端
首先输入命令启动容器内 sh 进程,
# docker run -it --net host mysql:5.7 "sh"
进入到docker命令行下运行以下命令即可启动MySQL客户端。
# mysql -h127.0.0.1 -P3306 -uroot -proot
运行结果:

mysql 客户端基本操作
接下来执行一些mysql的基本命令测试一下,首先创建一个名为test的数据库,然后使用该数据库。在这个数据库下我创建了两个表userinfo和userdetail。
create database test;
use test;
CREATE TABLE `userinfo` (
`uid` INT(10) NOT NULL AUTO_INCREMENT,
`username` VARCHAR(64) NULL DEFAULT NULL,
`departname` VARCHAR(64) NULL DEFAULT NULL,
`created` DATE NULL DEFAULT NULL,
PRIMARY KEY (`uid`)
);
CREATE TABLE `userdetail` (
`uid` INT(10) NOT NULL DEFAULT '0',
`intro` TEXT NULL,
`profile` TEXT NULL,
PRIMARY KEY (`uid`)
)
运行结果:



挂载卷保存db
查看数据库文件
# docker exec -it mysql2 bash
进入到docker命令行输入以下命令:
/# ls /var/lib/mysql
运行结果:

Dockerfile 的 VOLUME /var/lib/mysql 的含义
# docker container prune -f
# docker volume prune –f
# docker volume ls
运行结果:



创建卷并挂载
# docker rm $(docker ps -a -q) -f -v
# docker volume create mydb
# docker run --name mysql2 -e MYSQL_ROOT_PASSWORD=root -v mydb:/var/lib/mysql -d mysql:5.7
运行结果:

启动客户端容器链接服务器
# docker run --name myclient --link mysql2:mysql -it mysql:5.7 bash
启动bash命令后,输入env查看环境变量,
/# env
然后启动mysql客户端链接到服务器。
/# mysql -hmysql -P3306 -uroot -proot


四、总结
本次实验学习了如何安装Docker,也尝试了一些Docker的基本操作命令。最后还学习了使用Docker容器化的方式启动MySQL,并且也能启动成功,使用上也没有问题。这次的实验只是个入门,希望以后需要使用到的时候能够更加深入地进行学习。
本文详细介绍了Docker的安装配置过程,包括环境搭建、基本操作及常见镜像使用。重点演示了如何利用Docker容器化MySQL,涵盖镜像拉取、服务器启动、客户端连接及数据库操作等关键步骤。
288

被折叠的 条评论
为什么被折叠?



