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
相关推荐
颜淡慕潇1 小时前
【K8S系列】在 K8S 中使用 Values 文件定制不同环境下的应用配置
云原生·容器·kubernetes·环境配置
旦沐已成舟1 小时前
K8S-Pod的环境变量,重启策略,数据持久化,资源限制
java·docker·kubernetes
github_czy1 小时前
(k8s)k8s部署mysql与redis(无坑版)
redis·容器·kubernetes
超级阿飞1 小时前
利用Kubespray安装生产环境的k8s集群-实施篇
elasticsearch·容器·kubernetes
代码讲故事3 小时前
从Windows通过XRDP远程访问和控制银河麒麟ukey v10服务器,以及多次连接后黑屏的问题
linux·运维·服务器·windows·远程连接·远程桌面·xrdp
milk_yan4 小时前
Docker集成onlyoffice实现预览功能
前端·笔记·docker
IT北辰6 小时前
Linux下 date时间应该与系统的 RTC(硬件时钟)同步
linux·运维·实时音视频
Shootingmemory6 小时前
自动化01
运维·自动化
苹果醋37 小时前
golang 编程规范 - Effective Go 中文
java·运维·spring boot·mysql·nginx
心灵Haven7 小时前
CentOS 7乱码问题如何解决?
linux·运维·centos