debian docker 密码_Docker下MySQL的安装

1 概述

本文讲述了如何利用Docker去安装MySQL,以及MySQL自定义配置文件的相关设置。

2 安装Docker

首先安装Docker并开启服务:

systemctl start docker

如果没有添加国内源的话建议添加一下,新增/修改/etc/docker/daemon.json,添加如下内容:

{
    "registry-mirrors": ["http://hub-mirror.c.163.com"]
}

这里用的是网易的源,其他源如下:

  • Docker中国区官方镜像:https://registry.docker-cn.com
  • ustchttps://docker.mirrors.ustc.edu.cn
  • 中科大:https://docker.mirrors.ustc.edu.cn
  • 阿里云:每个人不同,需要到阿里云容器服务创建,具体请查看文档

3 拉取MySQL镜像

docker pull mysql:latest

权限不够请加sudo,另外这一步需要一点时间,请耐心等待。

拉取完成后可以查看镜像:

docker images

39cf7b39390f2d44088999fbf39ccb71.png

4 运行容器

docker run -itd -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 --name mysql-latest mysql

参数说明:

  • -i:以交互模式运行,通常配合-t
  • -t:为容器重新分配一个伪输入终端,通常配合-i
  • -d:后台运行容器
  • -p:端口映射,格式为主机端口:容器端口
  • -e:设置环境变量,这里设置的是root密码
  • --name:设置容器别名

759fbc7300cebe36e253e6ecf7089250.png

运行之后会返回一个容器ID

5 测试

先查看运行状态:

docker ps

59aa5d326c26676918c2c7195d7fb1de.png

接着连接到容器的伪终端上:

docker exec -it mysql-latest /bin/bash

其中mysql-latest是执行运行命令时创建的别名,同时使用mysql测试连接:

mysql -u root -p

输入环境变量传递的root密码后就可以连接上MySQL了:

efbf633ae3d861bcf658facebc1f86a3.png

也可以在IDEA中添加MySQL数据源并测试连接:

0e80161ff86f1255a9159924cc83ae7a.png

6 配置文件

一般来说仅仅安装完MySQL是不够的,还需要自定义一些配置文件,自定义配置文件有两种方法,一种是进入容器并修改里面的my.cnf,另一种是容器启动的时候使用-v参数挂载配置文件的目录。

6.1 容器内修改

首先进入容器:

docker exec -it mysql-latest /bin/bash

请把mysql-latest修改为对应的容器别名,进入后可以通过

mysql --help | grep my.cnf

查看配置文件的位置:

811d5c987bbfb8e8a6e251f52f6d68cf.png

这几个文件存在读取顺序,可以使用

mysqld --verbose --help --pid-file=/var/run/mysqld/mysqld.pid | grep -A 1 "Default options"

查看:

b922263501a685c3ad1526d8e3b83acb.png

这里修改的是/etc/mysql/my.cnf,但是。。。

ca222117f7acb453c328c5601a2558cf.png

没有vim?关系不大先用vi将就一下:

330b8b20876088461ce7ed42a7c28ced.png

当时就人傻了居然vi都没有,行,关系不大,安装就行了:

af34b1f1696e0fe34fb6bcd527db1558.png

这都什么玩意。。。包都搜不到。。。

查看了一下系统的版本,是Debian 10

47e782dd91dc7d53c10b547ff9fc1bbb.png

于是就找了对应的源:

deb http://mirrors.aliyun.com/debian/ buster main non-free contrib
deb-src http://mirrors.aliyun.com/debian/ buster main non-free contrib
deb http://mirrors.aliyun.com/debian-security buster/updates main
deb-src http://mirrors.aliyun.com/debian-security buster/updates main
deb http://mirrors.aliyun.com/debian/ buster-updates main non-free contrib
deb-src http://mirrors.aliyun.com/debian/ buster-updates main non-free contrib
deb http://mirrors.aliyun.com/debian/ buster-backports main non-free contrib
deb-src http://mirrors.aliyun.com/debian/ buster-backports main non-free contrib

先备份:

cp /etc/apt/sources.list /etc/apt/sources.list.bak

然后修改添加即可:

vim /etc/apt/sources.list

但是没有这个命令。。。

没办法了手动echo添加:

echo deb http://mirrors.aliyun.com/debian/ buster main non-free contrib deb-src http://mirrors.aliyun.com/debian/ buster main non-free contrib deb http://mirrors.aliyun.com/debian-security buster/updates main deb-src http://mirrors.aliyun.com/debian-security buster/updates main deb http://mirrors.aliyun.com/debian/ buster-updates main non-free contrib deb-src http://mirrors.aliyun.com/debian/ buster-updates main non-free contrib deb http://mirrors.aliyun.com/debian/ buster-backports main non-free contrib deb-src http://mirrors.aliyun.com/debian/ buster-backports main non-free contrib > sources.list

24233ec75e01b95a348cf27a78d44c54.png

然后更新:

apt update
apt upgrade

安装vim

apt install vim

接着修改配置文件即可:

vim /etc/mysql/my.cnf

下面是示例常用参数:

[mysqld]
character-set-server=utf8mb4
[client]
default-character-set=utf8mb4
[mysql]
default-character-set=utf8mb4

6.2 运行容器时挂载

先查看一下原来容器的字符集:

show variables like '%character%';

f64b05a812ff04ccfb1b1a372106be6c.png

