转--基于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

相关文章

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

redis中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

Win安装MySQL8全过程

《Win安装MySQL8全过程》:本文主要介绍Win安装MySQL8全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Win安装mysql81、下载MySQL2、解压文件3、新建文件夹data,用于保存数据库数据文件4、在mysql根目录下新建文件my.ini

使用Python和Pyecharts创建交互式地图

《使用Python和Pyecharts创建交互式地图》在数据可视化领域,创建交互式地图是一种强大的方式,可以使受众能够以引人入胜且信息丰富的方式探索地理数据,下面我们看看如何使用Python和Pyec... 目录简介Pyecharts 简介创建上海地图代码说明运行结果总结简介在数据可视化领域,创建交互式地

Java Stream流使用案例深入详解

《JavaStream流使用案例深入详解》:本文主要介绍JavaStream流使用案例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录前言1. Lambda1.1 语法1.2 没参数只有一条语句或者多条语句1.3 一个参数只有一条语句或者多

Java Spring 中 @PostConstruct 注解使用原理及常见场景

《JavaSpring中@PostConstruct注解使用原理及常见场景》在JavaSpring中,@PostConstruct注解是一个非常实用的功能,它允许开发者在Spring容器完全初... 目录一、@PostConstruct 注解概述二、@PostConstruct 注解的基本使用2.1 基本代

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式

springboot使用Scheduling实现动态增删启停定时任务教程

《springboot使用Scheduling实现动态增删启停定时任务教程》:本文主要介绍springboot使用Scheduling实现动态增删启停定时任务教程,具有很好的参考价值,希望对大家有... 目录1、配置定时任务需要的线程池2、创建ScheduledFuture的包装类3、注册定时任务,增加、删