Docker 是一個開源的應用容器引擎,讓開發者能夠打包他們的應用以及依賴包到一個可移植的容器中,而後發佈到任何流行的Linux機器或Windows 機器上,也能夠實現虛擬化,容器是徹底使用沙箱機制,相互之間不會有任何接口。java
沒用過的人能看懂這段話?
用過的人爲何要看這段話?
仍是要本身動手。mysql
試用了一下,就是下載運行官方製做的MySQL鏡像,沒自建鏡像倉庫,沒製做鏡像,用完以爲功能像是yum外加微型vmware。nginx
docker就是安裝自帶ENV軟件包的yum
左邊的MySQL啓動後,和服務器環境互相做用,像把一個新生兒放在了混合病房。
右邊的MySQL啓動後,自帶一套環境變量,和服務器環境互不影響,像把一個新生兒放進了保溫箱,保溫箱有本身的溫度溼度氧氣,保溫箱再放進病房裏。sql
咱們想安裝某個軟件,直接yum install 軟件,若是yum源服務器有安裝包,自動就安裝上了,而後啓動軟件開始工做。
docker方式相似的,咱們想使用某個軟件而且要求它以docker方式運行,那麼先要docker search命令看docker倉庫(官方倉庫有大量軟件鏡像能夠直接使用)是否有該軟件的鏡像,
有的話先將鏡像pull到本地,而後run鏡像,軟件就開始工做了。這些鏡像具備Build once,Run anyWhere的優點,和java機制很像。run起來的鏡像被稱做容器container,查看鏡像用docker images命令,查看容器用docker ps命令。docker
微型vmware是指,docker啓動某個軟件的鏡像後,就至關於啓動的這個軟件,不一樣的是這個軟件彷彿運行在一個和操做系統隔離的環境中,這個環境有本身的環境變量,而且它的環境變量不影響操做系統,只對本鏡像內的軟件有效,就好像每一個軟件都運行在各自的vmware虛擬機中,虛擬機之間互不影響。例如同一操做系統中有docker MySQL(docker啓動的MySQL鏡像)和docker nginx兩個進程在工做,兩個進程徹底互不干涉,MySQL運行在給它配置好的環境裏,nginx運行在給它配置好的環境裏,一個的死活和變化和另外一個無關,也和操做系統無關。數據庫
搜索「libcgroup rpm」 。 RedHat系統就選擇centos的安裝包,下載
libcgroup-0.41-21.el7.x86_64.rpm。ftp上傳到Redhat服務器。
centos
[root@bogon dockerab]# rpm -ivh libcgroup-0.41-21.el7.x86_64.rpm Preparing... ################################# [100%] Updating / installing... 1:libcgroup-0.41-21.el7 ################################# [100%]
[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
[root@basicserver dockertest]# rpm -ivh docker-engine-1.7.1-1.el6.x86_64.rpm Preparing... ########################################### [100%] 1:docker-engine ########################################### [100%]
[root@basicserver dockertest]# service docker start Starting cgconfig service: [ OK ] Starting docker: [ OK ]
Docker啓動了,至關於有了yum命令而已。yum固然要用來安裝各類軟件啦。bash
相似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]
[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鏡像下載成功。
啓動命令各個參數含義略。
[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
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的方便之處了。
看看容器內環境變量,變量不多
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的功能。
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
[root@basicserver dockertest]# docker run mysql #Redhat6 run不起來 FATAL: kernel too old
誰再說不會用docker,非要一步一步配環境,裝軟件,就問他,「你會用yum嗎?」 話說回來,剛開始用總感受不踏實,和系統隔了一層,不如直接安裝的東西手感好。