0002. docker mysql安装笔记

docker mysql安装笔记

直接上命令

[root@localhost ~] docker pull mysql:5.7
[root@localhost ~] docker run --name mysql_docker -d mysql:5.7
42f09819908bb72dd99ae19e792e0a5d03c48638421fa64cce5f8ba0f40f5846

mysql退出了
[root@localhost ~] docker ps -a
#错误日志 
[root@localhost ~] docker logs 42f09819908b 
error: database is uninitialized and password option is not specified You need to specify one of MYSQL_ROOT_PASSWORD, MYSQL_ALLOW_EMPTY_PASSWORD and MYSQL_RANDOM_ROOT_PASSWORD
这个三个参数必须指定一个(也就是mysql没有设置root密码,在构建容器的时候设置上就好了)

[root@localhost ~] docker run ‐‐name mysql_docker ‐e MYSQL_ROOT_PASSWORD=root ‐d mysql:5.7
b874c56bec49fb43024b3805ab51e9097da779f2f572c22c695305dedd684c5f

[root@localhost ~] docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 
b874c56bec49 mysql "docker‐entrypoint.sh" 4 seconds ago Up 3 seconds 3306/tcp mysql_docker

#将本机的3306端口和mysql容器的3306端口进行映射,这样外部才可访问到mysql
#docker run -p 3306:3306 --name mysql8.0 -e MYSQL_ROOT_PASSWORD=root -d mysql:8.0.16
[root@localhost ~] docker run ‐p 3306:3306 ‐‐name mysql_docker ‐e MYSQL_ROOT_PASSWORD=root ‐d mysql:5.7
ad10e4bc5c6a0f61cbad43898de71d366117d120e39db651844c0e73863b9434

[root@localhost ~] docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 
ad10e4bc5c6a mysql "docker‐entrypoint.sh" 4 seconds ago Up 2 seconds 0.0.0.0:3306‐>3306/tcp mysql_docker

启动docker映射到主机机时出现如下错误时:

/usr/bin/docker-current: 
error response from daemon: driver failed programming external connectivity on endpoint sc_mysql (1bc03030afe9f722ae1e6b46166172a70cf87bcc3f02f0acdac0be2a7f0f0036): 
(iptables failed: iptables --wait -t nat -A DOCKER -p tcp -d 0/0 --dport 3306 -j DNAT --to-destination 172.17.0.2:3306 ! -i docker0: iptables: No chain/target/match by that name.

这是由于来自守护进程的错误响应,而致使外部连接失败。删除,并重启docker服务

[root@localhost ] pkill docker                        # 终止进程
[root@localhost ] iptables -t nat -F                  # 清空 nat 表的所有链
[root@localhost ] ifconfig docker0 down               # 停止 docker 默认网桥
[root@localhost ] yum install bridge-utils -y         # 部分机器是无法使用 brctl,所以需要提前安装
[root@localhost ] brctl delbr docker0                 # 删除网桥  
[root@localhost ] systemctl restart docker            # 重启docker

几个其他的高级操作

[root@localhost ] docker run ‐‐name mysql03 ‐v /conf/mysql:/etc/mysql/conf.d ‐e MYSQL_ROOT_PASSWORD=my‐secret‐pw ‐d mysql:tag 
把主机的/conf/mysql文件夹挂载到 mysqldocker容器的/etc/mysql/conf.d文件夹里面 
改mysql的配置文件就只需要把mysql配置文件放在自定义的文件夹下(/conf/mysql)
 
[root@localhost ] docker run ‐‐name some‐mysql ‐e MYSQL_ROOT_PASSWORD=my‐secret‐pw ‐d mysql:tag ‐‐character‐set‐ server=utf8mb4 ‐‐collation‐server=utf8mb4_unicode_ci 
指定mysql的一些配置参数

-- docker下进入mysql命令行
[root@VM_0_8_centos ~]# docker exec -it 89c5b9c81e74  bash
root@89c5b9c81e74:/# mysql -u root -p
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值