docker没有下载完全_会用Docker的人都别装了,这多简单呐

f14b08e02d1f80faf7dc4d4bc2908d23.png

学术又官方的说法

Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器或Windows 机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。

没用过的人能看懂这段话?

还是要自己动手。

试用完感受

试用了一下,就是下载运行官方制作的MySQL镜像,没自建镜像仓库,没制作镜像,用完觉得功能像是yum外加微型vmware。

docker就是安装自带ENV软件包的yum

73ecabcf8fd1ab4ca39d4b1089010002.png

左边的MySQL启动后,和服务器环境互相作用,像把一个新生儿放在了混合病房。

右边的MySQL启动后,自带一套环境变量,和服务器环境互不影响,像把一个新生儿放进了保温箱,保温箱有自己的温度湿度氧气,保温箱再放进病房里。

像yum

我们想安装某个软件,直接yum install 软件,如果yum源服务器有安装包,自动就安装上了,然后启动软件开始工作。

docker方式类似的,我们想使用某个软件并且要求它以docker方式运行,那么先要docker search命令看docker仓库(官方仓库有大量软件镜像可以直接使用)是否有该软件的镜像,

9b69e0214341f5cfe9cb7158beccc076.png

有的话先将镜像pull到本地,然后run镜像,软件就开始工作了。这些镜像具有Build once,Run anyWhere的优势,和java机制很像。run起来的镜像被称作容器container,查看镜像用docker images命令,查看容器用docker ps命令。

像vmware

微型vmware是指,docker启动某个软件的镜像后,就相当于启动的这个软件,不同的是这个软件仿佛运行在一个和操作系统隔离的环境中,这个环境有自己的环境变量,并且它的环境变量不影响操作系统,只对本镜像内的软件有效,就好像每个软件都运行在各自的vmware虚拟机中,虚拟机之间互不影响。例如同一操作系统中有docker MySQL(docker启动的MySQL镜像)和docker nginx两个进程在工作,两个进程完全互不干涉,MySQL运行在给它配置好的环境里,nginx运行在给它配置好的环境里,一个的死活和变化和另一个无关,也和操作系统无关。

说容易,我做一遍试试

安装Docker

下载libcgroup

搜索“libcgroup rpm” 。 RedHat系统就选择centos的安装包,下载

libcgroup-0.41-21.el7.x86_64.rpm。ftp上传到Redhat服务器。

534a38aeed241cc10e736e6fb1df4a70.png

安装libcgroup

[root@bogon dockerab]# rpm -ivh libcgroup-0.41-21.el7.x86_64.rpm 
Preparing...                          ################################# [100%]
Updating / installing...
1:libcgroup-0.41-21.el7            ################################# [100%]

下载docker包

[root@basicserver dockertest]# wget https://get.docker.com/rpm/1.7.1/centos-6/RPMS/x86_64/docker-engine-1.7.1-1.el6.x86_64.rpm
--2020-06-17 08:34:52--  https://get.docker.com/rpm/1.7.1/centos-6/RPMS/x86_64/docker-engine-1.7.1-1.el6.x86_64.rpm
Resolving get.docker.com... 99.86.193.96, 99.86.193.12, 99.86.193.128, ...
Connecting to get.docker.com|99.86.193.96|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: 4762280 (4.5M) [binary/octet-stream]
Saving to: docker-engine-1.7.1-1.el6.x86_64.rpm16% [============>                                                                    ] 801,777     35.5K/s  eta 1m 49s

安装docker

[root@basicserver dockertest]# rpm -ivh docker-engine-1.7.1-1.el6.x86_64.rpm
Preparing...                ########################################### [100%]1:docker-engine          ########################################### [100%]

启动docker服务

[root@basicserver dockertest]# service docker start
Starting cgconfig service:                                 [  OK  ]
Starting docker:                                           [  OK  ]

起个MySQL

