首页 > 数据库 >服务器部署环境(docker安装Mysql + Redis + MongoDB)

服务器部署环境(docker安装Mysql + Redis + MongoDB)

时间:2024-07-24 09:29:15浏览次数:17  
标签:-- MongoDB redis admin conf Mysql docker yes Redis

1. 安装Docker

1、选择要安装的平台

Docker要求CentOS系统的内核版本高于3.10

uname -r #通过 uname -r 命令查看你当前的内核版本

在这里插入图片描述

官网地址
在这里插入图片描述在这里插入图片描述

2. 卸载已安装的Docker,

使用Root权限登录 Centos。确保yum包更新到最新。

sudo yum update

在这里插入图片描述

如果操作系统没有安装过Docker , 就不需要执行卸载命令。

 sudo yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine

在这里插入图片描述

3.建立仓库

## 安装Docker所需要的一些工具包
sudo yum install -y yum-utils
 
## 建立Docker仓库 (映射仓库地址)
sudo yum-config-manager \
    --add-repo \
    https://download.docker.com/linux/centos/docker-ce.repo

在这里插入图片描述

安装最新版本

sudo yum install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin

在这里插入图片描述
在这里插入图片描述

查看Docker是否成功及安装的具体版本号

docker info

在这里插入图片描述

启动docker服务(并开机自启)

systemctl start docker.service
systemctl enable docker.service

在这里插入图片描述

测试 Docker 是否安装正常

sudo docker run hello-world

查看docker服务状态 running 就是启动成功

systemctl status docker

在这里插入图片描述

使用docker镜像(阿里云加速器)

 也可使用中国科学技术大学的镜像: "registry-mirrors": ["https://docker.mirrors.ustc.edu.cn"]

在这里插入图片描述

命令行

sudo mkdir -p /etc/docker

sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://q0dw5726.mirror.aliyuncs.com"]
}
EOF

sudo systemctl daemon-reload

sudo systemctl restart docker

在这里插入图片描述

4. Docker 安装 MySQL

拉取镜像
查询有哪些 mySQL 镜像

docker search mysql

在这里插入图片描述

通过以下命令拉取镜像:mysql 后面不加 latest 也是可以的,默认就是拉去最新版本。

docker pull mysql:latest

创建容器
通过以下命令查看已下载的镜像

docker images

在这里插入图片描述

mysql 就是刚刚下载的镜像

###通过以下命令创建并运行容器

docker run -d \
--name mysql \
--restart=always \
-p 3306:3306 \
-e MYSQL_ROOT_PASSWORD=20240321 \
mysql:latest

在这里插入图片描述

解释:
-d : 后台运行
-p:端口映射 本机的端口:docker中的端口
–name :容器起别名
–restart:docker启动的时候随之启动
-e MYSQL_ROOT_PASSWORD :设置mysql的root用户的密码

查看容器
在这里插入图片描述

通过以下命令进入容器

docker exec -it 8dcff2228a5d  bash  //8dcff2228a5d 为容器的id,此处是我的容器id

登录MySQL:

mysql -u root -p

在这里插入图片描述

可以远程连接一下测试是否可以用

5. docker 安装 Redis

docker 镜像库
Docker如果想安装软件 , 必须先到 Docker 镜像仓库下载镜像。

命令描述
docker pull redis下载最新版Redis镜像 (其实此命令就等同于 : docker pull redis:latest )
docker pull redis:xxx下载指定版本的Redis镜像 (xxx指具体版本号)
docker search redis查看
exit退出

在这里插入图片描述在这里插入图片描述

查看是否拉取成功;出现 Redis 表示拉取成功

docker images -a

在这里插入图片描述

去redis官网下载redis,然后在redis-7.0.0\redis-7.0.0找到redis.conf文件官网链接

修改文件中以下配置项:

1.将bind 127.0.0.1 -::1注释掉
# bind 127.0.0.1 -::1
2.将 appendonly no 设置成yes,开启redis数据持久化 
 appendonly yes  
3.将  requirepass foobared 解开注释,设置密码
 requirepass root
4.以下两项配置可选(如果不需要从外部连接,可不进行配置,以下配置有风险,请谨慎配置)
保护模式:如果设置为yes,那么只允许我们在本机的回环连接,其他机器无法连接,即外部无法连接,此处关闭
protected-mode no 
将bind 127.0.0.1注释掉,此项配置的作用是服务绑定监听本机的哪个ip
# bind 127.0.0.1

修改完毕后的完整redis.conf文件如下:

# bind 192.168.1.100 10.0.0.1
# bind 127.0.0.1 ::1
#bind 127.0.0.1

protected-mode no

port 6379

tcp-backlog 511

requirepass root

timeout 0

tcp-keepalive 300

daemonize no

supervised no

pidfile /var/run/redis_6379.pid

loglevel notice

logfile ""

databases 30

always-show-logo yes

save 900 1
save 300 10
save 60 10000

stop-writes-on-bgsave-error yes

rdbcompression yes

rdbchecksum yes

dbfilename dump.rdb

dir ./

replica-serve-stale-data yes

replica-read-only yes

repl-diskless-sync no

repl-disable-tcp-nodelay no

replica-priority 100

lazyfree-lazy-eviction no
lazyfree-lazy-expire no
lazyfree-lazy-server-del no
replica-lazy-flush no

appendonly yes

appendfilename "appendonly.aof"

no-appendfsync-on-rewrite no

auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb

aof-load-truncated yes

aof-use-rdb-preamble yes

lua-time-limit 5000

slowlog-max-len 128

notify-keyspace-events ""

hash-max-ziplist-entries 512
hash-max-ziplist-value 64

list-max-ziplist-size -2

list-compress-depth 0

set-max-intset-entries 512

zset-max-ziplist-entries 128
zset-max-ziplist-value 64

hll-sparse-max-bytes 3000

stream-node-max-bytes 4096
stream-node-max-entries 100

activerehashing yes

hz 10

dynamic-hz yes

aof-rewrite-incremental-fsync yes

rdb-save-incremental-fsync yes




在linux服务器中新建/home/redis/目录,将redis.conf文件上传至该目录

使用如下命令运行redis容器:

docker run  -p 6379:6379 --name myredis -v /home/redis/redis.conf:/etc/redis/redis.conf -v /home/redis/data:/data -d redis redis-server /etc/redis/redis.conf    --requirepass "root"

或者

在linux服务器中新建docker-software/redis目录,将redis.conf文件上传至该目录

docker run --restart=always --log-opt max-size=1024m --log-opt max-file=2 -p 6379:6379 --name redis -v /docker-software/redis/conf/redis.conf:/etc/redis/redis.conf  -v /docker-software/redis/data:/data -d redis redis-server /etc/redis/redis.conf --appendonly yes --requirepass redis123456

查看是否运行成功

docker ps
 docker exec -it myredis redis-cli
docker run -d --name redis -p 6379:6379 --restart unless-stopped -v /home/redis/data:/data -v /home/redis/conf/redis.conf:/etc/redis/redis.conf redis-server /etc/redis/redis.conf redis:bullseye

正在使用的方案:
在根目录下创建文件夹data

docker run  --restart=always -p 6379:6379 --name redis \
-v /data/redis/conf/redis.conf:/etc/redis/redis.conf \
-v /data/redis/data:/data \
-d redis:latest redis-server /etc/redis/redis.conf

6.1 docker 拉取mysql镜像

docker pull mongo:latest

6.2 运行容器

docker run -itd --name mongo -p 27017:27017 mongo --auth
参数说明:
-p 27017:27017 :映射容器服务的 27017 端口到宿主机的 27017 端口。外部可以直接通过 宿主机 ip:27017 访问到 mongo 的服务。
--auth:需要密码才能访问容器服务。

6.3 创建用户并设置密码

docker exec -it mongo mongo admin(5.0版本以上连接mongo使用命令mongosh)
创建一个名为 admin,密码为 123456 的用户。
db.createUser({ user:'admin',pwd:'XXXXXX',roles:[ { role:'userAdminAnyDatabase', db: 'admin'},"readWriteAnyDatabase"]});
尝试使用上面创建的用户信息进行连接。
db.auth('admin', 'XXXXXX');

4.注释

权限 说明 read 允许用户读取指定数据库 readWrite 允许用户读写指定数据库
dbAdmin 允许用户在指定数据库中执行管理函数,如索引创建、删除,查看统计或访问system.profile
userAdmin 允许用户向system.users集合写入,可以在指定数据库里创建、删除和管理用户
clusterAdmin 只在admin数据库中可用,赋予用户所有分片和复制集相关函数的管理权限
readAnyDatabase 只在admin数据库中可用,赋予用户所有数据库的读权限
readWriteAnyDatabase 只在admin数据库中可用,赋予用户所有数据库的读写权限
userAdminAnyDatabase 只在admin数据库中可用,赋予用户所有数据库的userAdmin权限
dbAdminAnyDatabase 只在admin数据库中可用,赋予用户所有数据库的dbAdmin权限
root 只在admin数据库中可用。超级账号,超级权限

