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