Docker启动了,相当于有了yum命令而已。yum当然要用来安装各种软件啦。

查看仓库是否有MySQL

类似yum search命令,

[root@basicserver dockertest]# docker search mysql
NAME                              DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED
mysql                             MySQL is a widely used, open-source relati...   9634      [OK]       
mariadb                           MariaDB is a community-developed fork of M...   3500      [OK]

下载MySQL镜像到本地

[root@basicserver dockertest]# docker pull mysql
latest: Pulling from mysql
8011c293a399: Downloading [>                                                  ] 277.6 kB/27.1 MB
2455a1403f59: Download complete 
2f535805fb57: Download complete 
ebf295599c35: Downloading [=========>                                         ] 768.5 kB/4.178 MB

如果网络不好,需要等待时间较长,并且报错退出的话要反复执行docker pull mysql,直至下载成功。成功后会打印下面语句。

Digest: sha256:0648b8559643d01be3bfb0210ead5fdcb9a99ff7a6a1d5cb881bbd1f7f7b11bc
Status: Downloaded newer image for mysql:latest

查看镜像

[root@basicserver dockertest]# docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             VIRTUAL SIZE
mysql               latest              9cd0a11a66df        7 days ago          540.6 MB

看到MySQL镜像下载成功。

启动MySQL镜像

启动命令各个参数含义略。

[root@bogon ~]# docker run -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql
54fc423d7b42db8151e8fe916e33e6e0b0f5fd62fc4a455950f26d6a956a97e3

查看容器

理解成ps -ef | grep mysqld吧

[root@bogon ~]# docker ps
CONTAINER ID        IMAGE               COMMAND                CREATED             STATUS              PORTS                               NAMES
54fc423d7b42        mysql               "docker-entrypoint.s   8 seconds ago       Up 6 seconds        33060/tcp, 0.0.0.0:3306->3306/tcp   backstabbing_ptolemy

执行sql

redhat没安装连MySQL的工具,没法测试。如果有,不用进入容器,在redhat环境就可以访问数据库。

现在只能容器内试试了。docker exec进入容器,需要用到上面的CONTAINER ID,进入后可以查看容器的文件系统和环境变量。

[root@bogon ~]# docker exec -it 54fc423d7b42 bash

成功进入MySQL 容器,连接数据库试试

root@54fc423d7b42:/# mysql -uroot -p123456
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or g.
Your MySQL connection id is 8
Server version: 8.0.20 MySQL Community Server - GPLCopyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved.Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.Type 'help;' or 'h' for help. Type 'c' to clear the current input statement.mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
4 rows in set (0.00 sec)mysql>

到此就能使用MySQL了。如果直接安装MySQL遇到的问题可能很多,最顺利的情况也就和刚才一样吧!并且每台服务器都要解决不一样的问题,现在就能初步感受到docker的方便之处了。

容器内外环境对比

051734b0010b766bf1d1d74d57625213.png

看看容器内环境变量,变量很少

root@54fc423d7b42:/# env  
MYSQL_MAJOR=8.0
HOSTNAME=54fc423d7b42
PWD=/
MYSQL_ROOT_PASSWORD=123456
HOME=/root
MYSQL_VERSION=8.0.20-1debian10
GOSU_VERSION=1.12
SHLVL=1
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
_=/usr/bin/env

看文件系统就ls cd就可以了

退出容器,回到操作系统,查看环境变量

