docker 安装mysql 和挂载

仓库位置:

https://hub.docker.com/_/mysql/

安装的同时挂载data资料卷和config 配置的资料卷刀磁盘上

docker run -d -p 3306:3306 \
-e MYSQL_USER="soaeon" \
-e MYSQL_PASSWORD="#Liu123456" \
-e MYSQL_ROOT_PASSWORD="#Liu123456" \
--name mysql01 -v /docker/mysql/config/my.cnf:/etc/my.cnf -v /docker/mysql/data:/var/lib/mysql mysql/mysql-server:5.7

你听我解释呀!

  • -d 是后台运行
  • -e(environment)MYSQL_USER 指定用户
  • -e(environment)MYSQL_PASSWORD 指定用户的密码
  • -e(environment)MYSQL_ROOT_PASSWORD 指定root用户的密码
  • --name mysql01 指定容器的名字是mysql01 对应的镜像文件是mysql/sql-server:5.7
  • -v 挂载文件的地址:文件实际所在的地址

/docker/mysql/config/my.cnf 一定要先创建起来 my.cnf 内容如下:

[mysqld]

user=mysql

/docker/mysql/data 这个文件夹也要先创建起来, 而且这个文件夹必须是个空的哟

docker容器相关的操作命令

  • docker ps 查看运行中的容器

  • docker ps -a 查看全部的容器

  • docker images 查看所有的镜像

  • docker start mysql01 启动msyql01 容器

  • docker logs mysql01 查看mysql01容器的logs

  • docker stop mysql01 停止mysql01容器

  • docker restart mysql01 重启mysql01容器

  • docker rm mysql01 删除容器 mysql01

  • docker rmi images_id 删除镜像images_id

mysql 配置

PS:如果安装的过程中没有指定MYSQL_ROOT_PASSWORD的话, 我们需要去logs 中查看默认的密码哟

操作过程如下:

执行命令: docker logs mysql01 ,如果没没有: [Entrypoint] GENERATED ROOT PASSWORD选项,执行以下操作

  1. 进入容器的bash环境 docker exec -it mysql01 bash
  2. 登陆mysql mysql -uroot -p
  3. 输入密码 , 但是我们不知道密码是啥呀 那就直接回车吧
  4. 退出吧 exit
  5. 再次查看日志 docker logs mysql01 生成初始密码了 呃呃呃呃呃

进入mysql的 bash环境:

docker exec -it mysql01(容器名字) bash

查询账号:

select user ,host from user;

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

新增一个账户, 并赋予远程登陆的权限:

CREATE USER 'root'@'%' IDENTIFIED BY '#Liu123456';

grant all privileges on *.* to 'root'@'%' identified by '#Liu123456' with grant option;

flush privileges;

查看mysql的默认字符集:

show variables  like '%charac%';
mysql> show variables  like '%charac%';
+--------------------------+----------------------------+
| Variable_name | Value |
+--------------------------+----------------------------+
| character_set_client | latin1 |
| character_set_connection | latin1 |
| character_set_database | latin1 |
| character_set_filesystem | binary |
| character_set_results | latin1 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+

推出mysql的bash环境:

mysql> exit
Bye
bash-4.2# exit
exit
[root@host /]#

修改挂载资料卷下的my.cnf文件中的字符集(退出bash环境,使用vi命令):

[root@host /]# vi docker/mysql/config/my.cnf
[mysql]
default-character-set=utf8 [client]
default-character-set=utf8 [mysqld]
character-set-server=utf8
collation-server = utf8_unicode_ci
user=mysql

docker 中安装mysql 文档

大爷们拿去吧

https://dev.mysql.com/doc/mysql-installation-excerpt/5.7/en/docker-mysql-more-topics.html

