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

目录

[一:Mysql 容器化安装](#一:Mysql 容器化安装)

[二:Redis 容器化安装](#二:Redis 容器化安装)

[Redis 简介](#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 create docker start docker run有什么区别?

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

docker import docker load有什么区别?

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

docker rm docker rmi docker prune的差异?

  • docker rm:删除一个或多个容器。
  • docker rmi:删除一个或多个镜像。
  • docker prune:删除不再使用的 Docker 对象。
相关推荐
Dajiaonew11 分钟前
SpringCloud Stream 快速入门
后端·spring·spring cloud
用户693717500138422 分钟前
8.Kotlin 类:类的基础:主构造函数与次构造函数
android·后端·kotlin
用户693717500138423 分钟前
9.Kotlin 类:类的核心:属性 (Property) 与自定义访问器 (Getter/Setter)
android·后端·kotlin
回家路上绕了弯28 分钟前
接口 QPS 从 100 飙到 1000?从应急到根治的全流程优化方案
分布式·后端
袖手蹲31 分钟前
树莓派 5 Trixie 镜像 + Docker 架设 Eclipse Mosquitto 与 ESP32 双向 MQTT 交互
运维·docker·容器
The_cute_cat40 分钟前
通过内网穿透为课设临时添加域名访问【springboot+Vue】
vue.js·spring boot·后端
盛世隐者1 小时前
【Linux】好用的命令记录
linux
howcode1 小时前
女友去玩,竟带回一道 “虐哭程序员” 的难题
后端·设计模式·程序员
z***94841 小时前
SpringBoot教程(三十二) SpringBoot集成Skywalking链路跟踪
spring boot·后端·skywalking
程序员西西1 小时前
SpringBoot 数据存储实战拆解!
后端