正在使用的版本命令:

docker run -dit --name mongo -p 27017:27017 mongo:latest --auth


-p 27017:27017 :映射容器服务的 27017 端口到宿主机的 27017 端口。外部可以直接通过 宿主机 ip:27017 访问到 mongo 的服务。
--auth:需要密码才能访问容器服务。

docker exec -it mongo mongosh admin // (5.0版本以上连接mongo使用命令mongosh)

创建一个名为 admin,密码为 123456 的用户。
db.createUser({ user:'admin',pwd:'20004321',roles:[ { role:'userAdminAnyDatabase', db: 'admin'},"readWriteAnyDatabase"]});
尝试使用上面创建的用户信息进行连接。
db.auth('admin', '20004321');

标签:--,MongoDB,redis,admin,conf,Mysql,docker,yes,Redis
From: https://blog.csdn.net/qq_46703281/article/details/134539927

相关文章

  • 用于自动访问 MongoDB Atlas CLI 的 Python 脚本
    我想编写一个Python脚本,以便普通用户可以访问他的数据库并从他的终端执行CRUD操作。我正在查看官方文档,但我有点迷失。有人可以给我指点基本教程来开始吗?当然,以下是如何构建Python脚本来访问MongoDBAtlasCLI的基本教程:先决条件:MongoDBAtlas......
  • redis原理之底层数据结构-跳表
    1.什么是跳表1.1链表及其不足链表是在程序设计中最常见的数据结构之一,它通过指针将多个链表节点连接起来,这样就可以将逻辑上同一类的数据存储到不连续的内存空间上。链表结构如下:但是链表有一个问题,就是当链表需要查询一个元素的时候,需要从链表头部开始遍历,时间复杂度为o(......
  • MySQL---------存储过程
    存储过程●介绍:存储过程是事先经过编译并存储在数据库中的一段SQL语句的集合,调用存储过程可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的效率是有好处的。存储过程思想上很简单,就是数据库SQL语言层面的代码封装与复用......
  • redis的使用场景和持久化方式
    redis的使用场景热点数据的缓存。热点:频繁读取的数据。限时任务的操作:短信验证码。完成session共享的问题完成分布式锁。redis的持久化方式什么是持久化:把内存中的数据存储到磁盘的过程,同时也可以把磁盘中的数据加载到内存中。redis持久化分为两种:RDB和AOFRDB:什......
  • redis的集群模式
    为什么使用redis提高并发性和可用性提供了三种集群模式:第一种:主从模式概念:redis主从模式表示一个主节点跟若干个从节点。主节点负责读和写操作,而从节点只负责读操作,主节点的数据会自动同步到从节点上。如何搭建操作模式结构图为了操作方便可以在一台Linux上运行......
  • 记录下Visual Studio 2022配置mysql
    visualstudio能够连接mysql只需要以下几步即可寻找mysql安装路径,如果你没有选择默认在C盘下ProgramFiles下mysql文件夹里,找到include和lib文件夹,分别复制路径。我们接下来来到visualstudio中,右键项目选择properties再将刚才复制的include跟lib的路径添加到Include......
  • Redis(REmote DIctionary Server)基础
    Redis(REmoteDIctionaryServer)基础Redis是一个开放源代码(BSD许可)的内存数据结构存储,用作数据库、缓存和消息代理。它支持字符串、哈希、列表、集合、带范围查询的排序集合、位图、超日志、带半径查询和流的地理空间索引等数据结构。Redis具有内置的复制、Lua脚本、LRU收回、......
  • Spring Boot 如何引入redis并实际运用
    1.增加依赖<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency>2.程序入口初始化Beanimportorg.springframework.w......
  • MySQL数据库-基础篇
    一、MySQL概述cmd中输入services.msc可进入到系统服务中启动服务netstartmysql80停止服务netstopmysql80客户端连接mysql[-h127.0.0.1][-p3306]-uroot-ppassword[]中内容可省略,默认连接本机3306端口,前提是配置了环境变量,cmd中即可连接数据模型......
  • Oracle 和 MySQL 介绍及适用场景
    Oracle和MySQL介绍及适用场景Oracle介绍OracleDatabase是甲骨文公司开发的一款关系数据库管理系统。Oracle数据库是目前市场上最流行的数据库之一,广泛应用于大型企业和复杂业务系统中。Oracle提供了全面的数据管理和分析功能,支持事务处理、大规模数据库管理、高并......