关于docker:看完此文妈妈还会担心你Docker入不了门

2次阅读

共计 4604 个字符,预计需要花费 12 分钟才能阅读完成。

大家好,我是阿壮,一个有代码洁癖的程序员,集体网站:jonssonyan.com

当初很多企业都在上云,Docker 无疑是云时代的宠儿,像 MySQL,Redis 都能够部署在 Docker 中,从而不便咱们去治理,而且移植性强,打包成镜像,在任何一个装置了 Docker 的服务器上都能够运行。上面介绍 Docker 的装置,根底概念,常用命令,在 Docker 上部署 MySQL Redis,以及打包 jar 包并运行。

什么是 Docker?

Docker 翻译过去就是码头工人,是一个开源的利用容器引擎,基于 Go 语言。Docker 能够让开发者打包他们的利用以及依赖包到一个轻量级、可移植的容器中,而后公布到任何风行的 Linux 机器上,也能够实现虚拟化。容器是齐全应用沙箱机制,相互之间不会有任何接口(相似 iPhone 的 app), 更重要的是容器性能开销极低。

Linux 下装置 Docker

卸载旧版本

yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine

装置 yum-utils 软件包(提供 yum-config-manager 实用程序)

yum install -y yum-utils

设置稳固的存储库(应用阿里云镜像)

yum-config-manager \
    --add-repo \
    http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

更新缓存

yum makecache fast

装置最新版本的 Docker Engine 和容器,或转到下一步以装置特定版本

yum install docker-ce docker-ce-cli containerd.io

启动 Docker

systemctl start docker

配置 Docker

Docker 默认的镜像源于国内而言是有些慢,所以能够配置一下国内的镜像源,进步一下 pull 速度

阿里云镜像服务参考:https://cr.console.aliyun.com…

创立目录

mkdir -p /etc/docker

创立一个镜像配置文件

vi /etc/docker/daemon.json

配置文件中增加镜像

{"registry-mirrors":["http://hub-mirror.c.163.com"]
}

从新加载文件并重启 docker

systemctl daemon-reload // 从新加载文件
systemctl restart docker // 重启 docker
systemctl enable docker // 开机自启

一些其余的减速站点

https://registry.docker-cn.com
http://hub-mirror.c.163.com
https://mirror.ccs.tencentyun.com

卸载 Docker

卸载 Docker Engine,CLI 和 Containerd 软件包

yum remove docker-ce docker-ce-cli containerd.io

主机上的映像,容器,卷或自定义配置文件不会主动删除。要删除所有图像,容器和卷

rm -rf /var/lib/docker

常用命令

镜像指令

docker images // 查看 Docker 中以后领有哪些镜像
docker image MySQL // 查问指定镜像名
docker pull MySQL:5.7 // 下载镜像
docker search MySQL // 搜寻一下镜像有哪些版本
docker image rm MySQL:5.5 // 删除镜像
docker image rm bf756fb1ae65 // 通过指定镜像 id 进行删除
docker image rm -f bf756fb1ae65 // 如果删除的镜像正在运行中,此时须要强制执行删除
docker rmi -f $(docker images MySQL -q) // 借助 rmi 和 - p 进行一些联合操作,比方当初想删除所有的 MySQL 镜像

容器指令

docker run tomcat:8.0-jre8 // 通过镜像运行一个容器
docker ps // 查看以后运行的容器
docker run -p 8080:8080 tomcat:8.0-jre8 // 对宿主机端口与容器内的端口进行映射
docker run -d -p 8080:8080 --name tomcat01 tomcat:8.0-jre8 // 后盾的形式运行,并设置容器名称
docker ps -a // 列举运行和非运行的容器
docker start c2f5d78c5d1a // 启动容器
docker restart c2f5d78c5d1a // 重启容器
docker stop c2f5d78c5d1a // 进行容器
docker kill c2f5d78c5d1a // 间接杀死指定的容器
docker rm d5b6c177c151 // 删除容器
docker rm -f d5b6c177c151 // 强制删除容器
docker rm -f $(docker ps -qa) // 强制删除所有容器
docker logs 289cc00dc5ed // 查看容器的运行日志 应用 - f 参数显示实时日志 - t 参数还可能显示日志的工夫戳
docker top 289cc00dc5ed // 查看容器内运行了哪些过程
docker exec -it 289cc00dc5ed bash // 与容器进行交互 应用 exit 从容器内退出到宿主机
docker cp ./test.html 289cc00dc5ed:/usr/local/tomcat/webapps // 将文件从宿主机复制到容器中
docker inspect 923c969b0d91 // 查看容器外部具体的细节

数据卷指令