root@54fc423d7b42:/# exit
exit
[root@bogon ~]# env    #操作系统的环境变量
XDG_SESSION_ID=1
HOSTNAME=bogon
SELINUX_ROLE_REQUESTED=
TERM=vt100
SHELL=/bin/bash
HISTSIZE=1000
SSH_CLIENT=192.168.56.1 49661 22
SELINUX_USE_CURRENT_RANGE=
SSH_TTY=/dev/pts/0
USER=root
LS_COLORS=rs=0:di=01;34:....
SSH_AUTH_SOCK=/tmp/ssh-gSRfCMVd4x/agent.3732
MAIL=/var/spool/mail/root
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin
PWD=/root
LANG=en_US.UTF-8
SELINUX_LEVEL_REQUESTED=
HISTCONTROL=ignoredups
SHLVL=1
HOME=/root
LOGNAME=root
SSH_CONNECTION=192.168.56.1 49661 192.168.56.106 22
LESSOPEN=||/usr/bin/lesspipe.sh %s
XDG_RUNTIME_DIR=/run/user/0
_=/usr/bin/env

完全是两个世界,主环境没有一点安装过MySQL的痕迹,而这个服务器却实实在在的有MySQL的功能。

一些坑

  1. 遇到报错
Cannot connect to the Docker daemon. Is 'docker -d' running on this host?

,重启docker

[root@basicserver dockertest]# service docker stop    直接restart也可
[root@basicserver dockertest]# service docker start
  1. radhat7需要先安装libcgroup,然后安装docker的rpm包才能成功。
  2. redhat6无法运行本文版本的docker,当docker run时报错。所以如果安装本文版本的docker,Redhat版本要7以及更高。
[root@basicserver dockertest]# docker run mysql #Redhat6 run不起来
FATAL: kernel too old

总结

谁再说不会用docker,非要一步一步配环境,装软件,就问他,“你会用yum吗?”

话说回来,刚开始用总感觉不踏实,和系统隔了一层,不如直接安装的东西手感好。

出处:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/293148.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

WPF MVVM实例三

在没给大家讲解wpf mwm示例之前先给大家简单说下MVVM理论知识:WPF技术的主要特点是数据驱动UI,所以在使用WPF技术开发的过程中是以数据为核心的,WPF提供了数据绑定机制,当数据发生变化时,WPF会自动发出通知去更新UI。我们使用模式…

stringcstdlibctimecstdargctimectypecmathclimits

转载地址&#xff1a;http://blog.csdn.net/kz_ang/article/details/7767335 <string>头文件 string构造函数 string s  生成一个空字符串s string s(str)  拷贝构造函数,生成str对象的复制品 string s(str,stridx)  将字符串str对象内"始于位置stridx"…

C3P0 释放连接 的问题

2019独角兽企业重金招聘Python工程师标准>>> 记录一下使用C3P0 时犯的低级错误&#xff0c;没有关闭connection 达到连接池最大限制后造成程序假死的现象&#xff0c;以后得仔细再仔细了&#xff01; 转载于:https://my.oschina.net/fusxian/blog/146700

python随机抽取人名_python的random

python的random函数更多的random用法可参阅&#xff1a;random --- 生成伪随机数 - Python 3.7.4 文档​docs.python.org以下使用了&#xff1a;洗牌&#xff1a;random.shuffle随机抽取元素&#xff0c;且元素不重复&#xff1a;random.sample随机抽取元素&#xff0c;且元素可…

Windows 11/10 正式版全新 ISO 镜像下载

微软现已发布 Windows 11/10 正式版&#xff08;版本 21H2&#xff09;全新 ISO 镜像。Windows 11 版本 21H2 全新镜像集成了 2021 年 10 月更新、11 月更新和 12 月更新。Windows 10 版本 21H2 全新镜像集成了 2021 年 11 月更新和 12 月更新。版本区别Windows 11/10 消费者版…

java web filter 之一 基础实现

本文主要对filter的基本使用进行了讲解&#xff0c;其中涉及到了 filter是什么 一个filter处理一个jsp 多个filter处理一个jsp filter是什么 Filter 是java下的一种过滤器 &#xff0c;能实现对java web程序 客户端和服务器端消息的过滤&#xff0c;也就是在服务器段接受reques…

eclipse索引4超出范围_Python内置的4个重要基本数据结构:列表、元组、字典和集合

