还用说么?会用Docker的人都别装了,这多简单呐 - 新闻资讯 - 云南小程序开发|云南软件开发|云南网站建设-昆明葵宇信息科技有限公司

159-8711-8523

云南网建设/小程序开发/软件开发

知识

不管是网站,软件还是小程序,都要直接或间接能为您产生价值,我们在追求其视觉表现的同时,更侧重于功能的便捷,营销的便利,运营的高效,让网站成为营销工具,让软件能切实提升企业内部管理水平和效率。优秀的程序为后期升级提供便捷的支持!

您当前位置>首页 » 新闻资讯 » 技术分享 >

还用说么?会用Docker的人都别装了,这多简单呐

发表时间:2020-10-19

发布人:葵宇科技

浏览次数:26

学术又官方的说法

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

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

还是要自己动手。

由于平台不能直接发送学习资料等原因,有需要学习Docker的朋友们只需要评论+转发+关注,并且扫描下方小编二维码即可免费获取PDF学习笔记以及往期的面试题合集!!!

试用完感受

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

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

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

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

像yum

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

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

有的话先将镜像pull到本地,然后run镜像,软件就开始工作了。这些镜像具有Build src="https://img-blog.csdnimg.cn/img_convert/13e6ad35a014b48455689c4b0024a210.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.rpm

16% [============>                                                                    ] 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 src="https://img-blog.csdnimg.cn/img_convert/62d5c06092fda4899ef91c308a460d0d.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>[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吗?”

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

由于平台不能直接发送学习资料等原因,有需要学习Docker的朋友们只需要评论+转发+关注,并且扫描下方小编二维码即可免费获取PDF学习笔记以及往期的面试题合集!!!