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. 11、numpy——字符串函数

    NumPy 字符串函数 以下函数用于对 dtype 为 numpy.string_ 或 numpy.unicode_ 的数组执行向量化字符串操作. 它们基于 Python 内置库中的标准字符串函数. ...

  2. Using Keyboard Navigation

    http://technet.microsoft.com/en-us/library/cc939835.aspx

  3. P5468 [NOI2019]回家路线

    传送门 看题目一眼斜率优化,然后写半天调不出来 结果错误的 $dfs$ 有 $95$ 分?暴力 $SPFA$ 就 $AC$ 了? 讲讲正解: 显然是斜率优化的式子: 先不考虑 $q_{s_k}$ 的贡 ...

  4. Windows 下 MySQL 备份脚本

    @title MySQL备份脚本 @echo off @echo root@127.0.0.1:3306 set host=127.0.0.1 set port=3306 set user=root ...

  5. 使用logstash同步MongoDB数据到es

    input{ mongodb{ codec => "json" uri => 'mongodb://127.0.0.1:27017/kuaibao' placehold ...

  6. Tomcat-部署多个项目(不同端口)

    20190713  整理 参考文档 https://blog.csdn.net/chenchunlin526/article/details/78799772 如何在Tomcat服务中,为不同端口部署 ...

  7. [BZOJ5466][NOIP2018]保卫王国 倍增

    题面 首先可以写一个暴力dp的式子,非常经典的树形dp \(dp[i][0]\)表示\(i\)这个点没有驻军,\(dp[i][1]\)就是有驻军,\(j\)是\(i\)的孩子.那么显然: \[ \be ...

  8. INSTR代替NOT LIKE

    instr(title,'手册')>0  相当于  title like '%手册%' instr(title,'手册')=1  相当于  title like '手册%' instr(titl ...

  9. C#基础提升系列——C#任务同步

    C#任务同步 如果需要共享数据,就必须使用同步技术,确保一次只有一个线程访问和改变共享状态.如果不注意同步,就会出现争用条件和死锁. 不同步导致的线程问题 如果两个或多个线程访问相同的对象,并且对共享 ...

  10. linux的块设备层

    ll_rw_block()是块设备驱动层,向上提供按block读写块设备到某个内存地址的(是以page为目标单位)方法. bread()是块设备缓冲层,磁盘上的block用页缓存.先从这个缓存里找,找 ...