• Docker常用命令&操作以及安装Mysql示例


    一、Docker常用命令&操作

    1)、镜像操作

    操作命令说明
    检索 docker search 关键字 eg:docker search redis 我们经常去docker hub上检索镜像的详细信息,如镜像的TAG。
    拉取 docker pull 镜像名:tag :tag是可选的,tag表示标签,多为软件的版本,默认是latest
    列表 docker images 查看所有本地镜像
    删除 docker rmi image-id 删除指定的本地镜像

    https://hub.docker.com/

    2)、容器操作

    软件镜像(QQ安装程序)----运行镜像----产生一个容器(正在运行的软件,运行的QQ);

    步骤:

    1、搜索镜像
      [root@localhost ~]# docker search tomcat
    2、拉取镜像
      [root@localhost ~]# docker pull tomcat
    3、根据镜像启动容器
      docker run --name mytomcat -d tomcat:latest
    4、docker ps  
        查看运行中的容器
    5、 停止运行中的容器
        docker stop  容器的id
    6、查看所有的容器
        docker ps -a
    7、启动容器
        docker start 容器id
    8、删除一个容器
        docker rm 容器id
    9、启动一个做了端口映射的tomcat
        [root@localhost ~]# docker run -d -p 8888:8080 tomcat
    -d:后台运行
    -p: 将主机的端口映射到容器的一个端口    主机端口:容器内部的端口
    
    10、为了演示简单关闭了linux的防火墙
        service firewalld status ;查看防火墙状态
        service firewalld stop:关闭防火墙
    11、查看容器的日志
        docker logs container-name/container-id
    
    更多命令参看
    https://docs.docker.com/engine/reference/commandline/docker/
    可以参考每一个镜像的文档
    
    12、进入容器
        docker exec -it ubantu  /bin/bash
    -i: 交互式操作。
    -t: 终端。
    ubuntu: ubuntu 镜像。
    /bin/bash:放在镜像名后的是命令,这里我们希望有个交互式 Shell,因此用的是 /bin/bash。
    要退出终端,直接输入 exit:
    
    13、重启容器
    docker restart 容器id/名字

    二、安装MySQL示例

    docker pull mysql

    错误的启动:docker run --name mysql01 -d mysql

    [root@localhost ~]# docker run --name mysql01 -d mysql
    42f09819908bb72dd99ae19e792e0a5d03c48638421fa64cce5f8ba0f40f5846
    
    mysql退出了
    [root@localhost ~]# docker ps -a
    CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                           PORTS               NAMES
    42f09819908b        mysql               "docker-entrypoint.sh"   34 seconds ago      Exited (1) 33 seconds ago                            mysql01
    538bde63e500        tomcat              "catalina.sh run"        About an hour ago   Exited (143) About an hour ago                       compassionate_
    goldstine
    c4f1ac60b3fc        tomcat              "catalina.sh run"        About an hour ago   Exited (143) About an hour ago                       lonely_fermi
    81ec743a5271        tomcat              "catalina.sh run"        About an hour ago   Exited (143) About an hour ago                       sick_ramanujan

    错误日志:docker logs 42f09819908b

    //错误日志
    [root@localhost ~]# docker logs 42f09819908b
    error: 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;//这个三个参数必须指定一个

    正确的启动:docker run --name 容器Id  -e MYSQL_ROOT_PASSWORD=123456 -d mysql

    [root@localhost ~]# docker run --name mysql01 -e MYSQL_ROOT_PASSWORD=123456 -d mysql
    b874c56bec49fb43024b3805ab51e9097da779f2f572c22c695305dedd684c5f
    [root@localhost ~]# docker ps
    CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS               NAMES
    b874c56bec49        mysql               "docker-entrypoint.sh"   4 seconds ago       Up 3 seconds        3306/tcp            mysql01

    做了端口映射:docker run -p 3306:3306 --name mysql02 -e MYSQL_ROOT_PASSWORD=123456 -d mysql

    [root@localhost ~]# docker run -p 3306:3306 --name mysql02 -e MYSQL_ROOT_PASSWORD=123456 -d mysql
    ad10e4bc5c6a0f61cbad43898de71d366117d120e39db651844c0e73863b9434
    [root@localhost ~]# docker ps
    CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                    NAMES
    ad10e4bc5c6a        mysql               "docker-entrypoint.sh"   4 seconds ago       Up 2 seconds        0.0.0.0:3306->3306/tcp   mysql02

    几个其他的高级操作

    docker run --name mysql03 -v /conf/mysql:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag
    //把主机的/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的一些配置参数

    注意:最新版本(8.0以上)安装远程连接需要修改mysql的加密机制,不然会报"2059-Authentication plugin 'caching_sha2_password' cannot be loaded"错误

    进入docker中的mysql容器:

    docker exec -it 容器id  /bin/bash

    输入如下5行命令:

    1、grant all on *.* to 'root'@'%';  // 授权 
    2、flush privileges; 
    3、alter user 'root'@'localhost' identified by '123456' password expire never;  //修改加密规则 
    4、ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';  // 修改密码 
    5、flush privileges; 

    在本地用navicat测试连接,连接成功!

  • 相关阅读:
    Linux的JVM可以从SUN网站上下载
    实践是最好的老师
    SCAU 8624 多项式系数累加和
    SCAU 8617 阶乘数字和 (水题)
    SCAU 8614 素数
    SCAU 8619 公约公倍
    HDU ACM 1106 排序
    Uva 465 Overflow
    SCAU 8611 大牛之路I
    SCAU 9501 ACMer不得不知道的事儿
  • 原文地址:https://www.cnblogs.com/donleo123/p/14098540.html
Copyright © 2020-2023  润新知