Docker与本地数据库连接

1、Docker

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

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

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

    2. Docker与本地数据库连接_第1张图片

       

    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镜像Docker与本地数据库连接_第2张图片

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;Docker与本地数据库连接_第3张图片

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

你可能感兴趣的:(mysql,数据库,ubuntu)