一文快速学会Docker软件部署

这篇具有很好参考价值的文章主要介绍了一文快速学会Docker软件部署。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

👨‍🎓作者简介:一位大四、研0学生,正在努力准备大四暑假的实习
🌌上期文章:首期文章
📚订阅专栏:Docker
希望文章对你们有所帮助

做项目的时候,感觉很多地方的配置都特别麻烦,特别是搞微服务的时候,环境配置更是恶心了,Docker可以解决这些问题,所以我速成了一波。Docker的学习不需要什么知识储备,拿来做工具使用就行了。
在这边讲解一下Docker的基本机理,然后使用Docker进行配置实例的应用:MySQL、Tomcat、nginx、Redis。

初识Docker

Docker概述

我们写代码会接触到很多环境:开发环境、测试环境、生产环境。
当代码在开发环境中进行开发的时候,因为版本问题,经常会在测试环境中报错,处理起来较为复杂,Docker就是来解决这种问题的。

Docker:Docker是一个开源的应用容器引擎,基于Go语言实现,可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,并发布到任何流行的Linux机器上

总结:docker是一种容器技术,解决软件跨环境迁移的问题。

安装Docker(基于CentOs7)

docker官网:Docker官网
打开Linux命令行自行安装docker:

# 1、yum 包更新到最新 
yum update
# 2、安装需要的软件包, yum-util 提供yum-config-manager功能,另外两个是devicemapper驱动依赖的 
yum install -y yum-utils device-mapper-persistent-data lvm2
# 3、 设置yum源
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
# 4、 安装docker,出现输入的界面都按y,可能会安装失败,因为是从GitHub上面获取的,可以多安装几次
yum install -y docker-ce
# 5、 查看docker版本,验证是否验证成功
docker -v

Docker架构

一文快速学会Docker软件部署,Docker,docker,容器,redis,mysql,nginx,tomcat

Image(镜像):相当于root文件系统,由仓库提供
container(容器):一个镜像对应多个容器(相当于面向对象程序语言中类与对象的关系),镜像是静态的定义,容器是镜像运行时的实体。容器可以被创建、启动、停止、暂停等
repository(仓库):一个代码控制中心,用来保存镜像

配置Docker镜像加速器

国外速度比较慢,我们选择国内的阿里云的镜像加速器,打开阿里云官网:
阿里云
搜索容器镜像服务,将下列命令行复制到Linux中(每个人的网址都是不一样的):
一文快速学会Docker软件部署,Docker,docker,容器,redis,mysql,nginx,tomcat
用cat命令可以查看:
一文快速学会Docker软件部署,Docker,docker,容器,redis,mysql,nginx,tomcat
如果要换源,就把这里的网址换一下就好了。

Docker命令

服务相关命令

启动docker:systemctl start docker
关闭docker:systemctl stop docker
重启docker:systemctl restart docker
开机自启docker:systemctl enable docker
查看docker状态:systemctl status docker

镜像相关命令

1、查看镜像:查看本地所有的镜像

docker images
docker images -q # 查看所有镜像id

2、搜索镜像:从网络中查找需要的镜像

docker search 镜像名称

3、拉取镜像:从Docker仓库下载镜像到本地,镜像名称格式为 名称:版本号,如果版本号不指定则是最新的版本。如果不知道镜像版本,可以去docker hub搜索对应镜像查看。

docker pull 镜像名称

4、删除镜像

docker rmi 镜像id

容器相关命令(最重要)

1、查看容器

docker ps # 查看正在运行容器
docker ps -a # 查看所有容器

2、创建及进入容器:docker run 参数

参数说明:
-i:保持容器运行,通常与-t同时使用,加入it以后,容器创建后自动进入容器中,退出容器后,容器自动关闭
-t:为容器重新分配一个伪输入终端,通常与-i同时使用
-d:以守护模式运行容器。创建一个容器在后台运行,要用docker exec进入容器。退出后,容器不会关闭
-it创建的容器为交互式容器,-id创建的为守护式容器
–name:为创建的容器命名

3、启动容器

docker start 容器名

4、停止容器

docker stop 容器名

5、删除容器

docker rm 容器名

6、查看容器信息

docker inspect 容器名

Docker容器数据卷

数据卷概念与应用

Docker的问题:

Docker容器删除后,在容器中产生的数据也会随之销毁 Docker容器和外部机器不能直接交换文件(只能与宿主机进行)
容器之间不能进行数据交互

而数据卷可以解决这些问题

数据卷:
1、是宿主机中的一个目录或文件
2、当容器目录与数据卷目录绑定后,对方的数据会立即同步
3、一个数据卷可以被多个容器同时挂载
4、一个容器也可以被挂载多个数据卷

数据卷的作用:
1、容器数据持久化
2、外部机器与容器间接通信
3、容器之间数据交换

配置数据卷

创建启动容器时,使用-v参数设置数据卷

docker run … –v 宿主机目录(文件):容器内目录(文件) ...

注意:
1、目录必须是绝对路径
2、若目录不存在,会自动创建
3、可挂载多个数据卷

Docker应用部署

部署应用的步骤:
1、搜索镜像
2、拉取镜像
3、创建容器
4、操作容器中的应用

部署MySQL

我们知道,外部机器是无法直接与宿主机内的容器交互的,但是外部机器可以与宿主机交互,宿主机可以与其内部的容器交互。
举例一个解决方案:对于端口为3306的MySQL,我们可以将其与宿主机的3307端口交互,外部机器只需要与3307交互,这样外部机器即可间接访问容器的服务。
这种操作成为:端口映射
1、搜索mysql镜像

docker search mysql

2、拉取mysql镜像

docker pull mysql:5.6

3、创建容器,设置端口映射、目录映射

# 在/root目录下创建mysql目录用于存储mysql数据信息
mkdir ~/mysql
cd ~/mysql

docker run -id \
-p 3307:3306 \
--name=c_mysql \
-v $PWD/conf:/etc/mysql/conf.d \
-v $PWD/logs:/logs \
-v $PWD/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
mysql:5.6

-p 3307:3306:将容器的 3306 端口映射到宿主机的 3307 端口。
-v $PWD/conf:/etc/mysql/conf.d:将主机当前目录下的 conf/my.cnf 挂载到容器的 /etc/mysql/my.cnf。配置目录
-v $PWD/logs:/logs:将主机当前目录下的 logs 目录挂载到容器的 /logs。日志目录
-v $PWD/data:/var/lib/mysql :将主机当前目录下的data目录挂载到容器的 /var/lib/mysql 。数据目录
-e MYSQL_ROOT_PASSWORD=123456:初始化 root 用户的密码。

4、守护者模式进入容器,操作MySQL

docker exec –it c_mysql /bin/bash

上述4步执行完毕:
一文快速学会Docker软件部署,Docker,docker,容器,redis,mysql,nginx,tomcat

5、使用外部机器连接容器中的MySQL:
一文快速学会Docker软件部署,Docker,docker,容器,redis,mysql,nginx,tomcat
剩下的自行去验证就行。

部署Tomcat

1、搜索tomcat镜像

docker search tomcat

2、拉取tomcat镜像

docker pull tomcat

3、创建容器,设置端口映射、目录映射

# 在/root目录下创建tomcat目录用于存储tomcat数据信息
mkdir ~/tomcat
cd ~/tomcat

docker run -id --name=c_tomcat \
-p 8080:8080 \
-v $PWD:/usr/local/tomcat/webapps \
tomcat 

**-p 8080:8080:**将容器的8080端口映射到主机的8080端口
**-v $PWD:/usr/local/tomcat/webapps:**将主机中当前目录挂载到容器的webapps

4、使用外部机器访问tomcat
先使用vim编辑一点信息:

mkdir test
cd test
vim index.html

接着本地访问网址:192.168.177.130:8080/test/index.html

部署Nginx

1、搜索nginx镜像

docker search nginx

2、拉取nginx镜像

docker pull nginx

3、创建容器,设置端口映射、目录映射