可能实现宿主机与容器之间的文件共享,它的益处在于咱们对宿主机的文件进行批改将间接影响容器,而无需再将宿主机的文件再复制到容器中。

若是想将宿主机中 /opt/apps 目录与容器中 webapps 目录做一个数据卷,则应该这样编写指令

docker run -d -p 8080:8080 --name tomcat01 -v /opt/apps:/usr/local/tomcat/webapps tomcat:8.0-jre8

这就阐明咱们的数据卷设置胜利了,Docker 会将容器内的 webapps 目录与 /opt/apps 目录进行同步,而此时 /opt/apps 目录是空的,导致 webapps 目录也会变成空目录,所以就拜访不到了。

此时咱们只需向 /opt/apps 目录下增加文件,就会使得 webapps 目录也会领有雷同的文件,达到文件共享

docker run -d -p 8080:8080 --name tomcat01 -v aa:/usr/local/tomcat/webapps tomcat:8.0-jre8

此时的 aa 并不是数据卷的目录,而是数据卷的别名,Docker 会为咱们主动创立一个名为 aa 的数据卷,并且会将容器内 webapps 目录下的所有内容复制到数据卷中,该数据卷的地位在 /var/lib/docker/volumes 目录下

此时咱们只需批改该目录的内容就能可能影响到容器。

docker commit -m "形容信息" -a "镜像作者" tomcat01 my_tomcat:1.0 // 将容器打包成一个镜像
docker save my_tomcat:1.0 -o my-tomcat-1.0.tar // 将镜像备份进去
docker load -i my-tomcat-1.0.tar // 将.tar 格局的镜像,加载到 Docker 中

Docker 下装置 MySQL5.7.31

拉取 Mysql 5.7.31 镜像

docker pull mysql:5.7.31

运行 Mysql 5.7.31

docker run -d --name myMysql -p 9506:3306 -v /data/mysql:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7.31

参数解析:
-d: 后盾运行容器,并返回容器 ID
--name myMysql: 为容器指定一个名称
-p: 指定端口映射,格局为:主机(宿主) 端口: 容器端口
-v: 绑定一个卷,容器的 /var/lib/mysql 映射到 主机的目录 /data/mysql
-e MYSQL_ROOT_PASSWORD=123456: 设置环境变量,明码设置为 123456
mysql:5.7.31:应用镜像 mysql:5.7.31

批改数据库明码

  1. 此时运行 docker ps 能够看到容器正在运行

  1. 进入到容器命令
docker exec -it [容器 ID] /bin/bash
  1. 输出数据库账号密码命令
mysql -uroot -p
  1. 进入界面后更改 root 明码(123456 为我的新密码,此处明码由您决定)
update mysql.user set authentication_string=password('123456') where user='root' and Host = 'localhost';
  1. 刷新缓存
flush privileges;
  1. 退出 mysql
exit
  1. 而后重进 mysql,用批改后的明码登录

Dcoker 下装置 Redis

Redis Windows 版本:https://github.com/tporadowsk…

Redis 官网:https://redis.io/

AnotherRedisDesktopManager:https://github.com/qishibo/An…

装置命令

docker pull redis:latest
docker run -itd --name myRedis -p 6379:6379 redis --requirepass "123456"

如果在启动时遗记设置明码

docker exec -it myRedis redis-cli // 进入容器
config set requirepass 123456

将 jar 包做成 Docker 镜像,并运行

上传 jar 包文件和 Dockerfile 文件至服务器

Dockerfile 文件如下

FROM java:8
VOLUME /tmp
ADD jonsson-0.0.1-SNAPSHOT.jar jonsson.jar
EXPOSE 8888
ENTRYPOINT ["java","-jar","/jonsson.jar"]

解释:

  1. from java:8 拉取一个 jdk 为 1.8 的 docker image
  2. jonsson-0.0.1-SNAPSHOT.jar 就是你上传的 jar 包,替换为 jar 包的名称
  3. jonsson.jar 是你将该 jar 包重新命名为什么名称,在容器中运行
  4. expose 该容器裸露的端口是多少,就是 jar 在容器中以多少端口运行
  5. entrypoint 容器启动之后执行的命令,java -jar /jonsson.jar 即启动 jar

打包镜像

 docker build -t jonsson .

运行容器

docker run -d -p 8888:8888 --name jonsson-8888 jonsson

查看启动日志

docker logs -n 300 -f jonsson-8888

Reference

[1]《docker 从入门到实际》

[2]https://hub.docker.com/

我是阿壮,微信搜一搜:科技猫,关注这个有代码洁癖的程序员,咱们下期间

正文完
 0