Docker--Docker Container(容器) 之容器实战

对docker容器的前两篇文章
Docker--Docker Container(容器) 之 操作实例
Docker--Docker Container(容器)

Mysql容器化安装

我们可以先在Docker Hub上查看对应的Mysql镜像,拉取对应的镜像:

拉取mysql5.7版本的镜像:

cpp 复制代码
docker pull mysql:5.7

运行容器,并设置密码和端口映射:

cpp 复制代码
docker run --name mysql -e MYSQL_R00T_PASSW0RD=123456 -p 8090:3306 -d mysql:5.7

使用以下命令查看容器是否在运行:

cpp 复制代码
docker ps

进入容器的端口界面:

cpp 复制代码
docker exec -it mysql bash

然后登录上Mysql:

cpp 复制代码
bash-4.2# mysql -p

看一下数据库列表:

还可以通过workbench软件远程访问到mysql容器:

设置好映射端口和主机ip后,输入密码就能远程访问;

输入show databases 进行查看:

cpp 复制代码
docker stop mysql
docker rm mysql

释放空间

注意事项:

端口映射:如果需要从主机访问MySQL服务,可以在创建容器时使用-p参数映射端口。

数据持久化:为了保证数据不丢失,可以使用-v参数挂载数据目录到主机。

安全性:不要在生产环境中使用默认的root密码和端口,以及不要将敏感信息暴露在环境中。

Redis容器化安装

在Docker Hub上搜索Redis镜像,可以使用以下命令:

cpp 复制代码
docker search redis

拉取redis7.0版本的镜像:

cpp 复制代码
docker pult redis:7.0

运行容器redis,并设置端口映射:

cpp 复制代码
docker run --name redis -p 8089:6379 -d redis:7.0

进入redis容器运行界面,并运行redis :

cpp 复制代码
root@VM-8-12-ubuntu:~# docker exec -it redis bash 
root@545e7a6a42ec:/data# redis-cli

设置一个key:

也可以通过软件Redis Desktop Manager 远程访问Redis容器:

释放空间:

cpp 复制代码
docker stop redis
docker rm redis

注意事项:

  • 安全性:不要在生产环境中使用默认的密码和端口,以及不要将敏感信息暴露在环境中。可以通过修改redis.conf配置文件来设置密码和其他安全选项。
  • 资源限制:根据实际需求为Redis容器分配适当的CPU、内存和磁盘资源。可以使用Docker的--cpus、--memory和--storage-opt等参数来限制容器的资源使用。
  • 备份与恢复:定期备份Redis数据,并测试恢复过程以确保数据的安全性和可恢复性

C++容器简单制作

拉取一个ubuntu22.04的镜像:

cpp 复制代码
docker pull ubuntu:22.04

运行ubuntu容器:

cpp 复制代码
docker run --name mygcc -it ubuntu:22.04 bash

在ubuntu镜像中下载vim:

cpp 复制代码
apt update
apt install gcc vim -y

然后编辑一个demo.c C文件

cpp 复制代码
#include <stdio.h>
int main()
{
printf("hello docker!\n");
return 0;
}

编译代码并生成可执行程序

cpp 复制代码
gcc -o demo demo.c

退出并删除mygcc容器 :

cpp 复制代码
exit
docker rm mygcc

容器资源更新

运行容器mynginx,映射端口为8080 ,后台运行 :

cpp 复制代码
docker run -d --name mynginx1 -p 8080:80 nginx:1.23.4

对于命令 docker top 加上 aux 就能查看cpu和内存资源:

也可通过指令docker stats 来实时查看不断追踪资源使用情况:

cpp 复制代码
docker stats

通过资源更新将内存上限调为300m :

cpp 复制代码
docker update -m 300m --memory-swap 600m mynginx1

查看资源使用情况可以看到内存上限变为300m :

进入mynginx1运行端口 :

cpp 复制代码
docker exec -it mynginx1 bash

我们在容器中执行一个命令,打满 cpu:

cpp 复制代码
for i in `seq 1 $(cat /proc/cpuinfo | grep "physical id" |wc -l)`; 
do     
dd if=/dev/zero of=/dev/null &  
done

#cat /proc/cpuinfo |grep "physical id" | wc -l 可以获得 CPU 的个数,我们将其表示为 N

#seq 1 N 用来生成1到N之间的数字 , 通过for循环 不断执行命令 1-N;

#for i in seq 1 N; 就是循环执行命令,从1到N

#dd if=/dev/zero of=/dev/null 执行 dd 命令, 输出到/dev/null, 实际上只占用 CPU, 没有 IO 操作

#由于连续执行N个(N是 CPU 个数)的 dd 命令, 且使用率为 100%, 这时调度器

会调度每个 dd 命令在不同的 CPU 上处理,最终就实现所有CPU占用率 100%

更新容器mynginx1 的cpu上限为10%:

cpp 复制代码
docker update --cpu-period=100000 --cpu-quota=10000 mynginx1

停止运行的容器,并释放资源:

cpp 复制代码
docker stop mynginx1
docker rm mynginx1
相关推荐
计算机小手21 分钟前
AI 驱动数据分析:开源 SQLBot 项目探索,基于大模型和 RAG 实现精准问数与图表挖掘
经验分享·docker·开源软件
工藤新一¹1 小时前
Linux —— 虚拟进程地址空间
linux·运维·服务器·c/c++·虚拟进程地址空间
AI大模型1 小时前
基于Docker+DeepSeek+Dify :搭建企业级本地私有化知识库超详细教程
docker·llm·deepseek
再难也得平2 小时前
Linux初级篇
linux·运维·服务器
张璐月3 小时前
go docker-compose启动前后端分离项目 踩坑之旅
开发语言·docker·golang
attitude.x3 小时前
Swift 协议扩展与泛型:构建灵活、可维护的代码的艺术
运维·服务器·网络
止观止3 小时前
GitHub自动化利器:Probot框架实战指南
运维·自动化·github
方先森有点懒3 小时前
CentOS 7.2 虚机 ssh 登录报错在重启后无法进入系统
linux·运维·centos·ssh
shylyly_3 小时前
Linux->日志的实现
linux·运维·服务器
剑客的茶馆4 小时前
新服务器从0开始搭配Ubuntu+Conda+Docker+Dify
服务器·ubuntu·docker·conda·dify