Docker运行 Redis、Mysql、Nginx、MongoDB、Minio等

Redis

挂载文件,自行选择

wget http://download.redis.io/redis-stable/redis.conf

创建对应的文件

bash 复制代码
mkdir -p /docker/redis/data 
mkdir -p /docker/redis/conf
touch /docker/redis/conf/redis.conf # redis.conf什么的都不能是空

docker pull redis:6.0.8

docker run --name mr \
-p 6379:6379 \
-v /docker/redis/conf/redis.conf:/etc/redis/redis.conf \
--privileged=true -d redis:6.0.8 \
redis-server /etc/redis/redis.conf \
--appendonly yes
MySql
bash 复制代码
docker pull mysql:5.7 
#下面对应文件目录要有
docker run --name mysql \
 -e MYSQL_ROOT_PASSWORD=1320444219wx \
 -p 3306:3306 \
 -v /docker/mysql/conf/hmy.cnf:/etc/mysql/conf.d/hmy.cnf \
 -v /docker/mysql/data:/var/lib/mysql \
 -d  \
 mysql:5.7
Nginx
bash 复制代码
#拉取镜像
docker pull nginx:1.21.6

# 先运行一个实例
docker run --name mn -p 80:80 -d nginx:1.21.6

# 创建挂载目录
mkdir -p /docker/nginx/conf /docker/nginx/log /docker/nginx/html

# 将容器nginx.conf文件复制到宿主机
docker cp mn:/etc/nginx/nginx.conf /docker/nginx/conf/nginx.conf


# 将容器conf.d文件夹下内容复制到宿主机
docker cp mn:/etc/nginx/conf.d /docker/nginx/conf/conf.d


# 将容器中的html文件夹复制到宿主机
docker cp mn:/usr/share/nginx/html /docker/nginx/html 

#删除正在运行的nginx容器

docker rm -f mn

#再次运行一个新的容器进行挂载

docker run \
-p 80:80 \
--name mn \
-v /docker/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /docker/nginx/html:/usr/share/nginx/html \
-v /docker/nginx/conf/conf.d:/etc/nginx/conf.d \
-d nginx:1.21.6
MongoDB
  1. 拉取镜像:docker pull mongo:latest

  2. 运行一个容器:docker run -itd --name mongo -p 27017:27017 mongo --auth

  3. 进入容器修改配置信息

bash 复制代码
docker exec -it mongo mongosh admin
# 创建一个名为 admin,密码为 wangxing 的用户。
db.createUser({ user:'root',pwd:'root',roles:[ { role:'userAdminAnyDatabase', db: 'admin'},"readWriteAnyDatabase"]});
# 尝试使用上面创建的用户信息进行连接。
db.auth('root', 'wangxing')
Minio
  1. 拉镜像docker pull minio/minio

  2. 运行

bash 复制代码
docker run  -p 9000:9000 -p 9090:9090 --name minio \
 -d --restart=always \
 -e MINIO_ACCESS_KEY=123456\
 -e MINIO_SECRET_KEY=123456\
 -v /docker/minio/data:/data \
 -v /docker/minio/config:/root/.minio \
  minio/minio server /data  --console-address ":9090" --address ":9000"
相关推荐
_运维那些事儿20 小时前
VM环境的CI/CD
linux·运维·网络·阿里云·ci/cd·docker·云计算
·云扬·21 小时前
MySQL Binlog落盘机制深度解析:性能与安全性的平衡艺术
android·mysql·adb
霖霖总总21 小时前
[小技巧64]深入解析 MySQL InnoDB 的 Checkpoint 机制:原理、类型与调优
数据库·mysql
ALex_zry21 小时前
Redis Cluster 分布式缓存架构设计与实践
redis·分布式·缓存
それども1 天前
分库分表的事务问题 - 怎么实现事务
java·数据库·mysql
·云扬·1 天前
MySQL Binlog 配置指南与核心作用解析
数据库·mysql·adb
天空属于哈夫克31 天前
Java 版:利用外部群 API 实现自动“技术开课”倒计时提醒
数据库·python·mysql
lpruoyu1 天前
【Docker进阶-05】Docker网络
网络·docker·容器
luoluoal1 天前
基于深度学习的web端多格式纠错系统(源码+文档)
python·mysql·django·毕业设计·源码
乔江seven1 天前
【Flask 进阶】3 从同步到异步:基于 Redis 任务队列解决 API 高并发与长耗时任务阻塞
redis·python·flask