6.5.Docker数据管理和端口映射应用

文章目录

  • 实战总体步骤
  • 案例1:安装tomcat(端口映射使用)
  • 案例2:安装mysql(数据卷应用)
    • 测试版
    • 实战版
  • 案例3:安装Redis(数据卷应用)

实战总体步骤

  1. 搜索镜像

    可以在Dockerhub中查看容器如何使用,包括拉取和启动等。

  2. 拉取镜像

  3. 查看镜像

  4. 启动镜像

  5. 停止镜像

  6. 移除镜像

案例1:安装tomcat(端口映射使用)

  1. 搜索镜像

    docker hub上查找tomcat或通过命令搜索

    [root@zyn01 ~]# docker search -f is-official=true tomcat
    NAME      DESCRIPTION                                     STARS     OFFICIAL
    tomcat    Apache Tomcat is an open source implementati…   3667      [OK]
    tomee     Apache TomEE is an all-Apache Java EE certif…   115       [OK]
    
  2. 拉取镜像

    从docker hub拉取镜像到本地

    [root@zyn01 ~]# docker pull tomcat
    
  3. 查看镜像

    [root@zyn01 ~]# docker images tomcat
    REPOSITORY   TAG       IMAGE ID       CREATED       SIZE
    tomcat       latest    b64abfdee99c   2 years ago   668MB
    
  4. 启动镜像

    使用tomcat镜像创建容器实例

    [root@zyn01 ~]# docker run -it -d -p 8080:8080 tomcat
    7aa22c83581d11d6dc33e89511fe383b000fa4aa48309bbbc820ee9d1c1996b8
    [root@zyn01 ~]# docker ps
    CONTAINER ID   IMAGE     COMMAND             CREATED              STATUS              PORTS                                       NAMES
    db6b2e945248   tomcat    "catalina.sh run"   About a minute ago   Up About a minute   0.0.0.0:8080->8080/tcp, :::8080->8080/tcp   epic_jang
    

    -p 小写,主机端口:docker容器端口

    -P 大写,随机分配端口

    -i:交互

    -t:tty终端

    -d:后台

❓访问localhost:8080显示404。

可能是没有映射端口;可能是没有关闭防火墙;

新版tomcat需要进行如下修改:

把webapps.dist目录换成webapps,再次访问localhost:8080,访问成功。

[root@zyn01 ~]# docker exec -it db6b2e945248 /bin/bash
root@db6b2e945248:/usr/local/tomcat# ls
BUILDING.txt     LICENSE  README.md      RUNNING.txt  conf  logs            temp     webapps.dist
CONTRIBUTING.md  NOTICE   RELEASE-NOTES  bin          lib   native-jni-lib  webapps  work
root@db6b2e945248:/usr/local/tomcat# rm webapps
rm: cannot remove 'webapps': Is a directory
root@db6b2e945248:/usr/local/tomcat# rm -r webapps
root@db6b2e945248:/usr/local/tomcat# mv webapps.dist/ webapps
  1. 免修改版本操作流程

    docker pull billygoo/tomcat8-jdk8
    docker run -d -p 8080:8080 --name mytomcat8 billygoo/tomcat8-jdk8
    

案例2:安装mysql(数据卷应用)

