docker-compose 简单部署MySQL Database

docker-compose 简单部署MySQL Database

本博文部署MySQL 并与上篇部署的 Flask进行关联

主博客目录:《从零开始学习搭建量化平台笔记》


文章目录

  • [docker-compose 简单部署MySQL Database](#docker-compose 简单部署MySQL Database)
    • [部署 MySQL](#部署 MySQL)
    • [MySQL 开放端口与权限](#MySQL 开放端口与权限)

主项目计划需要搭建一个MySQL 数据库为其他部件提供数据,为了避免搭完就忘,因此就有了这个博客。

任务:搭建一个MySQL容器,给Flask部件提供一个只读用户权限,用来读取数据并生成网页。

部署 MySQL

bash 复制代码
# 创建工作目录
mkdir mysql
cd mysql
# 创建映射目录
mkdir conf datadir mysir source
touch conf/my.cnf

vim conf/my.cnf 编写 mysql配置文件:

my.cnf 复制代码
[mysqld]
user=mysql
default-storage-engine=INNODB
character-set-server=utf8
character-set-client-handshake=FALSE
collation-server=utf8_unicode_ci
init_connect='SET NAMES utf8'
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8

vim docker-compose.yml 编写 docker-compose.yml, 需注意缩进:

docker-compose.yml 复制代码
version: '3'

networks:
    n-bridge:
        external: true

services:
    varsql:
        image: mysql
        container_name: mysql
        ports:
            - "3306:3306"
        volumes:
            - mysql/mydir:/mydir
            - mysql/datadir:/var/lib/mysql
            - mysql/conf/my.cnf:/etc/my.cnf
            # 数据库还原目录 可将需要还原的sql文件放在这里
            - mysql/source:/docker-entrypoint-initdb.d
        restart: always

        logging:
            driver: json-file
            options:
                max-size: "20m" # 单个文件大小为20m
                max-file: "2" # 最多2个文件
        environment:
            MYSQL_DATABASE: YourDatabaseName
            MYSQL_ROOT_PASSWORD: YourPassword
            TZ: Asia/Shanghai
        networks:
            n-bridge:
                ipv4_address: 171.171.0.4

MySQL 开放端口与权限

查看是否创建成功:

复制代码
sudo docker ps

若 STATUS != Up 可以查看 logs 排查问题:

复制代码
sudo docker logs mysql --tail=100

进入MySQL Docker容器:

复制代码
sudo docker exec -it mysql /bin/bash

运行 MySQL:

复制代码
mysql -uroot -p

再输入docker compose 中填写的密码。

若登录成功,进行SQL命令操作。

查看已有数据库名称:

sql 复制代码
SHOW DATABASES;

创建新的数据库flask_ex

sql 复制代码
CREATE DATABASE flask_ex;

删除数据库命令:

sql 复制代码
DROP DATABASE flask_ex;

显示所有用户与端口,用户与端口绑定为唯一账户

sql 复制代码
SELECT user,host FROM mysql.user;

创建flask只读用户,只对flask端口开放(网桥端口映射在上篇博文中设置过):

sql 复制代码
CREATE USER 'flask_web'@'flask.my-bridge' IDENTIFIED BY "password";

显示用户所有权限:

sql 复制代码
SHOW grants for 'flask_web'@'flask.my-bridge';

清除用户所有权限

sql 复制代码
REVOKE all on *.* from 'flask_web'@'flask.my-bridge';

更改用户对flask_ex数据库只有只读权限:

sql 复制代码
GRANT SELECT ON flask_ex.* TO 'flask_web'@'flask.my-bridge' IDENTIFIED BY "password";

显示用户所有权限:

sql 复制代码
SHOW grants for 'flask_web'@'flask.my-bridge';

若添加成功,这样我们对flask端口的只读用户就创建完毕了。

以下为创建用户并开放权限通用命令:

sql 复制代码
# 创建只读账户
CREATE user 'username'@'%' IDENTIFIED BY "password";
GRANT SELECT ON dbname.* TO 'username'@'%' IDENTIFIED BY "password";
FLUSH PRIVILEGES;

# 赋予部分权限
GRANT select,delete,update,insert ON dbname.* TO 'username'@'%' IDENTIFIED BY "password    ";

# 创建完整账户
GRANT all privileges ON dbname.* TO 'username'@'%' IDENTIFIED BY "password";


# 修改密码
update user set password = password('password') where user = 'username';


# 查看本地root的权限,没有指定后面的localhost则默认为'%'
show grants for root@'localhost';
相关推荐
冒泡的肥皂3 小时前
MVCC初学demo(一
数据库·后端·mysql
.Shu.4 小时前
Redis Reactor 模型详解【基本架构、事件循环机制、结合源码详细追踪读写请求从客户端连接到命令执行的完整流程】
数据库·redis·架构
Bruce_Liuxiaowei6 小时前
MySQL完整重置密码流程(针对 macOS)
mysql
麦麦大数据6 小时前
F003疫情传染病数据可视化vue+flask+mysql
mysql·flask·vue·大屏·传染病
薛晓刚6 小时前
当MySQL的int不够用了
数据库
SelectDB技术团队7 小时前
Apache Doris 在菜鸟的大规模湖仓业务场景落地实践
数据库·数据仓库·数据分析·apache doris·菜鸟技术
AI大模型7 小时前
基于 Docker 的 LLaMA-Factory 全流程部署指南
docker·llm·llama
星空下的曙光7 小时前
mysql 命令语法操作篇 数据库约束有哪些 怎么使用
数据库·mysql
小楓12017 小时前
MySQL數據庫開發教學(一) 基本架構
数据库·后端·mysql
染落林间色7 小时前
达梦数据库-实时主备集群部署详解(附图文)手工搭建一主一备数据守护集群DW
数据库·sql