溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

玩大數(shù)據(jù)的你竟然不知道容器?——Docker入門(mén)之安裝Docker及MySQL

發(fā)布時(shí)間:2020-07-21 01:27:05 來(lái)源:網(wǎng)絡(luò) 閱讀:427 作者:Stitch_x 欄目:云計(jì)算

1.簡(jiǎn)介

Docker是一個(gè)開(kāi)源的應(yīng)用容器引擎;是一個(gè)輕量級(jí)容器技術(shù);

Docker支持將軟件編譯成一個(gè)鏡像;然后在鏡像中各種軟件做好配置,將鏡像發(fā)布出去,其他使用者可以直接使用這個(gè)鏡像;

運(yùn)行中的這個(gè)鏡像稱為容器,容器啟動(dòng)是非常快速的。

2.核心概念

docker主機(jī)(Host):安裝了Docker程序的機(jī)器(Docker直接安裝在操作系統(tǒng)之上);

docker客戶端(Client):連接docker主機(jī)進(jìn)行操作;

docker倉(cāng)庫(kù)(Registry):用來(lái)保存各種打包好的軟件鏡像;

docker鏡像(Images):軟件打包好的鏡像;放在docker倉(cāng)庫(kù)中;

docker容器(Container):鏡像啟動(dòng)后的實(shí)例稱為一個(gè)容器;容器是獨(dú)立運(yùn)行的一個(gè)或一組應(yīng)用

3.安裝環(huán)境

VM ware Workstation10CentOS-7-x86_64-DVD-1804.isouname -r3.10.0-862.el7.x86_64

檢查內(nèi)核版本,必須是3.10及以上 查看命令:uname -r

4.在linux虛擬機(jī)上安裝docker

步驟:

1、檢查內(nèi)核版本,必須是3.10及以上

uname -r

2、安裝docker

yum install docker

3、輸入y確認(rèn)安裝

Dependency Updated:  audit.x86_64 0:2.8.1-3.el7_5.1                                  audit-libs.x86_64 0:2.8.1-3.el7_5.1                                 Complete!(成功標(biāo)志)

4、啟動(dòng)docker

[root@hadoop000 ~]# systemctl start docker[root@hadoop000 ~]# docker -vDocker version 1.13.1, build 8633870/1.13.1

5、開(kāi)機(jī)啟動(dòng)docker

[root@hadoop000 ~]# systemctl enable dockerCreated symlink from /etc/systemd/system/multi-user.target.wants/docker.service to /usr/lib/systemd/system/docker.service.

6、停止docker

[root@hadoop000 ~]# systemctl stop docker

5.常用命令

鏡像操作

操作 命令 說(shuō)明
檢索 docker search 關(guān)鍵字 eg:docker search redis 我們經(jīng)常去docker hub上檢索鏡像的詳細(xì)信息,如鏡像的TAG
拉取 docker pull 鏡像名:tag :tag是可選的,tag表示標(biāo)簽,多為軟件的版本,默認(rèn)是latest
列表 docker images 查看所有本地鏡像
刪除 docker rmi image-id 刪除指定的本地鏡像

當(dāng)然大家也可以在官網(wǎng)查找:https://hub.docker.com/

容器操作
軟件鏡像(QQ安裝程序)—-運(yùn)行鏡像—-產(chǎn)生一個(gè)容器(正在運(yùn)行的軟件,運(yùn)行的QQ);

步驟:

  • 1、搜索鏡像

    [root@localhost ~]# docker search tomcat
  • 2、拉取鏡像

    [root@localhost ~]# docker pull tomcat
  • 3、根據(jù)鏡像啟動(dòng)容器

    docker run –name mytomcat -d tomcat:latest
  • 4、查看運(yùn)行中的容器

    docker ps
  • 5、 停止運(yùn)行中的容器

    docker stop 容器的id
  • 6、查看所有的容器

    docker ps -a
  • 7、啟動(dòng)容器
    docker start 容器id

  • 8、刪除一個(gè)容器
    docker rm 容器id

  • 9、啟動(dòng)一個(gè)做了端口映射的tomcat

    [root@localhost ~]# docker run -d -p 8888:8080 tomcat

    -d:后臺(tái)運(yùn)行
    -p: 將主機(jī)的端口映射到容器的一個(gè)端口 主機(jī)端口:容器內(nèi)部的端口

  • 10、為了演示簡(jiǎn)單關(guān)閉了linux的防火墻

    service firewalld status #;查看防火墻狀態(tài)
    service firewalld stop  #:關(guān)閉防火墻
    systemctl disable firewalld.service #禁止firewall開(kāi)機(jī)啟動(dòng)
  • 11、查看容器的日志

    docker logs container-name/container-id

