• 在docker中使用mysql数据库,在局域网访问


    注:本文所有内容均在CentOS Linux release 7.2.1511 (Core) 上测试完成

    假设,你已经安装好docker。如果没有安装好docker可以参考centos7上安装docker

    使用

    docker pull mysql
    • 1

    获得mysql镜像,接着使用

    docker images
    • 1

    查看镜像列表,如下
    image

    使用

    docker run -itd -P mysql bash
    eg:
    docker run -itd --name=mariadb_container_20180224 -p 3306:3306 mariadb /bin/bash
    mkdir -p /data/mysql/data
    chcon -Rt svirt_sandbox_file_t /data/mysql/data
    docker run -v /data/mysql/data:/var/lib/mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root --name mariadb -itd mariadb:latest
    docker run -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root --name mariadb -itd mariadb:latest

      

     
    • 1

    启动mysql镜像,docker run是启动容器的命令;i是交互式操作,t是一个终端,d指的是在后台运行,-P指在本地生成一个随机端口,用来映射mysql的3306端口,mysql指运行mysql镜像,bash指创建一个交互式shell。

    使用

    docker ps -a
    • 1

    查看已经运行的docker镜像,如下
    image

    从途中可以看到mysql镜像的3306端口绑定了本地的32773端口,因此就说如果你要在局域网中访问docker中的mysql数据库就需要使用服务器IP:32773来进行访问。

    使用命令

    docker exec -it sick_hawking bash
    • 1

    连接到mysql镜像中,

    docker exec
    • 1

    是docker镜像的连接命令,类似于ssh一样的命令,sick_hawking是镜像的名字,镜像每次启动都必须有一个名字,该名字可以手动指定也可以自己生成。

    连接成功以后,如下,

    image

    图中就已经进入到了docker mysql镜像中,使用

    service mysql status
    • 1

    查看mysql的启动状态,如下,
    image

    mysql没有启动可以使用

    service mysql start
    • 1

    ,如下,
    image

    输入mysql验证mysql是否启动成功,如下,
    image

    image

    到此为止,docker中的mysql已经启动成功。

    如何在外部使用root连接这个mysql?

    为了安全,首先需要设置root帐号的密码,如下

    update user set authentication_string = password('root') where user = 'root';
    • 1

    root的密码改为root
    接着,由于mysql中root执行绑定在了localhost,因此需要对root进行授权,代码如下,

    GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;
    • 1

    最后,使用navitecat测试mysql连接,如下,
    image

    连接成功,说明docker中的mysql可以在局域网中使用。

    完。

    CREATE USER
      'techonthenet'@'localhost' IDENTIFIED BY 'firstpassword',
      'checkyourmath'@'%' IDENTIFIED BY 'secondpassword';
    

      

    It looks like a container with the name qgis-desktop-2-4 already exists in the system. You can check output of below command to confirm if it indeed exists:

    $ docker ps -a
    

    Last column in above command's output is for names.

    If the container exists, remove it using:

    $ docker rm qgis-desktop-2-4
    

    or forcefully using,

    $ docker rm -f qgis-desktop-2-4
    
  • 相关阅读:
    SpringMVC上传文件异常 400 Required MultipartFile parameter 'files' is not present postman
    idea乱码但是线上ok 解决方法
    mysql查询所有子节点 非递归
    nacos设置了默认读不到原因
    c
    a
    b
    chrome developer tool 文章
    每日一库:JS.Class
    用Jquery获取解析获取URL参数地址
  • 原文地址:https://www.cnblogs.com/river2005/p/8276126.html
Copyright © 2020-2023  润新知