转--基于OpenEuler的Docker容器安装使用

2024-06-22 16:20

本文主要是介绍转--基于OpenEuler的Docker容器安装使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

/usr/sbin/sshd

执行以下命令查看ssh服务是否已经开始监听22端口:

netstat -tuln | grep :22

看到以下输出证明ssh服务已启动:

[root@master /]# netstat -tuln | grep :22
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN     
tcp6       0      0 :::22                   :::*                    LISTEN

注意:配置ssh服务在容器启动时自启动该服务,请参考该教程最后步骤。

步骤九:设置Docker容器密码
首先安装passwd工具,执行以下命令:

yum install passwd -y

设置Docker容器root账户密码,在终端运行以下命令。

passwd root

按照提示输入新的root密码两次。
步骤十:从Docker容器退出
退出Docker容器,在终端运行以下命令。

exit

步骤十一:测试SSH连接进入Docker容器
SSH进入master Docker容器,可以在Windows PowerShell终端运行以下命令。

ssh root@192.168.157.200

使用ssh连接master Docker容器的固定IP,输入root用户的密码来建立连接。
测试ssh连接成功后,退出ssh连接:

exit

步骤十二:提交容器成为镜像
将master容器保存为新的自定义镜像,执行以下命令:

docker commit master my_docker_image

检查保存结果:

docker images

将输出类似以下信息:

[root@ehdpc ~]# docker images
REPOSITORY            TAG                 IMAGE ID            CREATED             SIZE
my_docker_image       latest              b9e5ba96b775        18 hours ago        330MB
openeuler/openeuler   latest              d806015811ce        5 weeks ago         171MB
hello-world           latest              d2c94e258dcb        12 months ago       13.3kB

步骤十三:用自定义镜像创建容器
使用自定义镜像创建slave1和slave2容器,执行以下命令:

docker run -itd --name slave1 --network my_macvlan_network --ip=192.168.157.201 --hostname=slave1 my_docker_image /bin/bash
docker run -itd --name slave2 --network my_macvlan_network --ip=192.168.157.202 --hostname=slave2 my_docker_image /bin/bash

最后查看运行中的Docker容器,执行:

docker ps -a

将输出类似以下信息:

CONTAINER ID        IMAGE                        COMMAND             CREATED             STATUS              PORTS               NAMES
7751668f2e8b        my_docker_image              "/bin/bash"         12 seconds ago      Up 11 seconds                           slave2
739138768ee3        my_docker_image              "/bin/bash"         18 seconds ago      Up 17 seconds                           slave1
a21b573c926b        openeuler/openeuler:latest   "/bin/bash"         2 hours ago         Up 2 hours                              master

表示master、slave1、slave2三个OpenEuler容器成功创建,并且在Windows主机上可以通过ssh连接。

扩展内容
以上步骤创建的网络会在OpenEuler主机重启的时候丢失,所以每次主机重启时都需要重新创建网络,并和Docker容器做连接。
步骤十四:创建新网络
在终端运行以下命令。

docker network create -d macvlan --subnet=192.168.157.0/24 --gateway=192.168.157.2 -o parent=ens33 my_macvlan_network

步骤十五:容器连接新网络
在终端运行以下命令。

docker network connect --ip 192.168.157.200 my_macvlan_network master

将创建的新网络和master容器连接。
步骤十六:容器启动start
在终端运行以下命令。

docker start master

步骤十七:容器重启restart
在终端运行以下命令。

docker restart master

终极扩展内容
配置开机运行脚本来创建网络和启动容器。
步骤十八:创建脚本

sudo vi /etc/init.d/start_my_dockers.sh

输入以下内容并保存退出:

#!/bin/bash# 创建网络
docker network create -d macvlan --subnet=192.168.157.0/24 --gateway=192.168.157.2 -o parent=ens33 my_macvlan_network# 连接容器到网络
docker network connect --ip 192.168.157.200 my_macvlan_network master
docker network connect --ip 192.168.157.201 my_macvlan_network slave1
docker network connect --ip 192.168.157.202 my_macvlan_network slave2# 启动容器
docker start master
docker start slave1
docker start slave2# 启动SSH服务
while ! docker exec master netstat -tuln | grep -q ":22"; doecho "master SSH service not yet started. Trying again..."docker exec -d master /usr/sbin/sshdsleep 1
doneecho "master container SSH service started successfully."while ! docker exec slave1 netstat -tuln | grep -q ":22"; doecho "slave1 SSH service not yet started. Trying again..."docker exec -d slave1 /usr/sbin/sshdsleep 1
doneecho "slave1 container SSH service started successfully."while ! docker exec slave2 netstat -tuln | grep -q ":22"; doecho "slave2 SSH service not yet started. Trying again..."docker exec -d slave2 /usr/sbin/sshdsleep 1
doneecho "slave2 container SSH service started successfully."

添加可执行权限:

sudo chmod +x /etc/init.d/start_my_dockers.sh

步骤十九:创建并启动自定义服务

sudo vi /etc/systemd/system/my_dockers.service

输入以下内容并保存退出:

[Unit]
Description=Start Docker network and connect containers
Requires=docker.service
After=docker.service[Service]
Type=oneshot
ExecStart=/etc/init.d/start_my_dockers.sh[Install]
WantedBy=multi-user.target

启用该服务使开启运行:

sudo systemctl daemon-reload
sudo systemctl enable my_dockers.service

这样,在每次启动VMWare虚拟机后,master、slave1、slave2三个Docker容器也会启动,并且每个容器自启动ssh服务以便外部连接。

这篇关于转--基于OpenEuler的Docker容器安装使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1084796

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

Redis 基本数据类型和使用详解

《Redis基本数据类型和使用详解》String是Redis最基本的数据类型,一个键对应一个值,它的功能十分强大,可以存储字符串、整数、浮点数等多种数据格式,本文给大家介绍Redis基本数据类型和... 目录一、Redis 入门介绍二、Redis 的五大基本数据类型2.1 String 类型2.2 Hash

Redis中Hash从使用过程到原理说明

《Redis中Hash从使用过程到原理说明》RedisHash结构用于存储字段-值对,适合对象数据,支持HSET、HGET等命令,采用ziplist或hashtable编码,通过渐进式rehash优化... 目录一、开篇:Hash就像超市的货架二、Hash的基本使用1. 常用命令示例2. Java操作示例三

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他