docker运行mysql

//挂载后,删除、重启数据不会丢失
docker run -it -d --name mysql -p 3306:3306 -v /opt/dockermysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --restart=always mysql:5.6

参数解释

参数

解释

-t

在新容器内指定一个伪终端或终端。

-i

允许你对容器内的标准输入 (STDIN) 进行交互。

-d

后台运行

–name mysql

把容器命名为mysql

-p 3306:3306

端口映射 [IP]宿主机端口:容器端口

-v

绑定一个卷 宿主机路径:容器路径

-e

设置环境变量

–-restart=always

开机启动,失败也会一直重启

docker中python访问mysql数据库

  1. 如上启动mysql
  2. 创建py 文件如下
from sqlite3import Cursor 
from flask import Flask,request,make_response,jsonify import requests,pymysql import os import sys  

@app.route("/mysqltest" ,methods=["get"]) 
def mysq1ltest(): 
    db=pymysq1l.connect(host=ip1,port=3306, user="root"pasSwd=123456', db-="mysq1", charset='utf81) 
    cursor=db.cursor())
    cursor.execu("sekect * from user")
    data=cursor.fetchone() 
    print (data) 
    #response =make_response({"data":"join( data)) 
    return "data"
   
if __name__=='__main__':
   app.run(port=8081,debug=True)
  1. 启动python 容器,命令如下:
docker run -itd --name python -p 8081:8081 -v /opt/py:/opt/py python /bin/bash -c 'python /opt/py/app.py'

遇到问题:mysql 启动后宿主机可以通过navicat正常连接数据库,但是python连接不上

解决方法:

  1. 关闭防火墙,即可访问,命令如下
systemctl stop firewalld

#防火墙其他命令

#启动
systemctl start firewalld
#查看状态
systemctl status firewalld
# 释放端口
firewall-cmd --zone=public --add-port=8080/tcp --permanent
#移除端口
firewall-cmd --zone=public --remove-port=8080/tcp --permanent
#查看当前已经开放的端口号
firewall-cmd --zone=public --list-ports
#重启防火墙
firewall-cmd --reload
  1. 设置docker允许容器之间通信(此时需要启动防火墙,否则报错)
# 允许容器之间通信
iptables -A FORWARD -i docker0 -j ACCEPT
# 允许容器与主机之间通信
iptables -A INPUT -i docker0 -j ACCEPT

遇到的问题:
mysql 挂载路径后会生成临时文件auto.cnf ibdata1 ib_logfile0 ib_logfile1文件,需要删除后,才能运行

# 定义变量
mysql_path="/opt/dockermysql/data"
find $mysql_path -maxdepth 1 -type f -delete

docker删除命令

  1. 删除容器
#删除指定容器
docker rm  容器名或者ID
#删除全部容器
docker rm $(docker ps -aq)

#删除所有含有python的字符的容器
docker rm -f (docker ps -a | grep python |awk "print $1"})

命令 docker ps -a 用于列出所有容器的状态,包括正在运行的容器和已停止的容器。然后通过管道 | 将其输出传递给 grep python 命令,用于筛选出包含关键词 “python” 的行。这会输出包含 “python” 的所有行,包括容器ID、名称等。然后,使用 docker rm -f 命令来停止并删除筛选出的这些容器。但是你传递的是整行文本,而 docker rm -f 命令接受的是容器ID。为了使命令正常工作,需要使用 awk 命令来提取容器ID令 docker ps -a 用于列出所有容器的状态,包括正在运行的容器和已停止的容器。然后通过管道 | 将其输出传递给 grep python 命令,用于筛选出包含关键词 “python” 的行。这会输出包含 “python” 的所有行,包括容器ID、名称等。
然后使用 docker rm -f 命令来停止并删除筛选出的这些容器。但是传递的是整行文本,而 docker rm -f 命令接受的是容器ID。所以,为了使命令正常工作,需要使用 awk 命令来提取容器ID,并将其传递给 docker rm -f 命令。awk ‘{print $1}’ 可以提取文本中的第一个字段,也就是容器ID

docker run注意事项

如果dockerfile中有文件启动命令,只需启动容器,无需加bash

docker run -itd -p 8080:8081 --name python python