docker使用记录二:mysql安装与配置的更多相关文章

  1. Docker之Mysql安装及配置

    原文:Docker之Mysql安装及配置 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/zhaobw831/article/details/8014 ...

  2. 二:mysql安装配置、主从复制配置详解

    作者:NiceCui 本文谢绝转载,如需转载需征得作者本人同意,谢谢. 本文链接:http://www.cnblogs.com/NiceCui/p/8213723.html 邮箱:moyi@moyib ...

  3. PPTP + FreeRADIUS + MySQL 安装与配置

    原文地址:http://www.zhukun.net/archives/5375 PPTP + FreeRADIUS + MySQL 安装与配置 2012/03/29Linux运维centos.Fre ...

  4. Linux下MySQL安装及配置

    Linux下MySQL安装及配置 安装MySQL Ubuntu系统中,直接使用apt install的方式去安装MySQL的服务端和客户端,MySQL的客户端必须安装,否则无法通过命令连接并操作MyS ...

  5. CentOS 6.5系统使用yum方式安装LAMP环境和phpMyAdmin,mysql8.0.1/mysql5.7.22+centos7,windows mysql安装、配置

    介绍如何在CentOs6.2下面使用YUM配置安装LAMP环境,一些兄弟也很喜欢使用编译的安装方法,个人觉得如果不是对服务器做定制,用yum安装稳定简单,何必去download&make&am ...

  6. MySQL 安装 + 精简 + 配置

    MySQL 安装 + 精简 + 配置 下载安装 从官网 下载 Community Edition MySQL 5.6 版本 精简 根目录下只留 [data/bin/share] , my-defaul ...

  7. Linux下MySQL安装和配置

    --Linux下MySQL安装和配置 ---------------------------2014/05/18 Linux下MySQL的配置和安装 本文的安装采用 rpm 包安装 1.首先在官网下载 ...

  8. MySQL安装、配置、测试

    MySQL安装.配置.测试(win7_64bit) 目录 1.概述 2.本文用到的工具 3.MySQL安装配置 4.Java访问MySQL测试 5.注事事项 6.相关博文 >>看不清的图片 ...

  9. centos 7.3 服务器环境搭建——MySQL 安装和配置

    centos 7.3 服务器环境搭建——MySQL 安装和配置服务器信息如下:服务器:阿里云系统 centos 7.3 (阿里云该版本最新系统)mysql版本:5.7.18 (当前时间最新版本)连接服 ...

随机推荐

  1. Libre OJ 2255 (线段树优化建图+Tarjan缩点+DP)

    题面 传送门 分析 主体思路:若x能引爆y,从x向y连一条有向边,最后的答案就是从x出发能够到达的点的个数 首先我们发现一个炸弹可以波及到的范围一定是坐标轴上的一段连续区间 我们可以用二分查找求出炸弹 ...

  2. 9、numpy——数组操作

    Numpy 中包含了一些函数用于处理数组,大概可分为以下几类: (1)修改数组形状 (2)翻转数组 (3)修改数组维度 (4)连接数组 (5)分割数组 (6)数组元素的添加与删除 1.修改数组形状 函 ...

  3. hdu6354 Everything Has Changed (圆的相交弧长)

    题目传送门 题意: 用一堆圆来切割一个圆心为原点,半径为R的圆A,问切割完毕后圆A外围剩余部分的周长(图中的红线部分). 思路: 首先判定圆与圆A的关系,这题我们只需要与A内切.相交的圆. 然后就是求 ...

  4. php 模拟登陆(不带验证码)采集数据

    这里模拟表单登陆窗口 提交代码部分 1,生成session_id保存到 cookie $login_url = 'http://www.96net.com.cn/Login.php';$cookie_ ...

  5. day64--pymysql模块的使用、视图、触发器、函数、存储过程、事务

    一.pymysql的下载和使用 (一)pymysql模块的下载:pip3 install pymysql # 实现:使用Python实现用户登录,如果用户存在则登录成功(假设该用户已在数据库中) im ...

  6. uoj396 [NOI2018]屠龙勇士

    [NOI2018]屠龙勇士 描述 小 D 最近在网上发现了一款小游戏.游戏的规则如下: 游戏的目标是按照编号 1∼n 顺序杀掉 n 条巨龙,每条巨龙拥有一个初始的生命值 ai .同时每条巨龙拥有恢复能 ...

  7. 一键部署YApi

    编写docker-compose.yml version: '2.1' services: yapi: image: mrjin/yapi:latest # build: ./ container_n ...

  8. jq中的ajax传参

        一.   jq中的Ajax传参有两种           1.通过url地址来传参    2.通过data来传递参数 1. url来传递参数 function GetQuery(id) { | ...

  9. vim/vi编辑工具实现多行注释和取消注释

    转载声明:本文为转载文章 原文地址:https://blog.51cto.com/3332935/2106143 多行注释: 进入命令行模式--> 将光标移动到要注释的第一行位置--> 按 ...

  10. python range和arange

    range:自带函数,返回一个序列 range(起始点,终止点(不包含),步长(整数))   起始点和步长都可以省略,起始点默认为0,步长默认为1 range(1,11,2) [1,3,5,7,9] ...