docker学习笔记02-安装mysql

1.安装mysql8

复制代码
下载MySQL镜像
docker pull mysql:8.0


创建并启动容器
docker run -itd --name mysqltest -p 9999:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql

其中-it是交互界面 -d是后台执行 -name 指定容器名称 
-p指定映射端口 -e设置环境变量  最后mysql是镜像名或者用镜像id

如果这条命令报错就重启docker再执行命令

    原因:
        docker服务启动时定义的自定义链DOCKER由于 centos7 firewall 被清掉

        firewall的底层是使用iptables进行数据过滤,建立在iptables之上,这可能会与 Docker 产生冲突。
    
        当 firewalld 启动或者重启的时候,将会从 iptables 中移除 DOCKER 的规则,从而影响了 Docker 的正常工作。

        当你使用的是 Systemd 的时候, firewalld 会在 Docker 之前启动,但是如果你在 Docker 启动之后再启动 或者重启 firewalld ,你就需要重启 Docker 进程了。

        重启docker服务及可重新生成自定义链DOCKER

这个1110就是本地对应的端口,访问这个会映射刀容器里的3306 好理解把

2.使用dbeaver连接

emo,报错了 我靠

右键数据库------》编辑连接------》驱动属性------将"allowPublicKeyRetrieval"设置为true

再次连接成功了 注意端口是1110

确实比单独安装mysql服务器快多了,真真是快速部署

3.创建一个mysql远程用户

注意容器退出的时候用ctrl+p+q哦,用exit会停止容器

复制代码
进入容器
docker exec -it mysqltest /bin/bash
进入数据库
mysql -uroot -p123456
创建一个远程连接用户

use mysql


创建本地用户
# 创建一个用户名为admin,密码为 admin123456 的本地用户。
create user 'admin'@'localhost' identified by 'admin123456';
grant all privileges on *.* to 'admin'@'localhost';
flush privileges;


创建外网可访问用户
# 创建一个用户名为adminwai,密码为 admin123456 的本地用户
create user 'adminwai'@'%' identified by 'admin123456';
grant all privileges on *.* to 'adminwai'@'%';
flush privileges;

本地用户不能远程访问哦,远程用户才可以哦 用这个adminwai用户

其他操作忽略

复制代码
修改用户
	#将用户名 admin 更新为 admin_newm
	rename user 'admin'@'localhost' to 'admin_new'@'localhost';
	#将用户名 admin 更新为 admin_newm
	update user set User='admin_new' where User='admin' and Host='localhost';
	# 刷新授权才会生效
	flush privileges;
	
删除用户
	drop user 'admin'@'localhost';
	flush privileges;
	
操作用户权限
查看用户权限
show grants for 'admin'@'localhost'; 

修改用户权限
# 使admin用户获得所有权限。
grant all privileges on *.* to 'admin'@'localhost';
# 使admin用户获得所有数据库中所有表的(*.*)select、insert、update、delete权限
grant select,insert,update,delete on *.* to 'admin'@'localhost';
# 如果只想让该用户访问某一个数据库写成:testdb.* 即可
grant all privileges on testdb.* to 'admin'@'localhost';
# 刷新授权才会生效
flush privileges;

修改密码
# 修改admin用户的密码
ALTER USER 'admin'@'localhost' IDENTIFIED WITH MYSQL_NATIVE_PASSWORD BY 'admin123456';
# 刷新授权才会生效
flush privileges;
相关推荐
ling___xi16 分钟前
《计算机网络》计网3小时期末速成课各版本教程都可用谢稀仁湖科大版都可用_哔哩哔哩_bilibili(笔记)
网络·笔记·计算机网络
星火开发设计29 分钟前
类型别名 typedef:让复杂类型更简洁
开发语言·c++·学习·算法·函数·知识
Gorgous—l1 小时前
数据结构算法学习:LeetCode热题100-多维动态规划篇(不同路径、最小路径和、最长回文子串、最长公共子序列、编辑距离)
数据结构·学习·算法
啦啦啦小石头1 小时前
Docker 换源
docker
中屹指纹浏览器1 小时前
中屹指纹浏览器底层架构深度解析——基于虚拟化的全维度指纹仿真与环境隔离实现
经验分享·笔记
Hello_Embed2 小时前
libmodbus 移植 STM32(基础篇)
笔记·stm32·单片机·学习·modbus
无聊的小坏坏2 小时前
实习笔记:用 /etc/crontab 实现定期数据/日志清理
笔记·实习日记
香芋Yu2 小时前
【机器学习教程】第04章 指数族分布
人工智能·笔记·机器学习
●VON2 小时前
Flutter for OpenHarmony 21天训练营 Day03 总结:从学习到输出,迈出原创第一步
学习·flutter·openharmony·布局·技术
香芋Yu2 小时前
【大模型教程——第四部分:大模型应用开发】第1章:提示工程与上下文学习 (Prompt Engineering & ICL)
学习·prompt