测试版

  1. 搜索镜像

    docker hub上查找mysql或通过命令搜索。

    [root@zyn01 ~]# docker search -f is-official=true mysql
    NAME         DESCRIPTION                                     STARS     OFFICIAL
    mysql        MySQL is a widely used, open-source relation…   15055     [OK]
    
  2. 拉取镜像

    从docker hub拉取镜像到本地

    [root@zyn01 ~]# docker pull mysql
    
  3. 查看镜像

    [root@zyn01 ~]# docker images
    REPOSITORY     TAG       IMAGE ID       CREATED                  SIZE
    mysql          latest    96a1b6f60db8   Less than a second ago   592MB
    
  4. 启动镜像

    如何启动?https://hub.docker.com/_/mysql

    使用mysql镜像创建并启动容器实例

    [root@zyn01 ~]# docker run -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -d --name mysql mysql
    f3da95267e1eba21959c7739bd5967fef956d5a44b37e763b80e1ce68e08d77d[root@zyn01 ~]# docker ps
    CONTAINER ID   IMAGE     COMMAND                  CREATED          STATUS          PORTS                                                  
    NAMES
    f3da95267e1e   mysql     "docker-entrypoint.s…"   4 seconds ago    Up 3 seconds    0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp   
    mysql
  5. 进入容器测试mysql数据库,创建数据库和表

    [root@zyn01 ~]# docker exec -it f3da95267e1e /bin/bashbash-5.1# mysql -uroot -p123456
    mysql: [Warning] Using a password on the command line interface can be insecure.
    Welcome to the MySQL monitor.  Commands end with ; or \g.
    Your MySQL connection id is 9
    Server version: 8.4.0 MySQL Community Server - GPLCopyright (c) 2000, 2024, Oracle and/or its affiliates.Oracle is a registered trademark of Oracle Corporation and/or its
    affiliates. Other names may be trademarks of their respective
    owners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql> create database db01;
    Query OK, 1 row affected (0.00 sec)mysql> use db01;
    Database changed
    mysql> create table aa(id int,name varchar(20));
    Query OK, 0 rows affected (0.01 sec)mysql> insert into aa values(1,'zyn');
    Query OK, 1 row affected (0.01 sec)mysql> select * from aa;
    +------+------+
    | id   | name |
    +------+------+
    |    1 | zyn  |
    +------+------+
    1 row in set (0.00 sec)
    

    ❓存在插入中文乱码的情况!

    原因:docker上默认字符集编码隐患,使用mac本地客户端工具可以正常显示和插入中文,但是docker里面的mysql容器实例查看,内容如下:

    mysql>  SHOW VARIABLES LIKE 'character%';
    +--------------------------+--------------------------------+
    | Variable_name            | Value                          |
    +--------------------------+--------------------------------+
    | character_set_client     | latin1                         |
    | character_set_connection | latin1                         |
    | character_set_database   | utf8mb4                        |
    | character_set_filesystem | binary                         |
    | character_set_results    | latin1                         |
    | character_set_server     | utf8mb4                        |
    | character_set_system     | utf8mb3                        |
    | character_sets_dir       | /usr/share/mysql-8.4/charsets/ |
    +--------------------------+--------------------------------+
    8 rows in set (0.00 sec)mysql> select * from aa;
    +------+------+
    | id   | name |
    +------+------+
    |    1 | zyn  |
    |    2 | ??   |
    +------+------+
    2 rows in set (0.00 sec)
    

    接下来给出解决方案。容器删除后,数据将丢失。接下来通过挂在容器卷实现容器移除后再次重启容器数据维持不变。

