设为首页 加入收藏

TOP

Docker安装MySQL 8.0过程记录(一)
2019-02-22 22:07:53 】 浏览:161
Tags:Docker 安装 MySQL 8.0 过程 记录

环境:


Docker版本:version: 17.12.0-ce


1. 操作系统切换到root用户:


        # su root


2. 启动docker
        # systemctl start docker


3. 拉取mysql8.0镜像
        # docker pull mysql:8.0


4. 创建并启动容器


        -p: 映射本地端口3306


        --restart-always: docker服务启动时,自动启动容器,并且当容器停止时,尝试重启容器。


                --restart具体参数值详细信息:
                no -  容器退出时,不重启容器;
                on-failure - 只有在非0状态退出时才从新启动容器;
                always - 无论退出状态是如何,都重启容器;


        MYSQL_ROOT_PASSWORD:设置root密码为root


        设置默认数据库编码为utf8mb4,默认排序规则为utf8mb4_unicode_ci


        -v : 挂载本地卷


  注意:mysql8.0安装默认编码为utf8mb4,所以可以不需要参数--character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
docker run \
--name mysql \
-p 3306:3306 \
--restart=always \
-e MYSQL_ROOT_PASSWORD=root \
-v /var/lib/mysql/:/var/lib/mysql/ \
-d mysql:8.0 \
--character-set-server=utf8mb4 \
--collation-server=utf8mb4_unicode_ci


5. 进入docker的mysql容器
        #  docker exec -it mysql /bin/bash


6. 登录数据库(此处的密码为参数-e MYSQL_ROOT_PASSWORD=root对应的值,此处密码为root)
        #  mysql -uroot -proot


7. 使用mysql数据库
mysql> use mysql;


8. mysql8.0的root用户的验证方式变了,通过查询:select host,user,plugin from user;


得知:root的用户的加密方式为caching_sha2_passoword, 而navicat连接所用的方式为native_password。mysql为远程连接和本地连接提供了不同的密码验证方式。


修改root用户插件验证方式:


mysql> ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'root';


注意:先更改ser表中用户为root的host字段,若为localhost则改为%,只有改为%,该用户才可以远程访问。


此时,可以使用mysql客户端工具连接数据库。


如果navicat 提示“1045 access denied for user 'root'@'localhost' ”,则执行:


mysql> alter user 'root'@'localhost' identified by 'root';


同理:如果navicat 提示“1045 access denied for user 'root'@'%' ”,则执行:


mysql> alter user 'root'@'%' identified by 'root';


刷新权限:


mysql> flush privileges;


9. 修改mysql数据库编码,防止中文乱码


    (1)进入docker的mysql容器
            #  docker exec -it mysql /bin/bash


    (2)容器默认没有安装任何编辑器,先安装vim。


            #  apt-get update && apt-get install vim -y


      (3)  安装完vim之后,开始修改mysql数据库编码


            #  vim /etc/mysql/conf.d/mysql.cnf


            增加以下内容,然后保存,退出:     


          [client]
            default-character-set=utf8


          [mysql]
            default-character-set=utf8


      (4)  重启mysql容器,查询编码:此时编码已经修改为utf8。


            mysql>  show variables like'character%';


10.  查看挂载卷位置:获取容器/镜像的元数据。


      #  docker inspect  容器ID


其中:
    "Mounts": [
            {
                "Type": "volume",
                "Name": "ebc0e8f50d451650f29d7ac1a696a0130316073173835c1b5c9f7f88c5fb976f",
     

首页 上一页 1 2 下一页 尾页 1/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇MySQL 5.6升级为MySQL 5.7部署JBo.. 下一篇Oracle 12c可插拔数据库深入理解

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目