多服务器上的 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个容器之间的互相访问了

相关推荐
曲幽20 小时前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了
python·docker·web·pot·translate·libretranslate·arogstranslate
zzzzzz3102 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
XIAOHEZIcode2 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
用户0328472220703 天前
如何搭建本地yum源(上)
运维
武子康3 天前
调查研究-183 Apple container:Mac 上用轻量 VM 跑 Linux 容器,Swift 会改写本地容器体验吗?
docker·容器·apple
大树886 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠6 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质6 天前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
小宇宙Zz6 天前
Maven依赖冲突
java·服务器·maven
Inhand陈工6 天前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信