# 在/root目录下创建nginx目录用于存储nginx数据信息
mkdir ~/nginx
cd ~/nginx
mkdir conf
cd conf
# 在~/nginx/conf/下创建nginx.conf文件,粘贴下面内容
vim nginx.conf
user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;

    include /etc/nginx/conf.d/*.conf;
}
docker run -id --name=c_nginx \
-p 80:80 \
-v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf \
-v $PWD/logs:/var/log/nginx \
-v $PWD/html:/usr/share/nginx/html \
nginx

-p 80:80:将容器的 80端口映射到宿主机的 80 端口。
-v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf:将主机当前目录下的 /conf/nginx.conf 挂载到容器的 :/etc/nginx/nginx.conf。配置目录
-v $PWD/logs:/var/log/nginx:将主机当前目录下的 logs 目录挂载到容器的/var/log/nginx。日志目录

4、外部机器访问nginx

部署Redis

1、搜索Redis镜像

docker search redis

2、拉取Redis镜像

docker pull redis:5.0

3、创建容器,设置端口映射

docker run -id --name=c_redis -p 6379:6379 redis:5.0

4、使用外部机器连接redis文章来源地址https://www.toymoban.com/news/detail-799880.html

./redis-cli.exe -h 192.168.177.130 -p 6379

到了这里,关于一文快速学会Docker软件部署的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • docker 容器操作、应用部署、mysql,redis,nginx、迁移与备份、Dockerfile

    mysql部署 redis nginx 常用和不常用的命令 dockerfile构建一个django项目 docker私有仓库 镜像传到官方仓库 镜像分层 私有仓库搭建 新建flask项目app.py 编写Dockerfile 用于构建flask项目的镜像 编写dockercompose的yml文件dockercompose.yml dockercompose启动 项目目录结构 luffy_api/Dockerfile 构建uwsgi+dj

    2023年04月13日
    浏览(44)
  • docker容器中快速部署ES集群的详细操作步骤(6个节点)

    ElasticSearch集群 1.集群原理 ElasticSearch是天生支持集群的,他不需要依赖其他的服务发现和注册的组件,如zookeeper这些,因为他内置了一个名字叫ZenDiscovery的模块,是ElasticSearch自己实现的一套用于节点发现和选主等功能的组件,所以ElasticSearch做起集群来非常简单,不需要太多

    2024年02月09日
    浏览(36)
  • Docker本地部署Redis容器结合内网穿透实现无公网ip远程连接

    本文主要介绍如何在Ubuntu使用Docker部署Redis容器并结合cpolar内网穿透工具实现无公网ip环境远程访问本地数据库。 Redis作为一款高速缓存的key value键值对的数据库,在许许多多的场景中广泛使用,由于是把数据存储在内存中,所以读写效率极高。而在docker中部署Redis也非常简单

    2024年03月09日
    浏览(35)
  • docker - 常用容器部署命令大全(MySQL、MongoDB、Redis、RabbitMQ、ES、Kibana、Nacos、Sentine)

    目录 一、常用容器运行指令 MySQL Redis RabbitMQ ElasticSearch  kibana  Nacos Sentinel a)未持久化部署 b)持久化部署 a)未持久化部署: b)持久化部署:   a)为了 es 和 将来要下载的 kibana 进行互联,因此需要我们去创建一个网络. b) ES 部署 Ps:如果报错 \\\"Caused by: java.nio.file.Access

    2024年01月20日
    浏览(67)
  • 【云原生】一文学会Docker存储所有特性

      目录 1.Volumes         1.Volumes使用场景         2.持久将资源存放         3. 只读挂载 2.Bind mount Bind mounts使用场景 3.tmpfs mounts使用场景 4.Bind mounts和Volumes行为上的差异 5.docker file将存储内置到镜像中 6.volumes管理 1.查看存储卷 2.删除存储卷 3.查看存储卷的详细信息 7.Volumes操

    2024年02月14日
    浏览(24)
  • 使用Docker容器部署java运行环境(java8 + mysql5.7 + redis5.0 + nginx1.14.1

    环境:阿里云ECS服务器 1.1 安装工具 1.2 为yum源添加docker仓库位置 1.3 将软件包信息提前在本地索引缓存 (非必要,建议执行,可以提升yum安装的速度,报错去掉fast试试) 1.4 安装Docker 傻瓜式安装 点击y 1.5 启动Docker 1.6 设置开机自启动 1.7 安装完成后可以测试一下,是否安装成功

    2024年02月02日
    浏览(65)
  • 使用docker-compose.yml快速搭建开发、部署环境(nginx、tomcat、mysql、jar包、各种程序)以及多容器通信和统一配置

    image 镜像名称,可去镜像市场查找自己需要的 hostname 容器内服务名 container_name 容器名 volumes 可以把自己电脑的路径映射到容器中的文件夹中 networks 写同一个网络可以让容器之间进行通信 启动 在项目根目录的命令行中输入 docker-compose up 停止 在项目根目录的命令行中输入 d

    2024年02月12日
    浏览(38)
  • 一文搞清楚 Docker 镜像、容器、仓库

    博主介绍 : ✌博主从事应用安全和大数据领域,有8年研发经验,5年面试官经验,Java技术专家✌ Java知识图谱点击链接: 体系化学习Java(Java面试专题) 💕💕 感兴趣的同学可以收藏关注下 , 不然下次找不到哟 💕💕 Docker 镜像、容器、仓库是 Docker 技术中的三个重要概念

    2024年02月03日
    浏览(40)
  • 三分钟学会使用 Docker 部署前端项目

    本篇文章带领读者利用Docker+XShell+阿里云服务器进行简单的前端网页部署。笔者用到的环境如下: 本机操作系统:Windows 10(因此直接安装 Docker Desktop,图形化操作,较为方便) 云服务器:阿里云 2核 2G(Ubantu) 一些本人参考的资料整理: Docker中文文档:Docker — 从入门到实

    2024年02月22日
    浏览(40)
  • Docker基本操作【一篇学会项目部署】

    本文均学于“黑马程序员” 本文所用环境:CentOS7 、HeidiSQL 、MobaXterm、MySQL Docker 是一个虚拟环境容器,可以将你的开发环境、代码、配置文件等一并打包到这个容器中,并发布和应用到任意平台中。比如,你在本地用Python开发网站后台,开发测试完成后,就可以将Python3及其

    2024年02月06日
    浏览(30)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包