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"
相关推荐
xiaok14 小时前
GROUP BY进阶用法
mysql
李慕婉学姐14 小时前
【开题答辩过程】以《基于Android的健康助手APP的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
android·java·mysql
qq_124987075314 小时前
基于springboot健康养老APP的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·mysql·微信小程序·毕业设计
亚林瓜子15 小时前
mysql命令行手动导入csv数据到指定表
数据库·mysql·gui·csv·cli·db·import
杨浦老苏15 小时前
安全共享敏感信息的共享工具Hemmelig.app
docker·群晖·密码·阅后即焚
眠りたいです15 小时前
Docker:容器虚拟化技术基础-namespace,cgroups,资源管理与LXC
运维·docker·中间件·容器
一分半心动15 小时前
lnmp架构 mysql数据库Cannot assign requested address报错解决
linux·mysql·php
ChristXlx16 小时前
Linux安装mysql(虚拟机适用)
linux·mysql
瀚高PG实验室16 小时前
timestampdiff (MYSQL)函数在Highgo DB中的写法
数据库·mysql·瀚高数据库
赵渝强老师17 小时前
【赵渝强老师】MongoDB的数据类型
数据库·mongodb·nosql