本章内容提要&#xff1a;列表及操作元组及操作字典及操作集合简介第2章介绍了数字(整数、浮点数)、逻辑值和字符串等Python内置的基本数据类型。在实际的操作中&#xff0c;仅仅依赖它们很难高效地完成复杂的数据处理任务。基于对基本数据类型的构建&#xff0c;Python拓展出列…

.NET 6 中 System.Text.Json 的新特性

1支持忽略循环引用在 .NET 6 之前&#xff0c;如果 System.Text.Json 检测到循环引用&#xff0c;就会抛出 JsonException 异常。在 .NET 6 中&#xff0c;你可以忽略它们。Category dotnet new() {Name ".NET 6", }; Category systemTextJson new() {Name "…

Java基础知识回顾--线程

基本概念 线程是一个程序内部的顺序控制流 Java的线程是通过java.lang.Thread类来实现的。main函数是一个主线程&#xff0c;用户可以通过创建Thread的实例来创建新的线程。每一个线程都必须实现run方法。通过Thread类的start方法来启动一个线程。 两种方式实现&#xff0c;一…

四、物理优化(1)范式化

一、范式化的概念范式化&#xff08;Normalization&#xff09;的目标是消除数据冗余&#xff0c;减小物理存储空间。常用的范式有以下3种&#xff1a;1. 第一范式&#xff08;1NF&#xff09;在任何一个关系数据库中&#xff0c;1NF是对关系模式的基本要求&#xff0c;不满足1…

​如何在图书馆收获一段爱情?​

1 你为什么不喜欢拍照片&#xff08;素材来源网络&#xff0c;侵删&#xff09;▼2 当登记处挂起横幅▼3 这几天老是犯的错误▼4 在图书馆收获的爱情&#xff08;素材来源网络&#xff0c;侵删&#xff09;▼5 当老师用键盘讲课&#xff08;素材来源网络&#xff0c;侵删&a…

MongoDB服务无法启动,原因居然是...

前言某台CentOS服务器上的MongoDB服务突然停止运行&#xff0c;于是登上去排查原因&#xff0c;接下来就是苦逼的爬坑之旅。爬坑记录1、重启服务使用systemctl命令重启服务&#xff1a;systemctl restart mongod.service查看系统日志&#xff1a;journalctl -ex只是提示启动失败…

python绘制饼图双层_有趣!如何用Python-matplotlib绘制双层饼图及环形图?

&#xff08;1&#xff09; 饼图&#xff08;pie&#xff09;&#xff0c;即在一个圆圈内分成几块&#xff0c;显示不同数据系列的占比大小&#xff0c;这也是我们在日常数据的图形展示中最常用的图形之一。 在python中常用matplotlib的pie来绘制&#xff0c;基本命令如下所示&…

C# 获取Excel中的合并单元格

C# 获取Excel中的合并单元格 我们在制作表格时&#xff0c;有时经常需要合并及取消合并一些单元格。在取消合并单元格时需要逐个查找及取消&#xff0c;比较麻烦。这里分享一个简单的方法来识别Excel中的合并单元格&#xff0c;识别这些合并单元格之后对这些单元格进行取消合并…

SQL Server 解读【已分区索引的特殊指导原则】(3) - 非聚集索引分区

一、前言 在MSDN上看到一篇关于SQL Server 表分区的文档&#xff1a;已分区索引的特殊指导原则&#xff0c;如果你对表分区没有实战经验的话是比较难理解文档里面描述的意思。这里我就里面的一些概念进行讲解&#xff0c;方便大家的交流。 SQL Server 解读【已分区索引的特殊指…

Android之SharedPreferences 存储复杂对象

用SharedPreferences存储一些常用的设置信息很方便&#xff0c;但是我们知道SharedPreferences只能存储一些简单的类型 如何用SharedPreferences来存储一些复杂的对象&#xff1f;下面以map为例&#xff0c;看看SharedPreferences 存储复杂对象的方法 如果想用SharedPreference…