docker笔记4--实战用例

安装虚拟机

  • 安装虚拟机
    docker-machine create --engine-registry-mirror=https://nm7he5wc.mirror.aliyuncs.com -d virtualbox zdy

  • 查看信息
    docker info

  • 设置共享文件夹
    打开virtualbox
    点击 虚拟机 zdy 的设置
    点击共享文件夹
    点击 +
    新增固定分配或者临时分配目录

  • 添加网桥网卡
    点击网络-网卡3,改为网桥,修改为全部允许

  • 用 putty工具 登录
    用用户名= docker 密码= tcuser登录
    登录以后 用sudo -i 或 sudo su 转到root用户下

安装mysql

  • 下载mysql镜像
    docker pull mysql:latest
    docker pull mysql 要选择starts最高的那个name 进行下载

  • 查看镜像
    docker images

  • 运行容器

    • 写法1
      docker run --name dockermysql -p 3307:3306 -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql

      --name 为mysql的实例设置别名。 -p 3307为对外暴露的端口。3306是内部端口 
      -e MYSQL_ROOT_PASSWORD 设置mysql登录密码  -d 以守护进程运行(后台运行) 最后的mysql是镜像名称 
      
    • 写法2
      docker run -itd --name mysql1 -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql

    • 写法3
      docker run -itd --name mysql1 -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -v /d/volume/mysql:/var/lib/mysql mysql
      -v /d/volume/mysql:/var/lib/mysql 表示 把d盘/volume/mysql文件夹 挂到/var/lib/mysql路径

  • 安装mariadb (mysql 的姐妹版)
    docker run -p 3306:3306 -v /home/data/mariadb:/var/lib/mysql:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root --name mariadb -d mariadb:latest
    -v /zdy/mysql:/var/lib/mysql `
    冒号前面是宿主目录,后面是docker 容器中的路径。

    我测试了一下 采用共享方式把window目录共享给宿主主机,然后挂载到某个路径,无法创建容器
    只是创建了部分文件就会抛出异常 用
    docker logs mariadb 只是提到创建数据库文件时,二进制文件出错, 怀疑是ntfs 与linux 文件格式不同引起的,

  • 查看运行容器
    docker ps

  • 进入容器
    docker exec -it mysql1 /bin/bash

  • 登录mysql
    mysql -uroot -p123456

  • 授权
    grant all privileges on . to ‘root’@’%’ ;
    flush privileges;

  • 宿主连接 docker中的mysql
    可以再ifconfig中查看ip 一般是192.168.99 开头
    ip=192.168.99.*

  • 从 5.7 升级 8.0 版本的不会改变现有用户的身份验证方法,但新用户会默认使用新的 caching_sha2_password 。

客户端不支持新的加密方式。
方法之一,修改用户的密码和加密方式
ALTER USER ‘root’@‘localhost’ IDENTIFIED WITH mysql_native_password BY ‘密码’;
mysql8.*的新特性 caching_sha2_password 密码加密方式
以前版本的mysql密码加密使用的是 mysql_native_password
新添加的用户密码默认使用的 caching_sha2_password
如果在以前mysql基础上升级的 就得用户使用的密码加密使用的是 mysql_native_password
如果使用以前的密码加密方式,就修改文件 /etc/my.cnf

  • 数据库时区问题:
    链接数据库时serverTimezone=UTC这个参数出的问题
    只要改成serverTimezone=Asia/Shanghai就OK了!

  • 如果需要在 virtualbox 外部访问 boot2docker中的容器

    需要开启virtualbox 虚拟主机的端口映射 ,外部的程序才能连接 docker中的数据库
    选择虚拟主机 – 设置 – 网络 – 网卡(NAT 一般是网卡1 )–高级–端口转发 --端口转发规则(弹出窗) + 设置

名称协议主机ip主机端口子ip子端口
mysqlTCP33063306

安装redis

	docker search  redis 
	docker pull redis:latest 
	docker run --name redis  -d -p 6379:6379 redis
	docker ps
	docker exec -it redis /bin/bash

安装tomcat

	docker pull tomcat:latest 
	docker run --name tomcat -p 8080:8080 -v $PWD/test:/usr/local/tomcat/webapps/test -d tomcat  	
	docker exec -it tomcat /bin/bash

安装ngnix

	docker pull nginx:latest
	docker run --name nginx-test -p 8080:80 -d nginx

–name nginx-test:容器名称。
-p 8080:80: 端口进行映射,将本地 8080 端口映射到容器内部的 80 端口。
-d nginx: 设置容器在在后台一直运行。

导出容器

cd 要导出的路径
docker export 容器名|容器id > 备份文件名.tar	

docker export mariadb > my_mariadb.tar

导入容器备份成镜像,安装镜像

cat 文件名.tar |docker import - image_name:tag
cat my_mariadb.tar |docker import - mymariadb:0.0.1

  • 用docker images 查看导入的镜像
    导入后运行 原来带有的运行参数 必须都要带上,否则不能正常使用,
    并且一定要加上 command部分的内容 (通过 docker ps --no-trunc 查询)
    例如 :
    以下无法执行成功
    docker run --name mymariadb1 -d mymariadb:0.0.1 docker-entrypoint.sh - mysqld
    以下可以启动,但是宿主无法连接3306
    docker run -v /home/data/mariadb:/var/lib/mysql --name mymariadb -d mymariadb:0.0.1 docker-entrypoint.sh mysqld
    以下可以执行成功
    docker run -p 3306:3306 -v /home/data/mariadb:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root --name mymariadb -d mymariadb:0.0.1 docker-entrypoint.sh mysqld

  • 查看运行详细情况
    $ docker top redis

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值