Docker Compose--安装MySQL8的方法(实例)

news/2024/8/26 10:02:28 标签: docker, 容器, 运维

原文网址:Docker Compose--安装MySQL8的方法(实例)_IT利刃出鞘的博客-CSDN博客

简介

本文介绍使用Docker compose安装MySQL8的方法。

Java技术星球:way2j.com

脚本及配置

目录结构

├── docker-compose.yml # docker-compose.yml文件
├── conf
│   └── my.cnf  # MySQL配置文件
├── data # 数据库数据文件目录
├── log # 日志存放目录
└── bak # 手动备份数据的目录

data、log不需要手动创建,在docker compose运行时会自动创建。

docker-compose.yml

version: '3.1'
services:
    mysqldb:
        # 启动方式
        #restart: unless-stopped
        
        # 镜像
        image: mysql:8.0
        # 容器名字
        container_name: mysql8
        privileged: true
        environment:
          # 时区
          TZ: Asia/Shanghai
          # root用户的密码
          MYSQL_ROOT_PASSWORD: 123456
          # 用户(不能是root, 后续需要给新用户赋予权限)
          MYSQL_USER: adminUser
          # 用户密码
          MYSQL_PASSWORD: 222333
        command:
          --character-set-server=utf8mb4
          --collation-server=utf8mb4_general_ci
          --explicit_defaults_for_timestamp=true
        ports:
          - 3306:3306
        volumes:
          - ./log/:/var/log/mysql/
          - ./data/:/var/lib/mysql/
          - ./conf/:/etc/mysql/conf.d/
          - ./bak/:/bak/

my.cnf(mysql配置文件)

[client]
default-character-set=utf8mb4
 
[mysql]
default-character-set=utf8mb4
 
[mysqld]
#服务端口号 默认3306
port=3306

# 数据路径,默认是/var/lib/mysql/
#datadir = /app/data/
 
init_connect='SET NAMES utf8mb4'
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci
 
# 最大连接数
max_connections=200
 
# 连接失败的最大次数。防止有人从该主机试图攻击数据库系统
max_connect_errors=20
 
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB

skip-name-resolve

# binlog过期天数。默认是0(永远存在)
expire_logs_days=2

运行docker compose

法1:到配置文件目录下运行

docker compose up

会打印详细启动日志,而且会占用控制台。 

后台运行的方法:

docker compose up -d

-d:在后台运行。

法2:指定配置文件

docker compose -f /work/docker/docker-compose/mysql/docker-compose.yml up

docker compose的启动、停止等命令,全都是这样的,要么在配置文件目录下执行,要么指定配置文件。 

查看运行结果

compose查看

docker compose ls

docker查看

docker ps

给用户赋予权限

进到MySQL这个docker

docker exec -it mysql8 bash

连接到MySQL服务

mysql -uroot -p

回车后输入密码:123456,然后再回车即可。

授予所有权限

GRANT ALL ON *.* TO 'adminUser'@'%';

 刷新权限

FLUSH PRIVILEGES;

Navicat连接测试

停止容器

docker compose stop

停止容器,但不删除容器。 

启动容器

docker compose start 

删除容器

法1:rm

docker compose rm

只删除容器 

法2:down

docker compose down

停止容器,然后删除容器。 


http://www.niftyadmin.cn/n/5558124.html

相关文章

微软Edge浏览器中的自定义用户代理字符串:深度解析与实践

浏览器的用户代理(User Agent,简称UA)字符串是一个重要的信息载体,它向服务器提供了浏览器类型、操作系统、设备类型等关键信息。在某些情况下,开发者或用户可能需要自定义用户代理字符串以满足特定的需求,…

【Web前端技术 01】 探索HTML5的奥秘:为初学者打造网页的基石

🚀 探索HTML5的奥秘:为初学者打造网页的基石 🎓 引言 🌍 在这个数字化的世界中,互联网已成为我们探索和学习的重要工具。对于初学者来说,理解HTML5是开启网页设计和开发大门的第一步。HTML5不仅是一种语言…

GitHub 令牌泄漏, Python 核心资源库面临潜在攻击

TheHackerNews网站消息,软件供应链安全公司 JFrog 的网络安全研究人员称,他们发现了一个意外泄露的 GitHub 令牌,可授予 Python 语言 GitHub 存储库、Python 软件包索引(PyPI)和 Python 软件基金会(PSF&…

解决 Vscode不支持c++11的语法

问题: 解决方案: 1、按 CtrlShiftP 调出命令面板,输入 C/C: Edit Configurations (UI) 并选择它。这将打开 C/C 配置界面 2、打开 c_cpp_properties.json 文件 3、编辑 c_cpp_properties.json 4、保存 c_cpp_properties.json 文件。 关闭并…

硅纪元视角 | 微软开发全新AI模型,革新电子表格处理效率!

在数字化浪潮的推动下,人工智能(AI)正成为塑造未来的关键力量。硅纪元视角栏目紧跟AI科技的最新发展,捕捉行业动态;提供深入的新闻解读,助您洞悉技术背后的逻辑;汇聚行业专家的见解,…

使用Micronaut进行无服务器应用开发

随着云计算和无服务器架构的普及,开发者开始寻求高效且可扩展的解决方案来构建现代应用。Micronaut作为一个新兴的、轻量级的框架,提供了构建无服务器应用的理想工具集。在这篇博客中,我们将深入探讨如何使用Micronaut进行无服务器应用开发&a…

Azure Repos 仓库管理

从远端仓库克隆到本地 前提:本地要安装git,并且登录了账户 1.在要放这个远程仓库的路径下,打git 然后 git clone https://.. 如果要登录验证,那就验证下 克隆完后,cd 到克隆的路径, 可以用 git branch -a //查看分支名 git status //查看代码状态 删除…

「AI得贤招聘官」通过首批“AI产业创新场景应用案例”评估

近日,上海近屿智能科技有限公司的「AI得贤招聘官」,经过工业和信息化部工业文化发展中心数字科技中心的严格评估,荣获首批“AI产业创新场景应用案例”。 据官方介绍,为积极推进通用人工智能产业高质量发展,围绕人工智能…