实战版

  1. 新建mysql容器

    docker run -d -p 3306:3306 --privileged=true -v /zzyyuse/mysql/log:/var/log/mysql -v /zzyyuse/mysql/data:/var/lib/mysql -v /zzyyuse/mysql/conf:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=123456  --name mysql mysql
    
  2. 新建my.cnf,通过容器卷同步给mysql容器实例

    [root@zyn01 ~]# cd /zzyyuse/mysql/conf/
    [root@zyn01 conf]# vim my.cn
    [client]
    default_character_set=utf8
    [mysqld]
    collation_server = utf8_general_ci
    character_set_server = utf8
    
  3. 修改字符集操作后,重启mysql容器再次查看字符集编码并测试插入中文。

    [root@zyn01 conf]# docker restart  mysql
    mysql> [root@zyn01 ~]# docker exec -it mysql /bin/bash
    bash-5.1# mysql -uroot -p123456
    mysql: [Warning] Using a password on the command line interface can be insecure.
    Welcome to the MySQL monitor.  Commands end with ; or \g.
    Your MySQL connection id is 9
    Server version: 8.4.0 MySQL Community Server - GPLCopyright (c) 2000, 2024, Oracle and/or its affiliates.Oracle is a registered trademark of Oracle Corporation and/or its
    affiliates. Other names may be trademarks of their respective
    owners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql> SHOW VARIABLES LIKE 'character%';
    +--------------------------+--------------------------------+
    | Variable_name            | Value                          |
    +--------------------------+--------------------------------+
    | character_set_client     | utf8mb3                        |
    | character_set_connection | utf8mb3                        |
    | character_set_database   | utf8mb3                        |
    | character_set_filesystem | binary                         |
    | character_set_results    | utf8mb3                        |
    | character_set_server     | utf8mb3                        |
    | character_set_system     | utf8mb3                        |
    | character_sets_dir       | /usr/share/mysql-8.4/charsets/ |
    +--------------------------+--------------------------------+
    8 rows in set (0.01 sec)mysql> create database dn01;
    Query OK, 1 row affected (0.01 sec)
    mysql> use dn01;
    Database changed
    mysql> create table aa(id int,name varchar(20));
    Query OK, 0 rows affected (0.01 sec)mysql> select * from aa;
    +------+--------+
    | id   | name   |
    +------+--------+
    |    1 | 张 三    |
    +------+--------+
    1 row in set (0.00 sec)
    
  4. 本次绑定了数据卷,因此移除容器后再次重启容器,数据依然存在

    [root@zyn01 conf]# docker stop mysql
    mysql
    [root@zyn01 conf]# docker rm mysql
    mysql
    [root@zyn01 conf]# docker run -d -p 3306:3306 --privileged=true -v /zzyyuse/mysql/log:/var/log/mysql -v /zzyyuse/mysql/data:/var/lib/mysql -v /zzyyuse/mysql/conf:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=123456  --name mysql mysql
    3fdcedd80ef699764860393a377048ebb0ecc4400cd15e6e4ab4159e407ff631
    [root@zyn01 ~]# docker exec -it mysql /bin/bash
    bash-5.1# mysql -uroot -p123456
    mysql: [Warning] Using a password on the command line interface can be insecure.
    Welcome to the MySQL monitor.  Commands end with ; or \g.
    Your MySQL connection id is 9
    Server version: 8.4.0 MySQL Community Server - GPLCopyright (c) 2000, 2024, Oracle and/or its affiliates.Oracle is a registered trademark of Oracle Corporation and/or its
    affiliates. Other names may be trademarks of their respective
    owners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql> use dn01;
    Reading table information for completion of table and column names
    You can turn off this feature to get a quicker startup with -ADatabase changed
    mysql> select * from aa;
    +------+--------+
    | id   | name   |
    +------+--------+
    |    1 | 张 三    |
    +------+--------+
    1 row in set (0.00 sec)
    

案例3:安装Redis(数据卷应用)

  1. 拉取redis镜像

    docker pull redis:6.0.8
    
  2. 运行镜像

    [root@zyn01 conf]# docker run -d -p 6379:6379 redis:6.0.8
    d2cc16415883b0352c0d239692a17a0ac0ac7b7c04f16fea4060948769b64d4d
    [root@zyn01 conf]# docker ps
    CONTAINER ID   IMAGE         COMMAND                  CREATED             STATUS             PORTS                                                  NAMES
    d2cc16415883   redis:6.0.8   "docker-entrypoint.s…"   4 seconds ago       Up 3 seconds       0.0.0.0:6379->6379/tcp, :::6379->6379/tcp              magical_edison
    [root@zyn01 conf]# 
    [root@zyn01 conf]# docker exec -it d2cc16415883 /bin/bash
    root@d2cc16415883:/data# redis-cli
    127.0.0.1:6379> set k1 v1
    OK
    127.0.0.1:6379> get k1
    "v1"
    127.0.0.1:6379> ping
    PONG
    
  3. 在宿主机下新建目录/app/redis,将redis.conf文件上传至该目录并进行如下修改

    #1.开启redis验证 可选
    requirepass 123
    #2.允许redis外地连接 必须注释掉
    # bind 127.0.0.1
    #3.将daemonize yes注释起来或者daemonize no设置,因为该配置和docker run中-d参数冲突,会导致容器一直启动失败
    daemonize no
    #4.开启redis数据持久化  可选
    appendonly yes
    
  4. 停止和删除redis容器,重新创建进行测试

    [root@zyn01 redis]# docker ps
    CONTAINER ID   IMAGE         COMMAND                  CREATED          STATUS          PORTS                                                  NAMES
    d2cc16415883   redis:6.0.8   "docker-entrypoint.s…"   25 minutes ago   Up 25 minutes   0.0.0.0:6379->6379/tcp, :::6379->6379/tcp              magical_edison[root@zyn01 redis]# docker stop d2cc16415883
    d2cc16415883
    [root@zyn01 redis]# docker rm d2cc16415883
    d2cc16415883
    [root@zyn01 redis]# docker run  -p 6379:6379 --name myr3 --privileged=true -v /app/redis/redis.conf:/etc/redis/redis.conf -v /app/redis/data:/data -d redis:6.0.8 redis-server /etc/redis/redis.conf
    25d1f9ae4ddacea525fc00e4e8abba1e59c99557c9389b9f2b8780a51b4b1328[root@zyn01 redis]# docker exec -it myr3 /bin/bash
    root@25d1f9ae4dda:/data# redis-cli
    127.0.0.1:6379> set k1 v1
    (error) NOAUTH Authentication required.
    127.0.0.1:6379> auth 123
    OK
    127.0.0.1:6379> set k1 v1
    OK
    127.0.0.1:6379> get k1
    "v1"
    

    需要认证说明配置生效,测试成功。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/9979.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

