看完此文,妈妈还会担心你Docker入不了门?
编程并不是一个机械性的工作,而是需要有思考,有创新的工作,语法是固定的,但解决问题的思路则是依靠人的思维,这就需要我们坚持学习和更新自己的知识。今天golang学习网就整理分享《看完此文,妈妈还会担心你Docker入不了门?》,文章讲解的知识点主要包括MySQL、docker、Redis、Java,如果你对数据库方面的知识点感兴趣,就不要错过golang学习网,在这可以对大家的知识积累有所帮助,助力开发能力的提升。
大家好,我是阿壮,一个有代码洁癖的程序员,个人网站:jonssonyan.com
现在很多企业都在上云,Docker 无疑是云时代的宠儿,像 MySQL,Redis 都可以部署在 Docker 中,从而方便我们去管理,而且移植性强,打包成镜像,在任何一个安装了 Docker 的服务器上都可以运行。下面介绍 Docker 的安装,基础概念,常用命令,在 Docker 上部署 MySQL Redis,以及打包 jar 包并运行。
什么是 Docker?
Docker 翻译过来就是码头工人,是一个开源的应用容器引擎,基于 Go 语言。Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低。
Linux 下安装 Docker
卸载旧版本
yum remove docker \ docker-client \ docker-client-latest \ docker-common \ docker-latest \ docker-latest-logrotate \ docker-logrotate \ docker-engine
安装 yum-utils 软件包(提供 yum-config-manager 实用程序)
yum install -y yum-utils
设置稳定的存储库(使用阿里云镜像)
yum-config-manager \ --add-repo \ http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
更新缓存
yum makecache fast
安装最新版本的 Docker Engine 和容器,或转到下一步以安装特定版本
yum install docker-ce docker-ce-cli containerd.io
启动 Docker
systemctl start docker
配置 Docker
Docker 默认的镜像源于国内而言是有些慢,所以可以配置一下国内的镜像源,提高一下 pull 速度
阿里云镜像服务参考:https://cr.console.aliyun.com...
创建目录
mkdir -p /etc/docker
创建一个镜像配置文件
vi /etc/docker/daemon.json
配置文件中添加镜像
{ "registry-mirrors":["http://hub-mirror.c.163.com"] }
重新加载文件并重启 docker
systemctl daemon-reload // 重新加载文件 systemctl restart docker // 重启docker systemctl enable docker // 开机自启
一些其他的加速站点
https://registry.docker-cn.com http://hub-mirror.c.163.com https://mirror.ccs.tencentyun.com
卸载 Docker
卸载 Docker Engine,CLI 和 Containerd 软件包
yum remove docker-ce docker-ce-cli containerd.io
主机上的映像,容器,卷或自定义配置文件不会自动删除。要删除所有图像,容器和卷
rm -rf /var/lib/docker
常用命令
镜像指令
docker images // 查看 Docker 中当前拥有哪些镜像 docker image MySQL // 查询指定镜像名 docker pull MySQL:5.7 // 下载镜像 docker search MySQL // 搜索一下镜像有哪些版本 docker image rm MySQL:5.5 // 删除镜像 docker image rm bf756fb1ae65 // 通过指定镜像 id 进行删除 docker image rm -f bf756fb1ae65 // 如果删除的镜像正在运行中,此时需要强制执行删除 docker rmi -f $(docker images MySQL -q) // 借助rmi和-p进行一些联合操作,比如现在想删除所有的 MySQL 镜像
容器指令
docker run tomcat:8.0-jre8 // 通过镜像运行一个容器 docker ps // 查看当前运行的容器 docker run -p 8080:8080 tomcat:8.0-jre8 // 对宿主机端口与容器内的端口进行映射 docker run -d -p 8080:8080 --name tomcat01 tomcat:8.0-jre8 // 后台的方式运行,并设置容器名称 docker ps -a // 列举运行和非运行的容器 docker start c2f5d78c5d1a // 启动容器 docker restart c2f5d78c5d1a // 重启容器 docker stop c2f5d78c5d1a // 停止容器 docker kill c2f5d78c5d1a // 直接杀死指定的容器 docker rm d5b6c177c151 // 删除容器 docker rm -f d5b6c177c151 // 强制删除容器 docker rm -f $(docker ps -qa) // 强制删除所有容器 docker logs 289cc00dc5ed // 查看容器的运行日志 使用-f参数显示实时日志 -t参数还能够显示日志的时间戳 docker top 289cc00dc5ed // 查看容器内运行了哪些进程 docker exec -it 289cc00dc5ed bash // 与容器进行交互 使用exit 从容器内退出到宿主机 docker cp ./test.html 289cc00dc5ed:/usr/local/tomcat/webapps // 将文件从宿主机复制到容器中 docker inspect 923c969b0d91 // 查看容器内部具体的细节
数据卷指令
能够实现宿主机与容器之间的文件共享,它的好处在于我们对宿主机的文件进行修改将直接影响容器,而无需再将宿主机的文件再复制到容器中。
若是想将宿主机中/opt/apps 目录与容器中 webapps 目录做一个数据卷,则应该这样编写指令
docker run -d -p 8080:8080 --name tomcat01 -v /opt/apps:/usr/local/tomcat/webapps tomcat:8.0-jre8
这就说明我们的数据卷设置成功了,Docker 会将容器内的 webapps 目录与/opt/apps 目录进行同步,而此时/opt/apps 目录是空的,导致 webapps 目录也会变成空目录,所以就访问不到了。
此时我们只需向/opt/apps 目录下添加文件,就会使得 webapps 目录也会拥有相同的文件,达到文件共享
docker run -d -p 8080:8080 --name tomcat01 -v aa:/usr/local/tomcat/webapps tomcat:8.0-jre8
此时的 aa 并不是数据卷的目录,而是数据卷的别名,Docker 会为我们自动创建一个名为 aa 的数据卷,并且会将容器内 webapps 目录下的所有内容复制到数据卷中,该数据卷的位置在/var/lib/docker/volumes 目录下
此时我们只需修改该目录的内容就能能够影响到容器。
docker commit -m "描述信息" -a "镜像作者" tomcat01 my_tomcat:1.0 // 将容器打包成一个镜像 docker save my_tomcat:1.0 -o my-tomcat-1.0.tar // 将镜像备份出来 docker load -i my-tomcat-1.0.tar // 将.tar格式的镜像,加载到Docker中
Docker 下安装 MySQL5.7.31
拉取 Mysql 5.7.31 镜像
docker pull mysql:5.7.31
运行 Mysql 5.7.31
docker run -d --name myMysql -p 9506:3306 -v /data/mysql:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7.31
参数解析:
docker exec -it [容器ID] /bin/bash
- 输入数据库账号密码命令
mysql -uroot -p
- 进入界面后更改 root 密码(123456 为我的新密码 ,此处密码由您决定)
update mysql.user set authentication_string=password('123456') where user='root' and Host = 'localhost';
- 刷新缓存
flush privileges;
- 退出 mysql
exit
- 然后重进 mysql,用修改后的密码登录
Dcoker 下安装 Redis
Redis Windows 版本:https://github.com/tporadowsk...
Redis 官网:https://redis.io/
AnotherRedisDesktopManager:https://github.com/qishibo/An...
安装命令
docker pull redis:latest docker run -itd --name myRedis -p 6379:6379 redis --requirepass "123456"
如果在启动时忘记设置密码
docker exec -it myRedis redis-cli // 进入容器 config set requirepass 123456
将 jar 包做成 Docker 镜像,并运行
上传 jar 包文件和 Dockerfile 文件至服务器
Dockerfile 文件如下
FROM java:8 VOLUME /tmp ADD jonsson-0.0.1-SNAPSHOT.jar jonsson.jar EXPOSE 8888 ENTRYPOINT ["java","-jar","/jonsson.jar"]
解释:
- from java:8 拉取一个 jdk 为 1.8 的 docker image
- jonsson-0.0.1-SNAPSHOT.jar 就是你上传的 jar 包,替换为 jar 包的名称
- jonsson.jar 是你将该 jar 包重新命名为什么名称,在容器中运行
- expose 该容器暴露的端口是多少,就是 jar 在容器中以多少端口运行
- entrypoint 容器启动之后执行的命令,java -jar /jonsson.jar 即启动 jar
打包镜像
docker build -t jonsson .
运行容器
docker run -d -p 8888:8888 --name jonsson-8888 jonsson
查看启动日志
docker logs -n 300 -f jonsson-8888
Reference
我是阿壮,微信搜一搜:科技猫,关注这个有代码洁癖的程序员,我们下期间
文中关于mysql的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《看完此文,妈妈还会担心你Docker入不了门?》文章吧,也可关注golang学习网公众号了解相关技术文章。

