服务计算-玩转Docker

玩转Docker

一、准备Docker环境

安装
设置存储库
  1. 安装所需的软件包。yum-utils提供了yum-config-manager 效用,并device-mapper-persistent-data和lvm2由需要 devicemapper存储驱动程序。
$ sudo yum install -y yum-utils device-mapper-persistent-data lvm2
  1. 使用以下命令来设置稳定的存储库。
$ 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,并且也能启动成功,使用上也没有问题。这次的实验只是个入门,希望以后需要使用到的时候能够更加深入地进行学习。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值