js原生三种弹框

第一种: alert("提示内容"):提示弹框; alert("提示"); 第二种: prompt("内容","输入框默认值"):输入弹框,第一个值输入框提示内容,第二个值输入框默…

23种设计模式——责任链

责任链模式是一种行为设计模式,它允许将请求沿着处理链传递,直到有一个处理者能够处理该请求为止。责任链模式将请求的发送者和接收者解耦,使得多个对象都有机会处理请求,同时也可以动态地组织和修改处理链。 在责任链模式中&…

【SpringSecurity源码】过滤器链加载流程

theme: smartblue highlight: a11y-dark 一、前言及准备 1.1 SpringSecurity过滤器链简单介绍 在Spring Security中,过滤器链(Filter Chain)是由多个过滤器(Filter)组成的,这些过滤器按照一定的顺序对进…

AI绘画Stable Diffusion 插件篇:智能标签提示词插件sd-danbooru-tags-upsampler

大家好,我是向阳。 关于智能标签提示词插件,在很早之前就介绍过很多款了,今天再给大家介绍一款智能标签提示词插件sd-danbooru-tags-upsampler。该智能提示词插件是今年2月23号才发布的第一版V0.1.0,算是比较新的智能提示词插件。…

简化多容器应用部署:深入理解 Docker Compose

Docker Compose 已成为现代应用开发和部署的核心工具之一。它为开发者提供了一种简单且高效的方式来定义、运行和管理多容器应用程序。无论是在本地开发环境还是生产环境中,Docker Compose 都能够帮助开发团队快速搭建、部署和扩展复杂的应用系统。本文将深入探讨 D…

第100+7步 ChatGPT文献复现:ARIMA-GRNN预测出血热

基于WIN10的64位系统演示 一、写在前面 这一次,我们来解读ARIMA-GRNN组合模型文章,也是老文章了: 《PLoS One》杂志的2015年一篇题目为《Comparison of Two Hybrid Models for Forecasting the Incidence of Hemorrhagic Fever with Renal…

代码随想录 动态规划 刷题记录

动态规划 动规的五部曲: 确定dp数组(dp table)以及下标的含义确定递推公式dp数组如何初始化确定遍历顺序举例推导dp数组509.斐波那契数列 70.爬楼梯 746.使用最小花费爬楼梯 62.不同路径 63.不同路径II 343.整数拆分 96.不同的二叉搜索树 本轮树可以分为当1,2,3……

uni-app(五):原生插件打包并使用(Android)