更多命令參看
https://docs.docker.com/engine/reference/commandline/docker/
可以參考鏡像文檔

6.使用docker安裝mysql

  • > docker pull mysql
docker pull mysql Using default tag: latestTrying to pull repository docker.io/library/mysql ... latest: Pulling from docker.io/library/mysqla5a6f2f73cd8: Pull complete 936836019e67: Pull complete 283fa4c95fb4: Pull complete 1f212fb371f9: Pull complete e2ae0d063e89: Pull complete 5ed0ae805b65: Pull complete 0283dc49ef4e: Pull complete a7e1170b4fdb: Pull complete 88918a9e4742: Pull complete 241282fa67c2: Pull complete b0fecf619210: Pull complete bebf9f901dcc: Pull complete Digest: sha256:b7f7479f0a2e7a3f4ce008329572f3497075dc000d8b89bac3134b0fb0288de8Status: Downloaded newer image for docker.io/mysql:latest[root@hadoop000 ~]# docker imagesREPOSITORY          TAG                 IMAGE ID            CREATED             SIZEdocker.io/mysql     latest              f991c20cb508        10 days ago         486 MB
  • 啟動(dòng)
[root@hadoop000 ~]# docker imagesREPOSITORY          TAG                 IMAGE ID            CREATED             SIZEdocker.io/mysql     latest              f991c20cb508        10 days ago         486 MB[root@hadoop000 ~]# docker run --name mysql01 -d mysql756620c8e5832f4f7ef3e82117c31760d18ec169d45b8d48c0a10ff2536dcc4a[root@hadoop000 ~]# docker ps -aCONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                     PORTS               NAMES756620c8e583        mysql               "docker-entrypoint..."   9 seconds ago       Exited (1) 7 seconds ago                       mysql01[root@hadoop000 ~]# docker logs 756620c8e583error: database is uninitialized and password option is not specified   You need to specify one of MYSQL_ROOT_PASSWORD, MYSQL_ALLOW_EMPTY_PASSWORD and MYSQL_RANDOM_ROOT_PASSWORD

可以看到上面啟動(dòng)的方式是錯(cuò)誤的,提示我們要帶上具體的密碼

[root@hadoop000 ~]# docker run -p 3306:3306 --name mysql02 -e MYSQL_ROOT_PASSWORD=123456 -d mysqleae86796e132027df994e5f29775eb04c6a1039a92905c247f1d149714fedc06
–name:給新創(chuàng)建的容器命名,此處命名為pwc-mysql-e:配置信息,此處配置mysql的root用戶的登陸密碼-p:端口映射,此處映射主機(jī)3306端口到容器pwc-mysql的3306端口-d:成功啟動(dòng)容器后輸出容器的完整ID,例如上圖 73f8811f669ee...
  • 查看是否啟動(dòng)成功
[root@hadoop000 ~]# docker psCONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                               NAMESeae86796e132        mysql               "docker-entrypoint..."   8 minutes ago       Up 8 minutes        0.0.0.0:3306->3306/tcp, 33060/tcp   mysql02
  • 登陸MySQL
docker exec -it mysql04 /bin/bashroot@e34aba02c0c3:/# 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 80Server version: 8.0.13 MySQL Community Server - GPLCopyright (c) 2000, 2018, 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>
  • 其他的高級(jí)操作

    docker run --name mysql03 -v /conf/mysql:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag

    把主機(jī)的/conf/mysql文件夾掛載到 mysqldocker容器的/etc/mysql/conf.d文件夾里面

    改mysql的配置文件就只需要把mysql配置文件放在自定義的文件夾下(/conf/mysql)

    docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci

    指定mysql的一些配置參數(shù)

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI