我们都知道docker是一个个容器,他们相互独立互不影响,但是这也产生了一个问题,如果我们安装了一个mysql在项目里面需要连接mysql怎么办呢?如果通过127.0.0.1:3306这样的方式肯定行不通的,因为他们的网络是独立的,我给大家总结出两种简单的方法,可以进行容器之间相互访问。具体如下:
第一种:可以查询我们需要访问的容器IP,用IP进行直接访问,但是这样会出现一个问题,就是我们容器如果关掉重启的话我们的IP也相应的发生变化,那么我们就需要在重新查询IP在进行配置,这种方法是很麻烦的,但这也是一种方法,具体的方法如下,下面的mysql是容器的名字,也可以换成容器的ID:
docker inspect mysql |grep IPAddress
第二种: 那么就是通过创建bridge网络进行访问。
创建网络:my-net随机取的网络名字,执行以下命令
docker network create my-net
查看创建的网络:
docker network ls
到这里我们就创建好了一个网络了,后面我们直接将容器加入到网络就可以直接通过容器名字进行访问。下面我们将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
那么我们如何限制内存启动一个容器呢?
下面我创建一个容器的时候限制了容器占用内存大小为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
下面动态修改内容大小,修改mysql内存大小为400兆。
docker update --memory 400m --memory-swap -1 mysql