docker 容器相互访问以及查看内存使用情况

我们都知道docker是一个个容器,他们相互独立互不影响,但是这也产生了一个问题,如果我们安装了一个mysql在项目里面需要连接mysql怎么办呢?如果通过127.0.0.1:3306这样的方式肯定行不通的,因为他们的网络是独立的,我给大家总结出两种简单的方法,可以进行容器之间相互访问。具体如下:

第一种:可以查询我们需要访问的容器IP,用IP进行直接访问,但是这样会出现一个问题,就是我们容器如果关掉重启的话我们的IP也相应的发生变化,那么我们就需要在重新查询IP在进行配置,这种方法是很麻烦的,但这也是一种方法,具体的方法如下,下面的mysql是容器的名字,也可以换成容器的ID:

docker 容器相互访问以及查看内存使用情况_第1张图片

docker inspect mysql |grep IPAddress

第二种: 那么就是通过创建bridge网络进行访问。

创建网络:my-net随机取的网络名字,执行以下命令

docker network create my-net

查看创建的网络:

docker network ls

docker 容器相互访问以及查看内存使用情况_第2张图片

到这里我们就创建好了一个网络了,后面我们直接将容器加入到网络就可以直接通过容器名字进行访问。下面我们将mysql和redis加入到网络中。

#把mysql加入到网络

 docker network connect my-net mysql 

#把nacos加入到网络
 docker network connect my-net redis 
 

通过下面的命令查看是否加入成功了

docker network inspect my-net

后面在创建项目,我们也需要将项目加入到这个网络中去,然后项目里面连接mysql我们就可以直接改成容器名字即可。

docker容器占用内存问题?

我们在创建启动各个服务容器的时候最好都限制一下docker内存大小,防止占用过多内存。

通过以下命令可以查看各个容器占用内存情况:

 docker stats --no-stream

docker 容器相互访问以及查看内存使用情况_第3张图片

那么我们如何限制内存启动一个容器呢?

下面我创建一个容器的时候限制了容器占用内存大小为300兆。

-m 300m

docker run -m 300m -d -p 8848:8848 -e MODE=standalone -e PREFER_HOST_MODE=hostname -v /home/nacos/init.d/custom.properties:/home/nacos/init.d/custom.properties -v /home/nacos/logs:/home/nacos/logs --restart always --name nacos nacos/nacos-server

docker 容器相互访问以及查看内存使用情况_第4张图片

下面动态修改内容大小,修改mysql内存大小为400兆。

docker update --memory 400m --memory-swap -1 mysql

docker 容器相互访问以及查看内存使用情况_第5张图片 

 

你可能感兴趣的:(docker,容器,运维)