Kubernetes认证考试自学系列 | 容器互联

书籍来源:《CKA/CKAD应试指南:从Docker到Kubernetes完全攻略》

一边学习一边整理读书笔记,并与大家分享,侵权即删,谢谢支持!

附上汇总贴:Kubernetes认证考试自学系列 | 汇总_COCOgsta的博客-CSDN博客


有时我们需要多个应用共同工作才能对外提供服务,比如使用wordpress和mysql两个应用才能搭建博客。wordpress需要连接到mysql上,这样就需要两个容器,此时就需要将wordpress容器连接到mysql容器上。

1.9.1 方法1:通过容器IP的方式访问

前面在实战练习里,已经创建了一个名字叫作db的容器,ip为172.17.0.2且里面有一个数据库叫作blog。

[root@vms100 ~]# docker exec db ip a | grep 'inet '
  inet 127.0.0.1/8 scope host lo
  inet 172.17.0.2/16 scope global eth0
[root@vms100 ~]#
复制代码

下面使用wordpress镜像创建一个容器,此容器需要连接到mysql上。

这个容器需要使用的变量如下。

--WORDPRESS_DB_HOST用来指定mysql服务器的地址。

--WORDPRESS_DB_USER用来指定登录mysql的用户名。

--WORDPRESS_DB_PASSWORD用来指定登录mysql的密码。

--WORDPRESS_DB_DATABASE用来指定需要的数据库。

步骤1:创建wordpress的容器,并把端口发布出去,使得外界的主机能访问。

[root@vms100 ~]# docker run -dit --name blog --restart=always -e WORDPRESS_DB_HOST=172.17.0.2 -e WORDPRESS_DB_USER=root -e WORDPRESS_DB_PASSWORD=redhat -e WORDPRESS_DB_NAME=blog -p 80:80 hub.c.163.com/library/wordpress
85647b3af3d21d110971a4b40ccf650a6e396baae6d8e775d32333e16349cc45
[root@vms100 ~]#
复制代码

这里通过变量WORDPRESS_DB_HOST指定了mysql服务器的地址。

在地址栏输入192.168.26.100,如图1-18所示。

选择中文→继续,如图1-19所示。

并没有要求输入数据库的信息,因为它已经可以自动连接到数据库了。

这种方法有个问题,就是如果db容器出问题而重新生成的时候,IP可能会发生改变,那么wordpress就连接不上了。

1.9.2 方法2:使用link的方式

在创建容器时,--link选项的用法如下。

--link 容器名:别名
复制代码

在此命令后续部分想连接到此容器的话,直接使用别名即可。

步骤1:再次创建wordpress容器。

[root@vms100 ~]# docker run -dit --name blog --restart=always --link db:mysqlxx -e WORDPRESS_DB_HOST=mysqlxx -e WORDPRESS_DB_USER=root -e WORDPRESS_DB_PASSWORD=redhat -e WORDPRESS_DB_NAME=blog -p 80:80 hub.c.163.com/library/wordpress
4805eeod8a5cd079ad7e2d028e30695288172645fa354874c2aadc642f4a7e17
[root@vms100 ~]#
复制代码

这里创建名字叫blog的容器,用--link连接到名字为db的容器,起别名为mysqlxx,在WORDPRESS_DB_HOST这个变量里不再写db的IP了,而是直接写别名mysqlxx,此时blog正常运行,且能访问到数据库。

注意:--link里容器的别名是可以随意起的。

但是这个命令还是太过于复杂,可以进一步简化。刚才介绍了wordpress镜像所使用的变量,现在来看下它们的默认值。

--WORDPRESS_DB_HOST默认为link所连接的容器,且别名为mysql。

--WORDPRESS_DB_USER默认为root。

--WORDPRESS_DB_PASSWORD默认为mysql的root所使用的密码。

--WORDPRESS_DB_DATABASE默认为wordpress。

所以如果我们创建MySQL容器的时候,指定一个数据库是wordpress而不是blog的话,则上面的选项都可以不写。

步骤2:删除blog和db容器。

[root@vms100 ~]# docker rm -f db 
db
[root@vms100 ~]# docker rm -f blog 
blog
[root@vms100 ~]#
复制代码

步骤3:创建一个mysql的容器。

[root@vms100 ~]# docker run -d --name=db --restart=always -e MYSQL_ROOT_PASSWORD=redhat -e MYSQL_DATABASE=wordpress hub.c.163.com/library/mysql
7a422e94a4bd3d747f6d434593da730532b14334a3ddd814103e3f4e9f98a939
[root@vms100 ~]#
复制代码

在这个mysql容器里,通过变量MYSQL_DATABASE创建一个名字叫wordpress的库。在wordpress容器里如果没指定使用mysql里哪个库的话,默认使用的是名字叫wordpress的库。

步骤4:创建一个wordpress的容器,所有变量均使用默认值。

[root@vms100 ~]# docker run -dit --name blog --restart=always --link db:mysql -p 80:80 hub.c.163.com/library/wordpress 
33d96d183cceaa01f65caa97ef137a7ad5025fc7dbac9c30324ce319d 0827773
[root@vms100 ~]#
复制代码

这里别名使用的是mysql,--WORDPRESS_DB_HOST默认会连接别名为mysql的容器,这里创建wordpress容器的选项很少,因为都是使用的默认值。

在浏览器里测试,如图1-20所示。

虽然在创建wordpress容器时没有指定太多mysql的信息,但依然能跳过数据库的设置,说明wordpress容器是正确连接到数据库了。

猜你喜欢

转载自blog.csdn.net/guolianggsta/article/details/130541643
今日推荐