Linux CentOS7 安装Docker

CentOS7安装Docker:

Docker简介

Docker是一个开源的容器化平台,可帮助开发者轻松地创建、部署和运行应用程序。Docker使开发人员能够在一个独立的容器中打包应用程序及其依赖项,这样他们就可以轻松地将应用程序移植到任何其他环境中。Docker中每个容器都可以看成是一个独立的Linux极简操作系统,容器之间相互独立,互不干扰。

使用Docker的主要优势

1、便于部署:由于Docker容器可以在任何支持Docker的平台上运行,因此应用程序可以轻松地在不同的环境中部署和运行。

2、隔离性:Docker容器提供了隔离的运行环境,使得应用程序可以在独立的环境中运行,从而避免了依赖冲突和其他问题。

3、可移植性:Docker容器可以轻松地从一个平台移植到另一个平台,从而使应用程序在不同的平台上运行变得更加容易。

4、安全性:Docker容器提供了安全性隔离,使得应用程序和它的依赖项可以在受保护的环境中运行,从而减少了潜在的安全风险。
 

一、安装前必读

在安装 Docker 之前,先说一下配置,我这里是Centos7 Linux 内核:官方建议 3.10 以上,3.8以上貌似也可。

注意:本文的命令使用的是 root 用户登录执行,不是 root 的话所有命令前面要加 sudo

例如:sudo yum -y update

1.查看当前的内核版本

命令:uname -r

2.使用 root 权限更新 yum 包(生产环境中此步操作需慎重,看自己情况,学习的话随便搞)

执行:yum -y update 命令后 得重启下云服务器,很有可能启动不起来。

报错iptables提示unable to initialize table ‘filter’    解决办法:可以尝试重启服务器,正常启动了

这两个命令可以根据自己的情况来执行(不是必须执行的,如果出现不兼容的情况就必须update)

命令:yum -y update            #升级所有包同时也升级软件和系统内核

命令:yum -y upgrade          #只升级所有包,不升级软件和系统内核

3.卸载旧版本(如果之前安装过的话)

命令:yum remove docker docker-common docker-selinux docker-engine

二、安装Docker的详细步骤

1.安装需要的软件包, yum-util 提供yum-config-manager功能,另两个是devicemapper驱动依赖

命令:yum install -y yum-utils device-mapper-persistent-data lvm2

 2.设置 yum 源

设置一个yum源,下面两个都可用,自己选择一个即可

#中央仓库

yum-config-manager --add-repo http://download.docker.com/linux/centos/docker-ce.repo

#阿里仓库

yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

3.查看docker版本 

命令:yum list docker-ce --showduplicates | sort -r

 因为我是CentOS系统,所以选择了后面带centos的版本

4、选择一个Docker版本安装yum install docker-ce-版本号

命令:yum -y install docker-ce-18.03.1.ce

安装成功后启动Docker并设置开机自动启动

命令:systemctl start docker

命令:systemctl enable docker

Docker容器与容器之间互联

默认情况下容器与容器之间不能之间访问,需要通过–link进行设置连接。这样的操作比较麻烦,更推荐的方式是自定义网络,容器都使用该自定义网络,就可以实现通过容器名来互相访问了。

容器网络设置请参考:Docker 网络_hyper-v docker 桥接-CSDN博客

1、先创建两个容器

# mysql容器
sudo docker run --name test_mysql -itd -e MYSQL_ROOT_PASSWORD=123456 mysql:5.6.48 /bin/bash

# python容器
sudo docker run --name test_python -itd -p 5000:5000 python:3.6.5 /bin/bash

2、创建web服务器,通过docker link命令链接两个容器

# --link表示连接容器
# name:alias(链接的容器名:别名,name和alias可以相同),也可仅仅跟要链接的容器名

# 简单创建链接
sudo docker run -it --link test_mysql:mysql python:3.6.5 /bin/bash

# 完整创建链接
sudo docker run --name test_python -itd -p 5000:5000 --link test_mysql python:3.6.5

 3、通过docker exec -it命令查看容器是否连通。命令形式:docker exec -it 容器名 ping 容器名
示例如下:

sudo docker exec -it test_python ping test_mysql

安装Docker Compose

什么是Docker Compose

Compose是Docker官方推出 的一个工具软件,可以管理多个Docker容器组成的一个应用

