zoukankan      html  css  js  c++  java
  • docker中使用mysql数据库详解(在局域网访问)

    开发过程中经常需要安装、调试mysql数据库,还需要在各种操作系上安装包依赖,实在是繁琐,因此就研究了一下如何在docker上运行一个mysql镜像,省却了我安装、找依赖的问题。

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

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

    使用

    1
    docker pull mysql

    获得mysql镜像,接着使用

    1
    docker images

    查看镜像列表,如下

    使用

    1
    docker run -itd -P mysql bash

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

    使用

    1
    docker ps -a

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

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

    使用命令

    1
    docker exec -it sick_hawking bash

    连接到mysql镜像中,

    1
    docker exec

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

    连接成功以后,如下,

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

    1
    service mysql status

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

    mysql没有启动可以使用

    1
    service mysql start

    ,如下,

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

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

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

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

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

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

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

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

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

  • 相关阅读:
    【BZOJ2424】[HAOI2010]订货 最小费用流
    【BZOJ1935/4822】[Shoi2007]Tree 园丁的烦恼/[Cqoi2017]老C的任务 树状数组
    【BZOJ2500】幸福的道路 树形DP+RMQ+双指针法
    【BZOJ4726】[POI2017]Sabota? 树形DP
    【BZOJ4883】[Lydsy2017年5月月赛]棋盘上的守卫 KM算法
    【BZOJ4881】5月月赛D 线段游戏 树状数组+set
    【BZOJ4518】[Sdoi2016]征途 斜率优化
    【BZOJ4818】[Sdoi2017]序列计数 DP+矩阵乘法
    【BZOJ2553】[BeiJing2011]禁忌 AC自动机+期望DP+矩阵乘法
    【BZOJ3211】花神游历各国 并查集+树状数组
  • 原文地址:https://www.cnblogs.com/gongguan/p/9058021.html
Copyright © 2011-2022 走看看