未修改之前的字符集如图,下面使用-v参数挂载配置文件目录并对字符集进行修改,首先先把原来的容器停止掉,以免端口占用:

docker stop mysql-latest

接着在宿主机目录/etc/mysql下创建一个配置文件my.cnf

vim /etc/mysql/my.cnf
# 添加如下内容
[mysqld]
character-set-server=utf8mb4
[client]
default-character-set=utf8mb4
[mysql]
default-character-set=utf8mb4

重新创建并运行容器,并同时挂载目录:

docker run -itd -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -v /etc/mysql:/etc/mysql/conf.d --name mysql mysql

其中-v参数是挂载宿主机的一个目录,把宿主机的一个目录挂载到容器上,注意需要修改--name,不允许重复。

根据官网文档(链接戳这里),默认的配置文件位置为/etc/mysql/my.cnf,自定义的配置文件位置可以为/etc/mysql/conf.d/etc/mysql/mysql.conf.d,因此将宿主机的/etc/mysql挂载到容器的/etc/mysql/conf.dMySQL会自动合并默认的配置文件/etc/mysql/my.cnf与自定义的配置文件(这里是/etc/mysql/conf.d/my.cnf)。

1b6f2b29a2cbe0bdf26bf9734278d55b.png

再次进入容器查看字符集:

b4a6878b44bee46393845b5b1502ecf8.png

可以看到字符集被修改为了utf8bm4

7 参考

  • Docker Hub MySQL
  • 博客园-Docker安装mysql
  • 博客园-Docker -V详解
  • 博客园-MySQL查看和修改字符集的方法
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Docker 安装 MySQL 和 Keepalived 的过程可以分为几个步骤: ### 步骤一:安装 Docker 首先,您需要确保您的系统上已安装 Docker。对于 Debian 或 Ubuntu 系统,您可以运行以下命令来更新软件包列表并安装 Docker: ```bash sudo apt-y docker.io ``` 对 CentOS 或 RHEL 系统,则运行以下命令: ```bash sudo yum update sudo yum install epel-release -y sudo yum install docker-ce -y ``` 安装完成后,启动 Docker 并设置为开机自启: ```bash sudo systemctl start docker sudo systemctl enable docker ``` ### 步骤二:拉取 MySQL 镜像 接下来,从 Docker Hub 拉取 MySQL 的官方镜像,并将其指定为特定版本(例如 `8.0`)。通常,您可以使用以下命令获取 MySQL: ```bash docker pull mysql:8.0 ``` ### 步骤三:配置 MySQL 容器 创建一个新的文件用于存储 MySQL 的配置信息(如数据库密码、端口等),例如: ```bash vi /etc/mysql/my.cnf ``` 在此文件中添加以下内容: ```ini [mysqld] port = 3306 basedir=/usr datadir=/var/lib/mysql socket=/var/run/mysqld/mysqld.sock skip-grant-tables # 可选:跳过授权表加载,在首次登录时启用root用户的创建 # 设置 root 用户密码 # INSERT THE PASSWORD HERE password=your_secure_password ``` 保存并关闭文件。 然后,通过容器名或ID将 MySQL 容器设置为在后台运行: ```bash docker run -d \ --name my-mysql-server \ -p 3306:3306 \ -v /path/to/data:/var/lib/mysql \ -e MYSQL_ROOT_PASSWORD=your_secure_password \ -e 'MYSQL_DATABASE=mydb' \ -e 'MYSQL_USER=myuser' \ -e 'MYSQL_PASSWORD=mypassword' \ mysql:8.0 ``` 这里,`/path/to/data` 替换为您希望数据存放的实际路径。 ### 步骤四:初始化 MySQL 初次启动 MySQL 容器可能会遇到权限问题,因为它尝试访问 `/var/lib/mysql` 目录但尚未拥有所有必要的权限。这通常是由于默认情况下,MySQL 服务不允许外部进程直接访问其目录造成的。为了解决这个问题,您需要修改 MySQL 的安全模式(`skip-grant-tables` 参数),并在第一次登录时完成初始化过程。具体的初始化步骤包括登录 MySQL 客户端和修改根用户权限: ```bash docker exec -u root -p CREATE DATABASE mydb; GRANT ALL PRIVILEGES ON mydb.* TO 'myuser'@'localhost' IDENTIFIED BY 'mypassword'; FLUSH PRIVILEGES; EXIT; ``` ### 步骤五:安装 Keepalived 为了实现高可用性,您可以安装 Keepalived 以及它的依赖: ```bash sudo apt-get install keepalived ``` 安装完成后,创建或编辑 `keepalived.conf` 文件,配置两台或更多机器上的 Keepalived 实例,以便在一台服务器故障时自动切换到另一台服务器。 ### 步骤六:启动和测试 Keepalived 确保 Keepalived 服务正在运行: ```bash sudo systemctl start keepalived sudo systemctl enable keepalived ``` 通过 Ping 测试和监控 MySQL 服务是否正常运行,并检查 Keepalived 是否能正确感知网络状态变化。 --- --- 相关问题 --- 1. 在安装过程中,如果遇到权限错误该如何解决? 2. 如何优化 MySQL 容器性能? 3. 怎样在生产环境中部署更复杂的高可用架构? 此解答基于较为通用的场景和假设,实际情况中需考虑具体环境和需求进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值