Docker 系列2【docker安装mysql】【开启远程连接】

文章目录


前言

本文开始,默认已经安装docker,如果你还没有完成这个步骤,请查看这一篇文章【docker安装与使用】

开始步骤

1.增加mysql挂载目录

c 复制代码
mkdir -p /mydata/mysql8/conf
mkdir -p /mydata/mysql8/data

2.下载镜像

c 复制代码
docker run mysql:8.0.28 # run 相当于pull create start 三合一

2.启动容器

  • -d 表示后台运行
  • -v 挂载目录到本地,宿主机目录:容器目录,例如:-v /usr/local/nginx:/usr/local/nginx
  • --name 使用的是run命令,--name会作用到create命令表示创建一个name为mysql8的容器
c 复制代码
docker run -d -v /mydata/mysql8/data:/var/lib/mysql -v /mydata/mysql8/conf:/etc/mysql/conf.d --name mysql8 -e MYSQL_ROOT_PASSWORD=mysql123 -p 3308:3306 -d mysql:8.0.28

具体步骤

  • 1 增加配置文件

这个选项会导致不使用权限系统来启动服务器,它将让任何用户可以访问服务器并且不受限制的访问所有数据库。在不使用授权表启动服务器后可以通过shell来执行mysqladmin flush-privilegesmysqladmin reload命令或者在连接到服务器后执行flush privileges语句来让正在运行的服务器再次使用授权表。

c 复制代码
vi /mydata/mysql8/conf/my.cnf #进入my.cnf文件
# 加入以下内容
[mysqld]
skip-grant-tables

  • 2重启容器服务
c 复制代码
docker restart mysql8 # 重启mysql服务
  • 3进入容器内部
c 复制代码
docker exec -it mysql8 /bin/bash
  • 4登入mysql
c 复制代码
mysql -u root -p #输完这个命令后,输入之前·步骤2·设置的密码mysql123

出现下面的内容表示登入成功

  • 5 选择mysql数据库
c 复制代码
use mysql
  • 6设置允许远程访问
    在正常的情况下mysql的远程访问我们只需要配置东西即可.
    1 防火墙对应端口是否开启,一般是3306
    2 user用户表中是否存在root用户,并且其host列值为%
c 复制代码
select user,host from user; # 查看用户表中root用户的配置

如果root用户的host列为%,即表示此用户可以远程访问,否则可以使用sql进行更改

c 复制代码
update user set host='%' where user='root';

如果发现出现了两条root的用户记录,则需要删除一条

4.无法连接

如果无法远程连接,可以执行一下操作

  • 1注释my.cnf中的配置

    c 复制代码
    vi /mydata/mysql8/conf/my.cnf # 进入文件注释
  • 2 防火墙否放开对应端口

    c 复制代码
    firewall-cmd --zone=public --add-port=3308/tcp --permanent
    
    firewall-cmd --reload
    
    firewall-cmd --list-port

5.测试连接

通过客户端工具进行连接即可

总结

以上的流程走完之后你将得到一个,基础的mysql服务。如果想要一个成熟的mysql服务,你还需要实现以下功能。

  • 1.服务器应该进行过性能优化,包括合理的索引设计、查询优化、内存和I/O使用优化等。
  • 2.数据备份和恢复:服务器应该有定期的数据备份策略,并能在数据丢失或损坏时进行数据恢复
  • 3.高可用性:为了保证服务的连续性,服务器应该具备高可用性,例如通过主从复制、负载均衡、故障切换等方式来提高可用性。
相关推荐
小张是铁粉1 小时前
docker学习二天之镜像操作与容器操作
学习·docker·容器
烟雨书信1 小时前
Docker文件操作、数据卷、挂载
运维·docker·容器
IT成长日记1 小时前
【Docker基础】Docker数据卷管理:docker volume prune及其参数详解
运维·docker·容器·volume·prune
这儿有一堆花1 小时前
Docker编译环境搭建与开发实战指南
运维·docker·容器
LuckyLay1 小时前
Compose 高级用法详解——AI教你学Docker
运维·docker·容器
Uluoyu2 小时前
redisSearch docker安装
运维·redis·docker·容器
IT成长日记6 小时前
【Docker基础】Docker数据持久化与卷(Volume)介绍
运维·docker·容器·数据持久化·volume·
热爱生活的猴子6 小时前
阿里云服务器正确配置 Docker 国内镜像的方法
服务器·阿里云·docker
程序员岳焱10 小时前
Java 与 MySQL 性能优化:Java 实现百万数据分批次插入的最佳实践
后端·mysql·性能优化
FrankYoou10 小时前
Jenkins 与 GitLab CI/CD 的核心对比
java·docker