- 上一篇
- CloudQuery 的数据安全技术运用

- 下一篇
- 用 CloudQuery 管理和操作数据,更高效更安全
-
- 数据库 · MySQL | 1小时前 | 索引 数据类型 约束 命名规范 CREATETABLE
- MySQL建表语句规范与示例详解
- 100浏览 收藏
-
- 数据库 · MySQL | 1小时前 | 唯一性 主键 CREATETABLE AUTO_INCREMENT 聚集索引
- MySQL主键能否重复?深度解析唯一性约束
- 428浏览 收藏
-
- 数据库 · MySQL | 3小时前 |
- mysql新手必学基础命令操作合集
- 137浏览 收藏
-
- 数据库 · MySQL | 13小时前 | 外键 主键 ForeignKey CREATETABLE PRIMARYKEY
- mysql主外键创建语法详解与示例
- 397浏览 收藏
-
- 数据库 · MySQL | 18小时前 |
- mysql增删改查命令一览速查手册
- 182浏览 收藏
-
- 数据库 · MySQL | 21小时前 | Python 自动化 环境变量 mysql--version sudosystemctlstatusmysql
- 验证MySQL安装的三种快速方法
- 403浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL必备20个基础操作指令大全
- 166浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL基础教程:案例解析掌握基本操作
- 143浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- PPTFake答辩PPT生成器
- PPTFake答辩PPT生成器,专为答辩准备设计,极致高效生成PPT与自述稿。智能解析内容,提供多样模板,数据可视化,贴心配套服务,灵活自主编辑,降低制作门槛,适用于各类答辩场景。
- 16次使用
-
- Lovart
- SEO摘要探索Lovart AI,这款专注于设计领域的AI智能体,通过多模态模型集成和智能任务拆解,实现全链路设计自动化。无论是品牌全案设计、广告与视频制作,还是文创内容创作,Lovart AI都能满足您的需求,提升设计效率,降低成本。
- 15次使用
-
- 美图AI抠图
- 美图AI抠图,依托CVPR 2024竞赛亚军技术,提供顶尖的图像处理解决方案。适用于证件照、商品、毛发等多场景,支持批量处理,3秒出图,零PS基础也能轻松操作,满足个人与商业需求。
- 28次使用
-
- PetGPT
- SEO摘要PetGPT 是一款基于 Python 和 PyQt 开发的智能桌面宠物程序,集成了 OpenAI 的 GPT 模型,提供上下文感知对话和主动聊天功能。用户可高度自定义宠物的外观和行为,支持插件热更新和二次开发。适用于需要陪伴和效率辅助的办公族、学生及 AI 技术爱好者。
- 29次使用
-
- 可图AI图片生成
- 探索快手旗下可灵AI2.0发布的可图AI2.0图像生成大模型,体验从文本生成图像、图像编辑到风格转绘的全链路创作。了解其技术突破、功能创新及在广告、影视、非遗等领域的应用,领先于Midjourney、DALL-E等竞品。
- 53次使用
-
- golang MySQL实现对数据库表存储获取操作示例
- 2022-12-22 499浏览
-
- golang进程内存控制避免docker内oom
- 2022-12-22 160浏览
-
- golang进程在docker中OOM后hang住问题解析
- 2022-12-22 105浏览
-
- 分享Redis高可用架构设计实践
- 2023-01-24 286浏览
-
- 搞一个自娱自乐的博客(二) 架构搭建
- 2023-02-16 244浏览