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数据库
- 如上启动mysql
- 创建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)
- 启动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连接不上
解决方法:
- 关闭防火墙,即可访问,命令如下
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
- 设置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删除命令
- 删除容器
#删除指定容器
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