ToB企服应用市场:ToB评测及商务社交产业平台

标题: Docker 镜像使用和安装 [打印本页]

作者: 宝塔山    时间: 2024-8-14 17:27
标题: Docker 镜像使用和安装

1、简介

Docker是一个开源的应用容器引擎;是一个轻量级容器技术;
Docker支持将软件编译成一个镜像;然后在镜像中各种软件做好配置,将镜像发布出去,其他使用者可以直接使用这个镜像;
运行中的这个镜像称为容器,容器启动是非常快速的。

镜像的原理:

2、Docker的核心概念



比方你下载了一个QQ,如果我们将QQ在磁盘上的运行文件及其运行的操作体系依靠打包,形成QQ镜像。然后你可以启动多次,双开、乃至三开QQ。

3:使用Docker的步骤:


4:安装Docker

4.1:安装假造机

我的另一篇博客介绍的非常详细,请参考:
LInux操作详解一:vmware安装linux体系以及网络配置_vmware 安装linuxz
4.2:在linux假造机上安装docker

步骤:
  1. 1、检查内核版本,必须是3.10及以上
  2. uname -r
  3. 2、安装docker
  4. yum install docker
  5. 3、输入y确认安装
  6. 4、启动docker
  7. [root@localhost ~]# systemctl start docker
  8. //查看版本
  9. [root@localhost ~]# docker -v
  10. Docker version 1.12.6, build 3e8e77d/1.12.6
  11. 5、开机启动docker
  12. [root@localhost ~]# systemctl enable docker
  13. Created symlink from /etc/systemd/system/multi-user.target.wants/docker.service to /usr/lib/systemd/system/d
  14. ocker.service.
  15. 6、停止docker
  16. systemctl stop docker
复制代码
5:镜像操作以及下令

操作下令说明检索docker search 关键字; eg:docker search redis我们经常去docker hub上检索镜像的详细信息,如镜像的TAG。就是取https://hub.docker.com/上找拉取docker pull 镜像名:tag:tag是可选的,tag表示标签,多为软件的版本,默认是latest,最新的;如:docker pull mysql:5.6列表docker images检察全部本地镜像删除docker rmi image-id删除指定的本地镜像

0:镜像名称构成

首先来看下镜像的名称构成:

1:找寻镜像 - docker search tomcat

首先去镜像仓库搜索nginx镜像,比如DockerHub

或者直接在docker 下令中检察

2:拉取镜像 - docker pull mysql


3:检察本地镜像 - docker images


4:删除镜像 - docker rmi [镜像id]


5:镜像的保存和导入-docker save 和 docker load

在Docker中,我们可以通过一对操作:导出镜像(docker save)和导入镜像(docker load),来处理Docker镜像。这个操作会将全部的镜像层以及元数据打包到一个tar文件中,然后可以使用docker load下令将这个tar文件导入到任何Docker情况中。这种方式主要用于分享或迁移整个镜像,包括全部版本、标签和汗青。

  1. docker save -o [保存的目标文件名称] [镜像名称]
复制代码
其中,-o选项用于指定输出文件,比方:
  1. docker save -o nginx.tar nginx:latest
复制代码


  1. docker load -i [保存的目标文件名称]
复制代码
其中,—input选项用于指定导入的文件,代替STDIN。比方:
  1. docker load -i nginx.tar
复制代码


   假设你在你的开发情况中创建了一个新的Docker镜像,这个镜像包含了你的应用和全部依靠项,并且已经测试了这个镜像,打了一个标签,称其为“myapp:1.0”。现在你想要将这个镜像移到生产情况。这个场景中,你应该使用docker save和docker load下令。具体操作如下:在开发情况中,运行docker save -o myapp_1.0.tar myapp:1.0。这将创建一个名为“myapp_1.0.tar”的tar文件,其中包含了“myapp:1.0”镜像的全部层和元数据。你可以将这个tar文件复制到你的生产情况,然后在那里运行docker load -i myapp_1.0.tar。这将导入“myapp:1.0”镜像,你可以立即在生产情况中使用它。
  6:容器操作

软件镜像(QQ安装程序)----运行镜像----产生一个容器(正在运行的软件,运行的QQ);

1:容器保护三个状态:


2:容器操作下令

1:根据镜像启动容器 docker run

  1. docker run -itd -p 8080:8080 --name mytomcat  tomcat:latest
复制代码

