docker安装mysql

2023-12-22 16:32:02

1.下载镜像

docker pull mysql:5.7

2.创建目录

创建docker目录

mkdir /usr/local/docker

创建mysql目录及挂载文件夹
我们在刚刚创建的docker目录中创建mysql文件夹 里面继续创建2个文件夹 分别为config和data

mkdir /usr/local/docker/mysql/config
mkdir /usr/local/docker/mysql/data

3.创建配置文件

进入config中创建并配置my.cnf文件 直接复制下面代码即可
编辑完成后保存退出 使用冒号:wq保存退出

[client]
# 端口号
port=3306
 
[mysql]
no-beep
default-character-set=utf8mb4
 
[mysqld]
# 端口号
port=3306
# 数据目录
datadir=/var/lib/mysql
# 新模式或表时将使用的默认字符集
character-set-server=utf8mb4
# 默认存储引擎
default-storage-engine=INNODB
# 将 SQL 模式设置为严格
sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"
#  最大连接数
max_connections=1024
# 表缓存
table_open_cache=2000
# 表内存
tmp_table_size=16M
# 线程缓存
thread_cache_size=10
 
# myisam设置
myisam_max_sort_file_size=100G
myisam_sort_buffer_size=8M
key_buffer_size=8M
read_buffer_size=0
read_rnd_buffer_size=0
 
# innodb设置
innodb_flush_log_at_trx_commit=1
innodb_log_buffer_size=1M
innodb_buffer_pool_size=8M
innodb_log_file_size=48M
innodb_thread_concurrency=33
innodb_autoextend_increment=64
innodb_buffer_pool_instances=8
innodb_concurrency_tickets=5000
innodb_old_blocks_time=1000
innodb_open_files=300
innodb_stats_on_metadata=0
innodb_file_per_table=1
innodb_checksum_algorithm=0
# 其他设置
back_log=80
flush_time=0
join_buffer_size=256K
max_allowed_packet=4M
max_connect_errors=100
open_files_limit=4161
sort_buffer_size=256K
table_definition_cache=1400
binlog_row_event_max_size=8K
sync_master_info=10000
sync_relay_log=10000
sync_relay_log_info=10000

4.编辑启动文件

vim startMysql.sh

docker run -d \
--privileged=true \
--name mysql57 \
-p 3306:3306 \
--restart=always \
-v /usr/local/docker/mysql/data:/var/lib/mysql \
-v /usr/local/docker/mysql/config/my.cnf:/etc/mysql/my.cnf \
-e MYSQL_ROOT_PASSWORD=root mysql:5.7 \

-d 后台运行

–privileged=true 使容器拥有真正的root权限

– name 设置容器名字

-p 端口号(主机端口号):端口号(容器内端口号) 这里将容器内的3306端口号映射到主机上的5508端口,外部访问的时候需要访问5508端口,隐藏了端口号

-v 挂载 将容器内的目录(:后面的目录)挂载到本机指定目录(:前面的目录) 以后修改mysql配置文件时 直接修改挂载的文件即可 可以理解为window系统中的快捷方式

-e 初始化root用户的密码

5.给安装脚本执行权限

chmod -R 777 startMysql.sh

6.启动mysql

./startMysql.sh

7.登录mysql

mysql -u root -p

文章来源:https://blog.csdn.net/weixin_43451374/article/details/135155082
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。