文章目录
玩转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,并且也能启动成功,使用上也没有问题。这次的实验只是个入门,希望以后需要使用到的时候能够更加深入地进行学习。