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. 【洛谷UVA307】小木棍Sticks

    小木棍Sticks[传送门] 算法的话:dfs+超强剪枝: (另外注意UVA上好像不接受万能头[因为万能头WA了两次,瑟瑟发抖]) 思路: 最直接的思路,枚举木棍长度来dfs,但这样很容易就TLE了. ...

  2. KNN算法案例--手写数字识别

    import numpy as np import matplotlib .pyplot as plt import pandas as pd from sklearn.neighbors impor ...

  3. ajax_封装函数_步骤1

    <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8& ...

  4. [置顶]unity常用开发套件

    维京人骨骼动画制作(Unity 2D Animation资源包使用指南) 维京人骨骼动画制作2(Unity 2D IK资源包使用指南) -------------------------------- ...

  5. route - 显示 / 操作IP选路表

    总览 SYNOPSIS route [-CFvnee] route [-v] [-A family] add [-net|-host] target [netmask Nm] [gw Gw] [met ...

  6. 一、WebApi模型验证实践项目使用

    一.启语 前面我们说到,模型验证的原理(包含1.项目创建,2.模型创建,3.走通测试模型验证,4.在过滤器中处理返回json格式(非控制器内))-完全是新手理解使用的,新番理解 通常情况下,对于那些经 ...

  7. runltp出现问题 [

    runltp 623行: if [ "$?" == "0" ]; then 对[解析出了问题. 我灵机一动,是不是sh的问题. which sh /bin/sh ...

  8. apache You don't have permission to access / on this server.无权访问

    环境:ubuntu16.4 apache2 原因:修改了apache web项目路径 解决: 1. 修改 /etc/apache2/sites-available/000-default.conf 文 ...

  9. webRTC脱坑笔记(一)— 初识webRTC

    webRTC概述 WebRTC--- `Web browsers with Real-Time Communications (RTC)` WebRTC是一个开源项目,可以在`Web`和本机应用程序中 ...

  10. html中 的method=post和method=get的区别

    1. get是从服务器上获取数据,post是向服务器传送数据. 2. get是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到.post是通过 ...