會用Docker的人都別裝了,這多簡單吶

學術又官方的說法

Docker 是一個開源的應用容器引擎,讓開發者能夠打包他們的應用以及依賴包到一個可移植的容器中,而後發佈到任何流行的Linux機器或Windows 機器上,也能夠實現虛擬化,容器是徹底使用沙箱機制,相互之間不會有任何接口。java

沒用過的人能看懂這段話?
用過的人爲何要看這段話?

仍是要本身動手。mysql

試用完感覺

試用了一下,就是下載運行官方製做的MySQL鏡像,沒自建鏡像倉庫,沒製做鏡像,用完以爲功能像是yum外加微型vmware。nginx

docker就是安裝自帶ENV軟件包的yum


左邊的MySQL啓動後,和服務器環境互相做用,像把一個新生兒放在了混合病房。
右邊的MySQL啓動後,自帶一套環境變量,和服務器環境互不影響,像把一個新生兒放進了保溫箱,保溫箱有本身的溫度溼度氧氣,保溫箱再放進病房裏。sql

像yum

咱們想安裝某個軟件,直接yum install 軟件,若是yum源服務器有安裝包,自動就安裝上了,而後啓動軟件開始工做。
docker方式相似的,咱們想使用某個軟件而且要求它以docker方式運行,那麼先要docker search命令看docker倉庫(官方倉庫有大量軟件鏡像能夠直接使用)是否有該軟件的鏡像,

有的話先將鏡像pull到本地,而後run鏡像,軟件就開始工做了。這些鏡像具備Build once,Run anyWhere的優點,和java機制很像。run起來的鏡像被稱做容器container,查看鏡像用docker images命令,查看容器用docker ps命令。docker

像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服務器。
centos

安裝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固然要用來安裝各類軟件啦。bash

查看倉庫是否有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 - GPL

Copyright (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的方便之處了。

容器內外環境對比

image

看看容器內環境變量,變量不多

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嗎?」 話說回來,剛開始用總感受不踏實,和系統隔了一層,不如直接安裝的東西手感好。

相關文章
相關標籤/搜索