欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 健康 > 美食 > [Docker#8] 容器配置 | Mysql | Redis | C++ | 资源控制 | 命令对比

[Docker#8] 容器配置 | Mysql | Redis | C++ | 资源控制 | 命令对比

2025/3/15 0:07:51 来源:https://blog.csdn.net/2301_80171004/article/details/143754538  浏览:    关键词:[Docker#8] 容器配置 | Mysql | Redis | C++ | 资源控制 | 命令对比

目录

一:Mysql 容器化安装

二:Redis 容器化安装

Redis 简介

Redis 容器创建

三:C++容器制作

四:容器资源更新

常见问题


一:Mysql 容器化安装

进入 mysql 的镜像网站,查找 mysql 的镜像

mysql docker hub 官网,可以看到有这么多的 tag

选择使用最多的 5.7 版本,拉取镜像

docker pull mysql:5.7

启动一个 MySQL 容器,并指定密码和端口开放

docker run --name mysql -e MYSQL_ROOT_PASSWORD=maxhouroot -p 8200:3306 -d mysql:5.7

进入容器登录,验证 MySQL 是否正常运行

 

如果对外开放了 3877 端口,可以通过 GUI 工具远程登录到界面上

  • 例如使用 MySQL Workbench 连接。

释放空间

docker stop mysql
docker rm mysql

二:Redis 容器化安装

Redis 简介

Redis 出现的原因

  • 在 Web 应用发展的初期,关系型数据库受到了较为广泛的关注和应用,因为那时 Web 站点基本上访问和并发不高、交互也较少。
  • 随着访问量的提升,使用关系型数据库的 Web 站点在性能上出现了瓶颈,主要瓶颈在磁盘的I/O 上。
  • 随着互联网技术的进一步发展,对性能有了更高的需求,主要体现在低延迟的读写速度和支撑海量的数据和流量。

Redis 是什么

  • Redis 全称 Remote Dictionary Server,中文名为远程字典服务器
  • Redis 是一个使用 ANSI C 编写的开源、包含多种数据结构、支持网络、基于内存、可选持久性的键值对存储数据库。

Redis 的特性

  • 基于内存运行,性能高效
  • 支持分布式,理论上可以无限扩展
  • key-value 存储系统
  • 开源的使用 ANSI C 语言编写、遵守 BSD 协议、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API

Redis 的应用场景

  • 缓存系统(“热点”数据:高频读、低频写)
  • 计数器
  • 消息队列系统
  • 实时排行榜
  • 社交网络

Redis 生活案例

  • Redis 就像一个新华字典,可以根据某个字符快速找到字典对应的字。
Redis 容器创建

拉取 Redis 镜像

docker pull redis

启动 Redis 容器

docker run --name redis -p 6379:6379 -d redis

进入 Redis 容器并验证

 exec -it redis redis-cli
127.0.0.1:6379> ping
PONG

操作可视化:

用到的是 Another Redis Desktop Manager

释放空间

docker stop redis
docker rm redis

通过以上步骤,可以成功地将 MySQL 和 Redis 容器化,并进行基本的操作和验证


三:C++容器制作

下载 Ubuntu 镜像

docker pull ubuntu:22.04

启动容器

docker run --name mygcc -it ubuntu:22.04 bash

配置国内镜像源加速

sed -i 's@//.*archive.ubuntu.com@//mirrors.ustc.edu.cn@g' /etc/apt/sources.list

安装 gcc 和 vim

apt update
apt install gcc vim -y

编辑代码

mkdir src
cd src
vim demo.c

输入以下内容:

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

编译代码

gcc demo.c -o demo

在容器中运行

./demo

退出容器

exit

恢复容器

docker restart mygcc

清理容器释放空间

docker stop mygcc
docker rm mygcc

四:容器资源更新

运行一个 Nginx 容器

docker run -d --name mynginx5 -p 80:80 nginx:1.22.1

查看容器中的进程

docker top mynginx5 aux

查看资源的动态变化

docker stats

更新容器的最大内存

docker update -m 300m --memory-swap 600m mynginx5

执行命令打满 CPU

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

配置只能使用 10% 的 CPU

docker update --cpu-period=100000 --cpu-quota=10000 mynginx5

查看 CPU 使用情况

docker stats

停止容器,释放资源

docker stop mynginx5
docker rm mynginx5

常见问题

docker createdocker startdocker run 有什么区别?

  • docker create:从 Docker 镜像创建一个全新的容器,但不会立即运行
  • docker start:启动任何已停止的容器。如果使用 docker create ,可以使用此命令启动。
  • docker run:(=create+start) 创建并立即启动一个新的容器。如果在系统上找不到所需镜像,会从 Docker Hub 中拉取。

docker importdocker load 有什么区别?

  • docker save:将一个镜像导出为文件,使用 docker load 导入为镜像,保存所有历史记录。(迁移时建议使用这个)
  • docker export:将一个容器导出为文件,使用 docker import 导入为新的镜像,丢失所有元数据和历史记录。

docker rmdocker rmidocker prune 的差异?

  • docker rm:删除一个或多个容器
  • docker rmi:删除一个或多个镜像。
  • docker prune:删除不再使用的 Docker 对象。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词