會用Docker的人都別裝了,這多簡單吶
學術又官方的說法
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 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.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 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
- radhat7需要先安裝libcgroup,然後安裝docker的rpm包才能成功。
- redhat6無法執行本文版本的docker,當docker run時報錯。所以如果安裝本文版本的docker,Redhat版本要7以及更高。
[root@basicserver dockertest]# docker run mysql #Redhat6 run不起來 FATAL: kernel too old
總結
誰再說不會用docker,非要一步一步配環境,裝軟體,就問他,“你會用yum嗎?”
話說回來,剛開始用總感覺不踏實,和系統隔了一層,不如直接安裝的東西手感好。
由於平臺不能直接傳送學習資料等原因,有需要學習Docker的朋友們只需要評論+轉發+關注,並且掃描下方小編二維碼即可免費獲取PDF學習筆記以及往期的面試題合集!!!
相關文章
- Ubuntu下docker安裝及簡單應用UbuntuDocker
- 一個簡單的人臉識別庫
- 5個Word簡單實用小技巧,但真正會使用的人很少
- docker簡單實用教程Docker
- 99%的人都理解錯了 HTTP 中 GET 與 POST 的區別HTTP
- Java引用型別原理深度剖析,看完文章,90%的人都收藏了Java型別
- 99%的人都理解錯了HTTP中GET與POST的區別HTTP
- 這些必備Java技能,你都會了嗎Java
- Docker安裝和簡單使用Docker
- 這麼簡單!G2L開發板安裝DockerDocker
- 99%的人都理解錯了HTTP中GET與POST的區別 (轉)HTTP
- 利用opencv 做一個簡單的人臉識別OpenCV
- 有了這個平臺,企業開發應用更簡單了!
- kali簡單安裝docker和docker-composeDocker
- K8S 棄用 Docker 了?Docker 不能用了?別逗了!K8SDocker
- Python操作MySQL儲存,這些你都會了嗎?PythonMySql
- 這11個Linux下電子書工具,用的人都偷著樂Linux
- 用Python實現簡單的人臉識別,10分鐘搞定!(附原始碼)Python原始碼
- 做java的你,這些英文單詞都掌握了嗎?Java
- Docker入門為什麼可以這麼簡單?Docker
- 你我都會遇到的需求:如何匯出MySQL中的資料~ 簡單!實用!MySql
- 看完99%的人都學會了!一文帶你搞懂Android多執行緒Handler,大廠面試題彙總Android執行緒面試題
- 90%的人都搞不懂的資料治理,從理論到實踐,都在這裡了
- Java多執行緒就是這麼簡單Java執行緒
- docker簡單命令Docker
- 新來的運維這樣用HDFS,CIO都懵了···運維
- 這屆世界人工智慧大會,大佬們都說了啥?人工智慧
- 這是今年前端最常見的面試題,你都會了嗎?前端面試題
- 面試現場:這些常問的面試題你都會了嗎面試題
- 金三銀四跳槽季,這些面試題你都會了嗎?面試題
- 用一個簡單問題,我就這樣改良了技術面試面試
- 包裝模式就是這麼簡單啦模式
- 前端之路:緊跟潮流,docker簡單應用前端Docker
- linux上安裝Docker(非常簡單的安裝方法)LinuxDocker
- 我這節課都學了啥
- Docker-ElasticSearch7.8.1 安裝及簡單介紹DockerElasticsearch
- 多執行緒之死鎖就是這麼簡單執行緒
- 面試官:你都工作3年了,這個演算法題都不會?面試演算法