【原创】Ubuntu 18.04 Docker 安装与运行 MySQL 5.7 – 简要版

2024-06-15 20:18

本文主要是介绍【原创】Ubuntu 18.04 Docker 安装与运行 MySQL 5.7 – 简要版,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

安装准备

1、相关环境

Ubuntu 18.04 x64

Docker 19.03

MySQL Server CE 5.7.31

2、安装用户

使用具有 sudo 权限的普通用户安装

安装步骤

1、拉取镜像

sudo docker pull mysql/mysql-server:5.75.7: Pulling from mysql/mysql-server
e945e9180309: Pull complete 
bda404c4d2e2: Pull complete 
858855003112: Pull complete 
d92ed785684c: Pull complete 
Digest: sha256:6d6fdd5bd31256a484e887c96c41abfc9ee3e3deb989de83ebdb8694fcc83485
Status: Downloaded newer image for mysql/mysql-server:5.7
docker.io/mysql/mysql-server:5.7

查看镜像

sudo docker images | grep mysql
mysql/mysql-server   5.7                 9c31a29b3f30        6 weeks ago         322MB

2、运行容器

sudo docker run -p 3306:3306 --name mysql -d mysql/mysql-server:5.7

3、查看容器运行状态

sudo docker ps
CONTAINER ID        IMAGE                    COMMAND                  CREATED             STATUS                    PORTS                               NAMES
e1a229279e59        mysql/mysql-server:5.7   "/entrypoint.sh mysq…"   31 seconds ago      Up 31 seconds (healthy)   0.0.0.0:3306->3306/tcp, 33060/tcp   mysql

4、查看容器运行日志

sudo docker logs mysqlsudo docker logs mysql
[Entrypoint] MySQL Docker Image 5.7.31-1.1.17
[Entrypoint] No password option specified for new database.
[Entrypoint]   A random onetime password will be generated.
[Entrypoint] Initializing database
[Entrypoint] Database initialized
Warning: Unable to load '/usr/share/zoneinfo/iso3166.tab' as time zone. Skipping it.
Warning: Unable to load '/usr/share/zoneinfo/leapseconds' as time zone. Skipping it.
Warning: Unable to load '/usr/share/zoneinfo/tzdata.zi' as time zone. Skipping it.
Warning: Unable to load '/usr/share/zoneinfo/zone.tab' as time zone. Skipping it.
Warning: Unable to load '/usr/share/zoneinfo/zone1970.tab' as time zone. Skipping it.
[Entrypoint] GENERATED ROOT PASSWORD: 3l2icGisqUL.yGdUm(usJOLhAR
[Entrypoint] ignoring /docker-entrypoint-initdb.d/*
[Entrypoint] Server shut down
[Entrypoint] Setting root user as expired. Password will need to be changed before database can be used.
[Entrypoint] MySQL init process done. Ready for start up.
[Entrypoint] Starting MySQL 5.7.31-1.1.17

5、获取 MySQL Server 初始 root 密码

sudo docker logs mysql 2>&1 | grep "ROOT PASSWORD"
[Entrypoint] GENERATED ROOT PASSWORD: 3l2icGisqUL.yGdUm(usJOLhAR

6、使用 mysql client 命令连接到 MySQL Server

输入如下命令并回车,然后输入上一步搜索到的 root 初始密码

sudo docker exec -it mysql mysql -uroot -p
Enter password: Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 14
Server version: 5.7.31
Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>

7、更新 root 密码

mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'root@2020';
Query OK, 0 rows affected (0.00 sec)

8、连接到 MySQL Server 容器内部 shell 环境

sudo docker exec -it mysql bash
bash-4.2#

9、MySQL Server 配置文件、数据文件

配置文件位置

/etc/my.cnf

数据文件、日志文件等

bash-4.2# pwd
/var/lib/mysql
bash-4.2# ls
auto.cnf    ca.pem           client-key.pem  ib_logfile0  ibdata1  mysql       mysql.sock.lock     private_key.pem  server-cert.pem  sys
ca-key.pem  client-cert.pem  ib_buffer_pool  ib_logfile1  ibtmp1   mysql.sock  performance_schema  public_key.pem   server-key.pem
bash-4.2#

10、创建一个可远程连接的 MySQL Server 数据库用户

sudo docker exec -it mysql mysql -uroot -p
[sudo] password for jiangzl: 
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 60
Server version: 5.7.31 MySQL Community Server (GPL)
Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> grant all privileges on *.* to 'test'@'%' identified by 'test1234';
Query OK, 0 rows affected, 1 warning (0.00 sec)

注:

a、上面的命令有可能会需要输入两次密码(当前会话第一次使用 sudo 命令或者 sudo 命令使用过了 session 有效期),第一次是输入 Ubuntu 操作系统用户的密码以获取 root 权限,第二次是输入 MySQL Server 的 root  密码以连接到 MySQL Server。

b、创建用户后可以使用 MySQL Client 工具连接到数据库

dbeaver 连接 MySQL Server 示例:

填写 Ubuntu 的网络地址,端口号,用户名与密码,点击测试连接。显示已连接则连接成功。

c、以上安装方式仅是基础的安装方式,有很多需要配置的地方均未配置。因此,文档内容仅推荐开发或测试环境使用或者仅供参考。

附录

1、常用命令

sudo docker stop mysql # 停止容器名为 mysql 的容器
sudo docker start mysql # 启动容器名为 mysql 的容器(针对已经使用 sudo docker run 运行后的容器)
sudo docker restart mysql # 重启容器名为 mysql 的容器
sudo docker rm mysql # 删除容器名为 mysql 的容器
sudo docker rmi mysql/mysql-server:5.7 # 删除镜像名为 mysql/mysql-server,tag 为 5.7 的 mysql-server 容器

2、参考:

https://dev.mysql.com/doc/refman/5.7/en/docker-mysql-getting-started.html

这篇关于【原创】Ubuntu 18.04 Docker 安装与运行 MySQL 5.7 – 简要版的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1064471

相关文章

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

Ubuntu固定虚拟机ip地址的方法教程

《Ubuntu固定虚拟机ip地址的方法教程》本文详细介绍了如何在Ubuntu虚拟机中固定IP地址,包括检查和编辑`/etc/apt/sources.list`文件、更新网络配置文件以及使用Networ... 1、由于虚拟机网络是桥接,所以ip地址会不停地变化,接下来我们就讲述ip如何固定 2、如果apt安

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及

docker如何删除悬空镜像

《docker如何删除悬空镜像》文章介绍了如何使用Docker命令删除悬空镜像,以提高服务器空间利用率,通过使用dockerimage命令结合filter和awk工具,可以过滤出没有Tag的镜像,并将... 目录docChina编程ker删除悬空镜像前言悬空镜像docker官方提供的方式自定义方式总结docker