Debian下通过docker部署mysql

1.查询mysql版本

        docker search mysql

2.拉取mysql镜像

        docker pull mysql:5.7

3.创建mysql容器

       docker create --name mysql57 -e MYSQL_ROOT_PASSWORD=password -p  3306:3306 -v /data/mysql57-store:/var/lib/mysql --network=dockernet mysql:5.7

        或者直接运行:

docker run --name mysql57 -e MYSQL_ROOT_PASSWORD=password -p 3306:3306 -v /data/mysql57-store:/var/lib/mysql --network=dockernet mysql:5.7
 

        --name:  指定一个容器名称;

        -e: 定义EVN变量,这时设置一个root密码

        -p :  宿主机端口:容器端口

        -v: 数据卷:宿主机目录:容器目录(mysql存储在容器内部的,如果容器被删除,数据也会丢失。为了持久化数据,你可以挂载主机目录到容器内部的 MySQL 数据目录)  

        --network: 网络名字:在 Docker 中,如果两个容器连接到同一个网络(比如默认的 bridge 网络或者用户自定义的网络),它们确实可以通过容器名或者容器的 DNS 名称来进行通信,而不需要使用它们的 IP 地址。

     例如 --network: bridge

        docker network inspect bridge

在默认情况下,Docker 会在连接到同一个网络的容器之间设置一个简单的 DNS 服务,使得它们可以通过容器名进行通信。例如:

# 从 container1 发送 ping 到 container2
docker exec container1 ping container2

这里 container1container2 分别是容器的名称。

        

4,启动容器

        docker start mysql57

5,查看运行状态

        docker ps

6,进入容器查看数据

        docker exec -it mysql57 bash

        mysql -uroot -p

7, 查看容运行状态

        docker stats

  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值