Compose是用来定义和运行一个或多个容器应用的工具。使用compaose可以简化容器镜像的建立及容器的运行。
Compose使用python语言开发,非常适合在单机环境里部署一个或多个容器,并自动把多个容器互相关联起来。

在实际生产环境中,一个应用往往由许多服务构成,而 docker 的最佳实践是一个容器只运行一个进程,因此运行多个微服务就要运行多个容器。多个容器协同工作需要一个有效的工具来管理他们,定义这些容器如何相互关联。compose 应运而生。

能干嘛:

docker建议我们每一个容器只运行一个服务,因为docker容器本身占用资源极少,所以最好是将每一个服务单独地分割,但是这样,我们面临了一个问题

如果我们需要同事部署好多个服务,难道每个服务单独写Docckerfile,然后再构建镜像,构建容器,这样累死了,所以docker官方给我们提供了docker-compose多服务部署工具

例如:要实现一个Web微服务项目,除了Web服务容器本身,往往还需要加上后端的数据库mysql服务器,redis服务器,注册中心eureka,甚至还包括负载均衡Nginx容器等。。。

Compose允许用户通过一个单独的docker-compose.yml模板文件(YAML格式)来定义一组相关联的音容容器为一个项目(project)

可以很容易的用一个配置文件定义一个多容器的应用,然后使用一条指令安装这个应用需要的所有依赖,完成构建。docker-compose解决了容器与容器之间如何挂你编排的问题。

Docker Compose的核心概念

1、服务 (service):一个应用的容器,实际上可以包括若干运行相同镜像的容器实例。

2、项目 (project):由一组关联的应用容器组成的一个完整业务单元,在 docker-                 compose.yml 文件中定义。

Docker与Docker-Compose对比

DockerDocker-Compose
概念是一个供开发和运维人员开发、测试、部署和运行应用程序的容器平台(docker是一个容器平台)是一个用于创建和管理多容器应用程序的工具
创建容器数量每次1个多个
是否容易编辑每个容器需要单独去修改直接修改一个yaml文件即可
是否是服务一个由多个容器组成的服务,依赖于docker之上

下载并安装 Compose 独立版

这个命令地址是Docker官方文档:安装 Compose 独立版 |Docker 文档 中拿到的安装 Compose 独立版 |Docker 文档

命令:curl -SL https://github.com/docker/compose/releases/download/v2.23.3/docker-compose-linux-x86_64 -o /usr/local/bin/docker-compose

给目录赋权限

chmod +x /usr/local/bin/docker-compose

查看compose的版本号

docker-compose --version

卸载compose

rm /usr/local/bin/docker-compose

用法例子 :参考文档 

创建yaml文件

#用vim命令创建一个yaml文件

vim test_system.yaml

编写yaml文件内容
# 搭建测试系统环境# yaml文件版本号
version: '3.7'# yaml文件包含的容器
services:# python容器test-python:tty: trueimage: new-python:3.6.5container_name: test-python# 设置端口ports:- 5000:5000# 设置开机启动restart: alwaysvolumes:- /home/nikolas/webapp/my_python:/home/my_pythonlogging:driver: "json-file"options:max-size: "5g"# java容器test-java:tty: trueimage: new-jdk:1.0.0container_name: test-java# 设置端口ports:- 8088:8088# 设置开机启动restart: alwaysvolumes:- /home/nikolas/webapp/my_java:/home/my_javalogging:driver: "json-file"options:max-size: "5g"# mysql容器test-mysql:tty: trueimage: mysql:5.7.34container_name: test-mysql# 设置端口ports:- 3306:3306# 设置开机启动restart: alwaysvolumes:- /home/nikolas/db_data/mysql/data:/var/lib/mysqlenvironment:MYSQL_ROOT_PASSWORD: 123456# redis容器test-redis:tty: trueimage: redis:6.2container_name: test-redis# 设置端口ports:- 6379:6379# 设置开机启动restart: alwayscommand: --requirepass 123456# nginx容器test-nginx:tty: trueimage: nginx:1.20.0container_name: test-nginx# 设置端口ports:- 81:81- 446:446# 设置开机启动restart: alwaysvolumes:- /var/log/nginx:/var/log/nginx# yaml文件所用的网络
networks:default:external:name: my_net
使用docker-compose命令部署测试系统

一键创建yaml文件包含的所有容器

# docker-compose -f yaml文件所在路径
sudo docker-compose -f /home/nikolas/yaml/test_system.yaml up -d

一键删除yaml文件包含的所有容器

 # docker-compose -f yaml文件所在路径
sudo docker-compose -f /home/nikolas/yaml/test_system.yaml down

Docker可视化管理工具——Docker UI

简介

Docker UI 是一款最简单的,单机环境中的管理 Docker 的图形工具,适合初学者和小型 Docker 管理。

优点:
1、支持容器管理
2、稳定性高
3、可动态显示容器间的关系图

缺点:
1、管理页面无账户体系,缺乏安全性
2、对于容器的管理缺乏权限控制,任何人都可以对容器进行一些敏感操作
3、不支持多主机和 Swarm 集群

下载原生Docker UI镜像     

命令:docker pull uifd/ui-for-docker

启动Docker UI 容器   

docker ui端口地址默认是:9000

name后面的docker-web是容器的名称,我们可以随便改查自己喜欢的名称

命令:docker run -it -d --name docker-web -p 9000:9000 -v /var/run/docker.sock:/var/run/docker.sock docker.io/uifd/ui-for-docker

#如果其他容器已经占用了9000端口,就改成 8089:9000试试   如下:

命令:docker run -it -d --name docker-web -p 8089:9000 -v /var/run/docker.sock:/var/run/docker.sock docker.io/uifd/ui-for-docker

启动成功后,我们就可以通过  IP:端口 来访问Docker UI 界面了

我的虚拟机的静态IP地址是192.168.132.10  Docker UI端口是默认的:9000。

所以地址是192.168.132.10:9000

如果你的端口设置的是8089:你的Docker UI地址是 192.168.132.10:8089

STATUS:UP代表容器正在运行,Exited代表容器关闭

Docker可视化管理工具——Portainer

简介

Portainer 是一个轻量级的管理 UI ,可让你轻松管理不同的 Docker 环境(Docker 主机或 Swarm 群集)。它由可在任何 Docker 引擎上运行的单个容器组成,旨在使部署更简单 。
提供状态显示面板、应用模板快速部署、容器镜像网络数据卷的基本操作(包括上传下载镜像,创建容器等操作)、事件日志显示、容器控制台操作、Swarm集群和服务等集中管理和操作、登录用户管理和控制等功能。

优点
既可以管理单机环境,也可以管理 Swarm 集群
提供了用户的登录界面
可以为用户分配某个容器

缺点
暂时没发现

搜索portainer镜像

命令:docker search portainer

拉取portainer镜像

命令:docker pull portainer/portainer

启动portainer容器

Portainer使用默认的9000端口进行访问,如果此端口被其他应用程序占用,Portainer将无法启动。

因为我前面安装了Docker UI 使用的端口就是9000,所以,我这里就将9000端口改为8080 这样就可以通过192.168.132.10:8080来访问portainer的UI界面了

myprtainer:我是自己定义的名称,表示容器名称

命令:docker run -d -p 8080:9000 --restart=always -v /var/run/docker.sock:/var/run/docker.sock --name myprtainer portainer/portainer 

 这就是Portainer的管理界面:进入的时候需要设置用户名和密码

如果Portainer使用的端口已被其他应用程序占用,可以通过更改Portainer的端口号来解决冲突。

以下是通过Docker命令更改Portainer端口的示例:

命令:docker run -d -p 8080:9000 --name=myportainer portainer/portainer

name=myportainer:表示我要将name为myportainer的容器的端口号改为8080

启用Portainer的远程访问

默认情况下,Portainer只允许在本地主机上访问。如果您想从其他计算机上访问Portainer,需要启用Portainer的远程访问。可以通过设置环境变量来实现。以下是启用远程访问的示例:

docker run -d -p 8080:9000 -e "AGENT_CLUSTER_ADDR=agent:9001" --name=myportainer --restart=always portainer/portainer

在上述示例中,通过设置AGENT_CLUSTER_ADDR环境变量,将Portainer的访问限制解除,允许从其他计算机上访问。

常用的Docker命令:

命令:docker version    显示docker版本信息

命令:docker info          显示docker系统系统信息,镜像以及容器数量等信息

命令:docker images     查看本地所有镜像

启动容器:

命令:docker start 903c48353e37   启动容器ID为:903c48353e37这个容器

重启容器

 命令:docker restart 903c48353e37   重启容器ID为:903c48353e37这个容器

停止容器

