Docker与本地数据库连接

1、Docker

是一个开源的应用容器,容器是完全使用沙箱机制,各个应用之间不会有连接,是单独运行的。

  1. 镜像:将应用程序所需要的环境和配置等文件打包在一起

    1. "mysql:5.7"前半部分的代表镜像的名称,后半部分代表版本号(若没有版本号则为最新版本latest)

    2.  

    3. docker images 查看镜像
      docker rmi 删除镜像
      docker push 推送镜像到服务器
      docker pull 从服务器拉取镜像
      docker save 保存镜像为压缩包
      docker load 加载压缩包为镜像

      拉取、查看镜像

      docker pull 从服务器拉取镜像

      docker images 查看拉取的镜像

      保存、导入镜像

      docker save -o [保存的目标文件名称] [镜像名称]

      docker 1 load -i 镜像包

  2. 容器:存放镜像运行进程所产生的文件,对外不可见

    容器相关命令:
    docker run:创建并运行一个容器,处于运行状态
    docker stop:停止一个运行的容器
    docker start:让一个停止的容器再次运行
    docker restart:重新启动容器
    docker rm:删除一个容器
    docker pause:让一个运行的容器暂停
    docker unpause:让一个容器从暂停状态恢复运行
创建并运行容器:

docker run --name containerName 1 -p 80:80 -d nginx

参数:

docker run :创建并运行一个容器 --name : 给容器起的名字,例如叫做ng -p :将宿主机端口与容器端口映射,冒号左侧是宿主机端口,右侧是容器端口 -d:后台运行容器 nginx:镜像名称,例如nginx

2、数据卷

数据与容器解耦需要用到数据卷,数据卷是一个虚拟目录,指向宿主机文件系统中的某个目录。

一旦完成数据卷挂载,对容器的一切操作都会作用在数据卷对应的宿主机目录了。这样,我们操作宿主机的/var/lib/docker/volumes/html目录,就等于操作容器内的/usr/share/nginx/html目录了。

数据卷操作的基本语法:

docker 1 volume [COMMAND]

创建数据卷:

docker 1 volume create 数据卷名

查看所有数据卷:

docker volume 数据卷名

挂载数据卷:

docker run --name ng -v html:/usr/share/nginx/html -p 8080:80 -d nginx

参数如下: -v html:/usr/share/nginx/html :把html数据卷挂载到容器内 的/usr/share/nginx/html这个目录中 nginx默认网页在nginx中的存储位置就是/usr/share/nginx/html目录 挂载后,宿主机的/var/lib/docker/volumes/html/_data目录就是nginx的网页 目录了,在这个目录中创建网页就可用直接访问了。

给MySQL挂载本地目录

步骤:

  • 1、从服务器端拉取mysql文件镜像
  • 2、创建目录/usr/mysql/data
  • 3、创建目录/usr/mysql/conf
  • 4、将提供的hmy.cnf文件上传到/usr/mysql/conf
  • 5、挂载/usr/mysql/data到mysql容器内数据存储目录
  • 6、挂载/usr/mysql/conf/hmy.cnf到mysql容器的配置文件
  • 7、设置MySQL密码

图片步骤:

1、拉取mysql镜像

2、在终端处输入容器运行代码:

docker run \
--name mysql \
-e MYSQL_ROOT_PASSWORD=root \
-p 3309:3306 \
-v /usr/mysql/conf/hmy.cnf:/etc/mysql/conf.d/hmy.cnf \
-v /usr/mysql/data:/var/lib/mysql \
-d \
mysql:8.0.20

即可完成运行

3、在终端处访问服务器地址:

mysql -u root -h 服务器地址 -p -P端口号

4、登陆进去后使用命令更改密码即可;

UPDATE mysql.user SET authentication_string='' WHERE user='root';
use mysql 
ALTER user root@'localhost' identified by '123456'

5、最后刷新权限即可;

flush privileges;

测试结果如上则表示成功挂载在本地目录。

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Docker是一种容器化技术,可在其中运行现代应用程序。Docker容器本身是一种虚拟化技术,它允许用户将应用程序与依赖项捆绑在一起,并以一种轻量级的方式运行在不同的环境中。Docker容器的关键优势在于能够轻松地在不同的环境中部署应用程序,达到开发人员和运维人员的持续整合、持续部署和持续交付。 Docker Compose是一种工具,它允许用户定义和运行多个Docker容器。使用Docker Compose可以轻松地配置容器之间的网络连接和依赖关系,使得多个Docker容器能够协同工作,从而形成一个完整应用程序。 连接本地数据库时,可以使用Docker Compose配置文件定义数据库容器和应用程序容器之间的连接。在Docker Compose配置文件中,可以指定数据库容器要映射到的本地端口,以及应用程序容器如何连接到本地数据库。例如,下面是一个简单的Docker Compose配置文件,用于连接一个MySQL数据库和一个PHP应用程序: version: '3.1' services: db: image: mysql:latest ports: - "3306:3306" environment: MYSQL_ROOT_PASSWORD: example_password php: build: . ports: - "80:80" depends_on: - db environment: DB_HOST: db DB_USER: root DB_PASSWORD: example_password 在上面的Docker Compose配置文件中,我们定义了两个服务:一个MySQL数据库服务和一个PHP应用程序服务。数据库服务的镜像是MySQL的最新版。我们将其映射到本地端口3306,并设置了MySQL的root密码。PHP应用程序服务使用Dockerfile进行构建。我们将其映射到本地端口80,并指定它依赖于数据库服务。然后我们通过环境变量将应用程序容器连接到本地数据库。 总之,Docker容器和Docker Compose的使用使得我们能够轻松地集成和部署多个容器,包括本地数据库,使得整个应用程序具有高效性、可靠性和扩展性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值