多服务器上的 docker 实现互相访问

场景:

  • Server_1上有一个docker容器 containerX
  • Server_2上有一个docker容器 containerX
  • ...
  • Server_n上有一个docker容器 containerX

如何实现着 n 个docker之间的互相访问呢?

实现方式:

Step1:配置一个通用的容器

新建一个容器,在容器中做以下配置:

  • 确保已经安装,如果没有安装,则: sshsudo apt-get install openssh-server
  • 确保 ssh 开机启动,.bashrc 中添加 service ssh start。执行 source .bashrc
  • sshd配置(用于接受其它容器的链接):
shell 复制代码
$ vim /etc/ssh/sshd_config    # 修改 ssh 守护配置
	<<LongComment
  		###需要在文件末尾添加以下内容
  		port=2478  ##这个端口号不要跟本服务器其它Docker容器端口号重复!
  		PermitRootLogin yes 
  		PubkeyAuthentication yes 
  		PasswordAuthentication yes 
	LongComment
  • ssh配置(用于链接其它容器)
shell 复制代码
$ vim /etc/ssh/ssh_config 
	<<LongComment
  		###需要在文件末尾添加以下内容
  		port=2478  ##将端口号修改为想要连接的服务器容器端口号
	LongComment
  • 设置ssh公钥,免密登录 $ ssh-keygen -t rsa -C "multi-node"
    将生成的公钥内容 ~/.ssh/id_rsa.pub拷贝到 ~/.ssh/authorized_keys
Step2:将这个通用的容器(设为cont_g)导出为 tar 文件,拷贝到所有n个server上

docker export cont_g > cont_g.tar

Step3:将cont_g.tar导入为 image

docker import cont_g.tar container:generel

Step4:在所有的server上从image构建各自的容器

Server_1:Server_n 上的操作相同:
docker run -it --name containerX--network=host --ipc=host --privileged container:generel /bin/bash

最后,通过 ssh Server_x(x∈[1,n])就可以实现n个容器之间的互相访问了

相关推荐
安科士andxe1 小时前
深入解析|安科士1.25G CWDM SFP光模块核心技术,破解中长距离传输痛点
服务器·网络·5g
2601_949146534 小时前
Shell语音通知接口使用指南:运维自动化中的语音告警集成方案
运维·自动化
儒雅的晴天5 小时前
大模型幻觉问题
运维·服务器
Gofarlic_OMS5 小时前
科学计算领域MATLAB许可证管理工具对比推荐
运维·开发语言·算法·matlab·自动化
通信大师5 小时前
深度解析PCC策略计费控制:核心网产品与应用价值
运维·服务器·网络·5g
dixiuapp6 小时前
智能工单系统如何选,实现自动化与预测性维护
运维·自动化
Elastic 中国社区官方博客6 小时前
如何防御你的 RAG 系统免受上下文投毒攻击
大数据·运维·人工智能·elasticsearch·搜索引擎·ai·全文检索
小锋学长生活大爆炸6 小时前
【教程】免Root在Termux上安装Docker
运维·docker·容器
进击切图仔6 小时前
常用 Docker 命令备份
运维·docker·容器
NotStrandedYet7 小时前
《国产系统运维笔记》第8期:挑战国产化流媒体部署——银河麒麟+龙芯架构编译SRS实战全记录
运维·kylin·国产化·银河麒麟·龙芯·信创运维·srs编译安装