命令:docker stop 903c48353e37   停止容器ID为:903c48353e37这个容器

删除容器:删除容器前需要先停止容器

命令:docker rm -f 903c48353e37   删除容器ID为:903c48353e37这个容器

杀掉容器

命令:docker kill 903c48353e37   杀掉容器ID为:903c48353e37这个容器

 其他常用命令

命令:docker container ls  可以查看当前正在运行的容器

命令:docker container ls -a   可以列举出所有的容器,包括正在运行的和没有运行的容器 

命令:docker ps  查看所有正在运行的容器

命令:docker ps -a  查看所有的容器,包括已经停止的容器

命令:docker image ls       用于列出所有镜像

命令:docker rmi -f abc    强制删除 镜像id为 abc 的镜像

命令:docker rmi --no-prune  abc  不移除镜像id为 abc 的镜像的过程镜像,默认移除

命令:docker ps -a   显示所有容器,包括未运行的

命令:docker ps -l     显示最后一个运行的容器(无论该容器目前处于什么状态)

命令:docker ps -n 5  数量5:表示显示最后 5 个运行容器(无论该容器目前处于什么状态)

命令:docker ps -s  显示总的文件大小

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

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

相关文章

基础堆溢出原理与DWORD SHOOT实现

堆介绍 堆的数据结构与管理策略 程序员在使用堆时只需要做三件事情:申请一定大小的内存,使用内存,释放内存。 对于堆管理系统来说,响应程序的内存使用申请就意味着要在"杂乱"的堆区中"辨别"出哪些内存是正在…

Python实现交易策略评价指标-夏普比率

1.夏普比率的定义 在投资的过程中,仅关注策略的收益率是不够的,同时还需要关注承受的风险,也就是收益风险比。 夏普比率正是这样一个指标,它表示承担单位的风险会产生多少超额收益。用数学公式描述就是: S h a r p R…

【算法每日一练]-图论(保姆级教程 篇6(图上dp))#最大食物链 #游走

目录 题目:最大食物链 解法一: 解法二: 记忆化 题目:游走 思路: 题目:最大食物链 解法一: 我们标记f[i]是被f[x]捕食的点对应的类食物链数 不难得出: f[x]∑(f[i]) 首先从生…

206 反转链表

解题思路可以有两种方法:递归 or 迭代。 \qquad 迭代:通过使用for循环遍历,完成目标。方法直观,容易理解。 \qquad 递归:通过函数调用其自身,完成目标。递归最复杂、最重要的部分就是递归函数的构建&#…

【数据结构】——栈|队列(基本功能)

目录 栈 基本概念 栈的常见基本操作 栈的存储 ✌栈的基本操作实现 栈的构建 栈的初始化 入栈 打印栈 出栈 获取栈顶元素 获取栈的有效元素个数 判断栈是否为空 销毁栈 队列 基本概念 队列的常见基本操作 ✌队列的基本操作实现 队列的构建 初始化 入队列 出…

Spring Security 6.x 系列(9)—— 基于过滤器链的源码分析(二)

一、前言 在本系列文章: Spring Security 6.x 系列(4)—— 基于过滤器链的源码分析(一)中着重分析了Spring Security在Spring Boot 的自动配置、 DefaultSecurityFilterChain 的构造流程、FilterChainProxy 的构造流…

详解原生Spring当中的事务

😉😉 学习交流群: ✅✅1:这是孙哥suns给大家的福利! ✨✨2:我们免费分享Netty、Dubbo、k8s、Mybatis、Spring...应用和源码级别的视频资料 🥭🥭3:QQ群:583783…

Spring Security 6.x 系列(8)—— 源码分析之配置器SecurityConfigurer接口及其分支实现

一、前言 本章主要内容是关于配置器的接口架构设计,任意找一个配置器一直往上找,就会找到配置器的顶级接口:SecurityConfigurer。 查看SecurityConfigurer接口的实现类情况: 在 AbstractHttpConfigurer 抽象类的下面可以看到所有…

idea类和方法模版

类模版 修改目标位置 class #if (${PACKAGE_NAME} && ${PACKAGE_NAME} ! "")package ${PACKAGE_NAME};#end #parse("File Header.java")/*** ${Description}* author whc ${YEAR}/${MONTH}/${DAY}* version v1.0 */public class ${NAME} { }inte…

【网络安全】虚假IP地址攻击如何防范?

