docker中镜像映射和端口映射
镜像映射
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | 镜像映射 docker - v # 在宿主机上修改文件或增加文件 容器跟着变化 # 运行出一个 centos77 容器,不进入, 做目录映射 # 把宿主机的 /root/lqz文件夹 映射到 容器内部的 /lqz文件夹(容器没有会自动创建) # -v可以写多个,可以是文件或文件夹 1 cd # 回家 前提是你是root用户 2 mkdir lqz # 在root目录下创建lqz文件夹 3 运行容器,做目录映射 '宿主机中/root/lqz文件夹跟 容器中 /lqz文件加做映射' docker run - id --name=centos77 - v /root/lqz : /lqz centos:centos7 4 在宿主机的 /root/lqz 下新建 xx.txt vim xx.txt 5 来到容器内部:看这个文件在不在 cat xx.txt 6 他们是相互影响的: 容器内部修改文件---》会影响外部 外部修改文件---》影响内部 # 目录映射好处是,后期咱们部署django项目 1 有个django容器,做好映射,代码放在宿主机上即可,以后更新了代码,只要重启容器,代码就是最新了 2 运行mysql容器---》mysql配置文件,数据data目录,放在宿主机上做好映射 如果 mysql容器---》表数据,放到容器中---》如果删了容器---》数据库全没了 表数据,放在宿主机上---》把容器删除---》表数据还在----》再启动一个容器做好映射---》数据都还在 |
端口映射 docker -p
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | # -p参数:端口映射 容器中启动一个mysql5.7 --》容器中的3306监听,宿主机3306没人监听,做端口映射后,宿主机的3306就被docker的这个容器监听了 '启动mysql容器 -p 宿主机端口:容器端口' # 以后台守护进程运行mysql容器,mysql的root用户密码是123456,宿主机和容器做了端口映射 docker run - id --name=mysql5.7 -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7 '-e 参数 具体看官网mysql的参数介绍' # netstat -nlp |grep 3307 查看本机80端口占用情况 # 查看宿主机 3307端口占用情况 yum install net-tools -y netstat -nlp | grep 3307 # 被docker占了 # 以后访问宿主机3307端口就等于访问容器的3306端口 # win机器可以远程链接 mysql -命令行链接:mysql -h 10.0.0.110 -P 3307 -uroot -p -Navicate: 链接,创建lqz数据库 -python: # 宿主机--》进入到容器内部--》进入到mysql,查看有没有创建lqz这个库 docker exec -it mysql5.7 /bin/bash # 进入容器内部 # 登录mysql用户 mysql -uroot -p # 进入mysql show databases; # 查看所有数据库 |
MySQL部署和端口映射案例
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 | # dokcer 中部署mysql,以后不需要在宿主机上装mysql #1 假如没有做目录映射---》配置文件--》表数据都在容器中---》一旦删除--》所有都没了 # 2 做目录(配置文件和数据文件)和端口映射 # 做目录映射:data文件,配置文件 # 在宿主机创建文件夹 mkdir /mysql mkdir /mysql/conf .d mkdir /mysql/data/ # 进入到配置文件修改配置 没有文件会自动创建 vim /mysql/my .cnf 或者 vi /mysql/my .cnf 因为没安装vim # 文件内容 "" " [client] default-character- set =utf8 [mysqld] user=mysql character- set -server=utf8 default_authentication_plugin=mysql_native_password secure_file_priv= /var/lib/mysql expire_logs_days=7 sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION max_connections=1000 "" " 做好映射之后 执行命令 docker run -di - v /mysql/data/ : /var/lib/mysql - v /mysql/conf .d: /etc/mysql/conf .d - v /mysql/my .cnf: /etc/mysql/my .cnf -p 3307:3306 --name mysql5.7 -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7 # 一条命令过长 可以用&& 分割 # 执行上面这一句 相当是映射了三个文件 同时还映射了端口和起密码 - v /mysql/data/ : /var/lib/mysql - v /mysql/conf .d: /etc/mysql/conf .d - v /mysql/my .cnf: /etc/mysql/my .cnf -p 3306:3306 --name mysql5.7 -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7 # 关闭容器,删除容器,myslq的容器没了,但是数据在宿主机上放着 docker stop mysql2 docker rm mysql2 # 再运行起一个容器,做好目录映射,数据都回来了 端口还可以修改 docker run -di - v /mysql/data/ : /var/lib/mysql - v /mysql/conf .d: /etc/mysql/conf .d - v /mysql/my .cnf: /etc/mysql/my .cnf -p 3307:3306 --name mysql2 -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7 |