docker中镜像映射和端口映射的实现步骤

 更新时间:2024年11月24日 10:19:06   作者:Lsc`  
本文介绍了在Docker中进行镜像映射和端口映射,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

镜像映射

镜像映射 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

# -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部署和端口映射案例

# 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 

到此这篇关于docker中镜像映射和端口映射的实现步骤的文章就介绍到这了,更多相关docker 镜像映射和端口映射内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

相关文章

  • Docker镜像推送(push)到Docker Hub的实现

    Docker镜像推送(push)到Docker Hub的实现

    这篇文章主要介绍了Docker镜像推送(push)到Docker Hub的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09
  • docker搭建redis主从哨兵集群的实现步骤

    docker搭建redis主从哨兵集群的实现步骤

    本文主要介绍了docker搭建redis主从哨兵集群的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • 使用docker安装部署NextCloud私人网盘的方法步骤

    使用docker安装部署NextCloud私人网盘的方法步骤

    本文主要介绍了使用docker安装部署NextCloud私人网盘的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • Docker上部署FastApi的示例代码

    Docker上部署FastApi的示例代码

    本文主要介绍了Docker上部署FastApi的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • n8n搭建docker部署教程

    n8n搭建docker部署教程

    文章指导如何通过Docker搭建n8n,包含更换镜像源、修改daemon.json配置、下载1.8.2版本及使用docker-compose.yml和.env文件部署的步骤,旨在提升部署效率与便捷性
    2025-07-07
  • 部署Prometheus+Grafana监控平台实践

    部署Prometheus+Grafana监控平台实践

    文章介绍了如何在宿主机上配置Prometheus和Grafana,并使用NodeExporter监控Linux服务器,通过Docker部署Prometheus和Grafana,并在Prometheus中添加NodeExporter作为数据源,最后,通过Grafana导入仪表盘来可视化监控数据
    2026-01-01
  • docker pull mysql报missing signature key错误解决办法

    docker pull mysql报missing signature key错误解决办法

    这篇文章主要给大家介绍了关于docker pull mysql报missing signature key错误的解决办法,docker pull mysql命令用于从Docker Hub下载MySQL镜像,需要的朋友可以参考下
    2023-11-11
  • 解决docker 容器设置中文语言包出现的问题

    解决docker 容器设置中文语言包出现的问题

    这篇文章主要介绍了解决docker 容器设置中文语言包出现的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-03-03
  • docker prune命令定时清理不常用数据的操作方法

    docker prune命令定时清理不常用数据的操作方法

    使用docker引擎服务时间久了,会发现磁盘空间越来越大,现在要删除关于docker相关不用的数据来释放磁盘空间,这篇文章主要介绍了docker prune命令 可定时清理不常用数据,需要的朋友可以参考下
    2022-10-10
  • docker 拉取镜像失败 read: connection reset by peer

    docker 拉取镜像失败 read: connection reset&nbs

    本文主要介绍了docker 拉取镜像失败 read: connection reset by peer,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-12-12

最新评论