在当今的网络时代,虚假IP地址攻击已成为一种新型的网络攻击方式,给网络安全带来了极大的威胁。那么,什么是虚假IP地址攻击?又如何进行溯源和防范呢?本文将为您揭开这一神秘面纱。 一、虚假IP地址攻击概述 虚假IP地址攻…

[python]离线加载fetch_20newsgroups数据集

首先手动下载这个数据包 http://qwone.com/~jason/20Newsgroups/20news-bydate.tar.gz 下载这个文件后和脚本放一起就行,然后 打开twenty_newsgroups.py文件(在fetch_20newsgroups函数名上,右键转到定义即可找到) 之后运行代码即…

羊大师教你如何有效应对冬季流感,保护自己与家人

羊大师教你如何有效应对冬季流感,保护自己与家人 随着冬季的临近,流感病毒将再次蔓延。如何预防冬季流感来袭,成为了许多人关注的话题。幸运的是,我们可以采取一系列的预防措施来保护自己和家人,避免被流感侵袭。下面…

【Altium designer 20】

Altium designer 20 1. Altium designer 201.1 原理图库1.1.1 上划岗 在字母前面加\在加字母1.1.2 自定义快捷键1.1.3 对齐1.1.4 在原有的电路图中使用封装1.1.5 利用excel创建IC类元件库1.1.6 现有原理图库分类以及调用1.1.7 现有原理图库中自动生成原理图库 1.2 绘制原理图1.…

【初阶解法-数据结构】包含min函数的栈(代码+图示)

【数据结构】刷题-包含min函数的栈(代码图示)-初阶解法 文章目录 【数据结构】刷题-包含min函数的栈(代码图示)-初阶解法题目提炼题目要求分析题目总结思路代码时间/空间复杂度进阶版 题目 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的 min 函…

Ubuntu22.04 交叉编译mp4V2 for Rv1106

一、配置工具链环境 sudo vim ~/.bashrc在文件最后添加 export PATH$PATH:/opt/arm-rockchip830-linux-uclibcgnueabihf/bin 保存,重启机器 二、下载mp4v2 下载路径:MP4v2 | mp4v2 三、修改CMakeLists.txt 四、执行编译 mkdir build cd buildcmak…

羊大师教你如何在冬天运动,然后悄悄惊艳所有人

羊大师教你如何在冬天运动,然后悄悄惊艳所有人 寒冷的冬季,寂静的清晨,你是否也曾感到在冰冷的天气中进行锻炼是一件非常困难的事情?但是,现在请跟随小编羊大师一起来探索冬季秘密运动,让你在春节惊艳众人…

人工智能_机器学习060_核函数对应数学公式_数据空间错位分割_简单介绍_以及核函数总结---人工智能工作笔记0100

我们之前做的都是线性分类问题,那么需要一根线来分割类别,但是,如果出现了,环形数据,我们知道,在二维中我们就无法分割了,那么有没有什么办法分割呢? 实际上是有的,可以看到,我们可以把数据进行升维,可以看到,如果把数据升高到2维度以上,可以看到,神奇的一幕出现了,这个时候,因…

【Linux】进程控制--进程创建/进程终止/进程等待/进程程序替换/简易shell实现

文章目录 一、进程创建1.fork函数2.fork函数返回值3.写时拷贝4.fork常规用法5.fork调用失败的原因 二、进程终止1.进程退出码2.进程退出场景3.进程常见退出方法 三、进程等待1.为什么要进行进程等待2.如何进行进程等待1.wait方法2.waitpid方法3.获取子进程status4.进程的阻塞等…

价差后的几种方向,澳福如何操作才能盈利

在价差出现时,澳福认为会出现以下几种方向。 昂贵资产的贬值和便宜资产的平行升值。昂贵的资产贬值,而便宜的资产保持不变。昂贵资产的贬值和便宜资产的平行贬值,但昂贵资产的贬值速度更快,超过便宜资产。更贵的一对的进一步升值和…

7. 系统信息与系统资源

7. 系统信息与系统资源 1. 系统信息1.1 系统标识 uname()1.2 sysinfo()1.3 gethostname()1.4 sysconf() 2. 时间、日期2.1 Linux 系统中的时间2.1.1 Linux 怎么记录时间2.1.2 jiffies 的引入 2.2 获取时间 time/gettimeofday2.2.1 time()2.2.2 gettimeofday() 2.3 时间转换函数…