默认情况下,容器是隔离情况,我们直接访问宿主机的80端口,肯定访问不到容器中的nginx。
现在,将容器的80与宿主机的80关联起来,当我们访问宿主机的80端口时,就会被映射到容器的80,如许就能访问到nginx了:

2:检察运行中的容器 docker ps

  1. docker ps [-a]
复制代码

3:启动容器 docker start

  1. docker start 容器id
复制代码
4:制止运行中的容器 docker stop

  1. docker stop  容器的id
复制代码
5:删除一个容器 docker rm

  1. docker rm  [-f]  容器id
复制代码

6:检察容器的日志 docker logs

  1. docker logs [-f] 容器名或者容器id
复制代码

注:

3:docker操作镜像-以mysql为例

当安装一个新的镜像时可以登录https://hub.docker.com/直接搜索想要安装的镜像,检察文档
1:拉取镜像

  1. docker pull mysql   或者 docker pull mysql:版本号
复制代码
2:错误的启动

  1. docker run --name mysql01 -d mysql
复制代码
这个只是默认的启动方式,每一个镜像都有本身的配置,记得检察文档
3:精确的启动

按照文档上举行启动
  1. docker run --name mysql01 -e MYSQL_ROOT_PASSWORD=123456 -d mysql
复制代码

启动成功了,但是访问不了,因为没有与主机所在做映射
制止并删除容器:

4:做了端口映射的精确启动

  1. docker run -p 3306:3306 --name mysql01 -e MYSQL_ROOT_PASSWORD=123456 -d mysql
复制代码
5:几个高级操作

  1. docker run --name mysql03 -v /conf/mysql:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag
  2. 把主机的/conf/mysql文件夹挂载到 mysqldocker容器的/etc/mysql/conf.d文件夹里面
  3. 改mysql的配置文件就只需要把mysql配置文件放在自定义的文件夹下(/conf/mysql)
  4. docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
  5. 指定mysql的一些配置参数
复制代码
6:mysql远程连接需要密码加密


4:进入容器,修改文件

1:进入容器的情况

docker exec -it [容器id或名称] bash (每个人创建的container ID都不一样)

2:进入mysql的下令窗口

容器内部会模拟一个独立的Linux文件体系,以是按照linux正常操作就行
mysql --user=root --password
3:将密码加密

ALTER USER ‘root’ IDENTIFIED WITH mysql_native_password BY ‘1234567’;
5:挂载数据卷

​什么是数据卷

数据卷(volume) 是一个假造目录,指向宿主机文件体系中的某个目录。

一旦完成数据卷挂载,对容器的一切操作都会作用在数据卷对应的宿主机目录了。
如许,我们操作宿主机的/var/lib/docker/volumes/html目录,就即是操作容器内的/usr/share/nginx/html目录了
数据集操作下令

  1. docker volume [COMMAND]
复制代码
docker volume下令是数据卷操作,根据下令后跟随的command来确定下一步的操作:

  1. docker volume create:创建数据卷
  2. docker volume ls:查看所有数据卷
  3. docker volume inspect:查看数据卷详细信息,包括关联的宿主机目录位置
  4. docker volume rm:删除指定数据卷
  5. docker volume prune:删除所有未使用的数据卷
复制代码
挂载数据卷

  1. docker run --name mn -v html:/usr/share/nginx/html -p 80:80 -d nginx
复制代码

挂载本地目录

容器不仅仅可以挂载数据卷,也可以直接挂载到宿主机目录上。关联关系如下:

  1. 实现思路如下:
  2. 拉取Mysql镜像(这里使用的是5.7.25版本)
  3. 创建目录/tmp/mysql/data
  4. 创建目录/tmp/mysql/conf,将自己的hmy.cnf文件上传到/tmp/mysql/conf
  5. 去DockerHub查阅资料,创建并运行MySQL容器,要求:
  6.         挂载/tmp/mysql/data到mysql容器内数据存储目录
  7.         挂载/tmp/mysql/conf/hmy.cnf到mysql容器的配置文件
  8. 命令:
  9. docker run \
  10.   --name mymysql \
  11.   -e MYSQL_ROOT_PASSWORD=XXXXXXXXXX \
  12.   -p 3306:3306 \
  13.   -v /tmp/mysql/conf/hmy.cnf:/etc/mysql/conf.d/hmy.cnf \
  14.   -v /tmp/mysql/data:/var/lib/mysql \
  15.   -d mysql:5.7.25
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4