学术又官网的说法

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

没用过的人能看懂这段话?
用过的人为什么要看这段话?

还是要本人入手。

试用完感触

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

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


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

像yum

咱们想装置某个软件,间接yum install 软件,如果yum源服务器有安装包,主动就装置上了,而后启动软件开始工作。
docker形式相似的,咱们想应用某个软件并且要求它以docker形式运行,那么先要docker search命令看docker仓库(官网仓库有大量软件镜像能够间接应用)是否有该软件的镜像,

有的话先将镜像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服务器。

装置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.rpmResolving 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 OKLength: 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.rpmPreparing...                ########################################### [100%]   1:docker-engine          ########################################### [100%]

启动docker服务

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

起个MySQL

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

查看仓库是否有MySQL

相似yum search命令,

[root@basicserver dockertest]# docker search mysqlNAME                              DESCRIPTION                                     STARS     OFFICIAL   AUTOMATEDmysql                             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 mysqllatest: Pulling from mysql8011c293a399: Downloading [>                                                  ] 277.6 kB/27.1 MB2455a1403f59: Download complete 2f535805fb57: Download complete ebf295599c35: Downloading [=========>                                         ] 768.5 kB/4.178 MB

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

Digest: sha256:0648b8559643d01be3bfb0210ead5fdcb9a99ff7a6a1d5cb881bbd1f7f7b11bcStatus: Downloaded newer image for mysql:latest

查看镜像

[root@basicserver dockertest]# docker imagesREPOSITORY          TAG                 IMAGE ID            CREATED             VIRTUAL SIZEmysql               latest              9cd0a11a66df        7 days ago          540.6 MB

看到MySQL镜像下载胜利。

启动MySQL镜像

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

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

查看容器

了解成ps -ef | grep mysqld吧

[root@bogon ~]# docker psCONTAINER ID        IMAGE               COMMAND                CREATED             STATUS              PORTS                               NAMES54fc423d7b42        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 -p123456mysql: [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 8Server 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 itsaffiliates. Other names may be trademarks of their respectiveowners.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的不便之处了。

容器内外环境比照

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

root@54fc423d7b42:/# env  MYSQL_MAJOR=8.0HOSTNAME=54fc423d7b42PWD=/MYSQL_ROOT_PASSWORD=123456HOME=/rootMYSQL_VERSION=8.0.20-1debian10GOSU_VERSION=1.12SHLVL=1PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin_=/usr/bin/env

看文件系统就ls cd就能够了

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

root@54fc423d7b42:/# exitexit[root@bogon ~]# env    #操作系统的环境变量XDG_SESSION_ID=1HOSTNAME=bogonSELINUX_ROLE_REQUESTED=TERM=vt100SHELL=/bin/bashHISTSIZE=1000SSH_CLIENT=192.168.56.1 49661 22SELINUX_USE_CURRENT_RANGE=SSH_TTY=/dev/pts/0USER=rootLS_COLORS=rs=0:di=01;34:....SSH_AUTH_SOCK=/tmp/ssh-gSRfCMVd4x/agent.3732MAIL=/var/spool/mail/rootPATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/binPWD=/rootLANG=en_US.UTF-8SELINUX_LEVEL_REQUESTED=HISTCONTROL=ignoredupsSHLVL=1HOME=/rootLOGNAME=rootSSH_CONNECTION=192.168.56.1 49661 192.168.56.106 22LESSOPEN=||/usr/bin/lesspipe.sh %sXDG_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吗?”
话说回来,刚开始用总感觉不虚浮,和零碎隔了一层,不如间接装置的货色手感好。