原生插件打包并使用 解决Gradle不显示命令问题解决方法 运行打包查看打包好的包引入到uni-app项目中编写配置文件TestModuleTestComponent 制作基座并运行 解决Gradle不显示命令问题 解决方法 运行打包 查看打包好的包 引入到uni-app项目中 编写配置文件 TestModule {"n…

vue2 Avoided redundant navigation to current location

再次点击同一个链接会报错 每次使用 push 方法时带上两个回调函数 this.$router.push({name: item.name}, ()>{}, ()>{}) //第二、第三个参数分别为成功和失败的回调函数重写 Vue-router 原型对象上的 push 函数不行 https://blog.csdn.net/weixin_43615570/article/d…

Linux -- Git

Git Git 是一个开源的分布式版本控制系统,主要用于软件开发中的源代码管理。它由 Linus Torvalds 创建,也是 Linux 内核的开发者。Git 使得多个开发者可以在同一个项目上协作,而不会相互干扰。它允许开发者在本地计算机上创建多个分支&#…

番外篇 | YOLOv8改进之利用SCINet解决黑夜目标检测问题 | 低照度图像增强网络

前言:Hello大家好,我是小哥谈。自校正照明网络(Self-Calibrating Illumination Network, SCINet)是一种基于深度学习的图像照明算法,可以自动分析图像的内容并根据图像内容自动优化照明。SCINet是一种专为低光照图像增强设计的框架。它通过级联照明学习过程和权重共享机制…

Php php7的特性

1. 性能优化 PHP7引入了Zend Engine 3.0,显著提高了执行效率,相比PHP 5.x,性能提升了2-3倍。这个特性无法直接通过代码示例展示,但你可以感受到在升级到PHP7后,相同代码的执行速度更快。 2. 函数返回类型声明 允许在…

【系统分析师】软件架构设计

文章目录 1、构件与软件复用1.1 主流构件标准1.2 构件获取与管理1.3 构件复用的方法 2、软件架构概述3、软件架构建模4、软件架构风格4.1 经典架构风格4.2 层次架构风格4.3 富互联网应用-RIA 5、面向服务的架构5.1 SOA概述5.2 SOA的关键技术5.3 SOA的实现方法 6、软件架构评估6…

Nginx - server、listen、server_name和多服务请求处理(三)

server 上下文 server { }server指令用于配置一个虚拟服务。listen指令描述了本服务可接受链接的所有地址和端口,server_name指令列举了所有服务的名字,例如 server {listen 80;server_name example.org www.example.org; }listen 指令 Syntax: …

Rust - 基础语法

文章目录 注释基本输出输出 {} 变量重影(Shadowing) 数据类型整数型(Integer)浮点数型(Floating-Point) f32、f64数学计算布尔型 bool字符型 char元组 ()数组 [].. 表示范围切片 slice结构体枚举match 处理…

AI大模型探索之路-训练篇20:大语言模型预训练-常见微调技术对比

系列篇章💥 AI大模型探索之路-训练篇1:大语言模型微调基础认知 AI大模型探索之路-训练篇2:大语言模型预训练基础认知 AI大模型探索之路-训练篇3:大语言模型全景解读 AI大模型探索之路-训练篇4:大语言模型训练数据集概…

nginx 详解

Nginx(发音为“Engine-X”)是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3代理服务器。Nginx以其高稳定性、丰富的功能集、简单的配置和低资源消耗而闻名。它特别适用于处理高并发请求,这部分归功于其事件驱动和异步架构。…

RF Plasma gernerator-系列(RF-5KW Adtec)说明书TX06-9001-00

RF Plasma gernerator-系列(RF-5KW Adtec)说明书TX06-9001-00

深度学习课程论文精读——ESRGAN

目录 1.研究概述 2.论文创新 2.1 改进生成器的网络框架 2.2 改进判别器 2.3 改进感知损失 2.4 网络插值 3.实验 3.1 评价指标 3.2 训练细节 3.3 对比实验 3.4 消融实验 3.5 网络插值 4.总结 5.阅读参考 文章标题:《ESRGAN: Enhanced Super-Resolution…

Hive优化(1)——分桶采样

分桶(Bucketing) 分桶是将数据按照某个字段的哈希值进行分组存储的一种技术。它的原理是将数据按照指定字段的哈希值分成固定数量的桶,将每条记录分配到对应的桶中。分桶可以帮助优化特定类型的查询,例如连接查询和聚合操作&…