服务器摆设情况(docker安装Mysql + Redis + MongoDB)

农民  论坛元老 | 2024-7-30 01:30:47 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 1021|帖子 1021|积分 3063

1. 安装Docker

1、选择要安装的平台
   Docker要求CentOS系统的内核版本高于3.10
  1. uname -r #通过 uname -r 命令查看你当前的内核版本
复制代码

官网地点

2. 卸载已安装的Docker,

   利用Root权限登录 Centos。确保yum包更新到最新。
  1. sudo yum update
复制代码

   如果操纵系统没有安装过Docker , 就不需要执行卸载命令。
  1. sudo yum remove docker \
  2.                   docker-client \
  3.                   docker-client-latest \
  4.                   docker-common \
  5.                   docker-latest \
  6.                   docker-latest-logrotate \
  7.                   docker-logrotate \
  8.                   docker-engine
复制代码

3.创建仓库

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

安装最新版本

  1. sudo yum install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
复制代码


检察Docker是否成功及安装的具体版本号

  1. docker info
复制代码

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

  1. systemctl start docker.service
  2. systemctl enable docker.service
复制代码

测试 Docker 是否安装正常

  1. sudo docker run hello-world
复制代码
检察docker服务状态 running 就是启动成功

   systemctl status docker
  

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

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

   命令行
  1. sudo mkdir -p /etc/docker
  2. sudo tee /etc/docker/daemon.json <<-'EOF'
  3. {
  4.   "registry-mirrors": ["https://q0dw5726.mirror.aliyuncs.com"]
  5. }
  6. EOF
  7. sudo systemctl daemon-reload
  8. sudo systemctl restart docker
复制代码

4. Docker 安装 MySQL

   拉取镜像
查询有哪些 mySQL 镜像
  1. docker search mysql
复制代码

   通过以下命令拉取镜像:mysql 后面不加 latest 也是可以的,默认就是拉去最新版本。
  1. docker pull mysql:latest
复制代码
  创建容器
通过以下命令检察已下载的镜像
  1. docker images
复制代码

   mysql 就是刚刚下载的镜像
  ###通过以下命令创建并运行容器
  1. docker run -d \
  2. --name mysql \
  3. --restart=always \
  4. -p 3306:3306 \
  5. -e MYSQL_ROOT_PASSWORD=20240321 \
  6. mysql:latest
复制代码

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

通过以下命令进入容器

  1. docker exec -it 8dcff2228a5d  bash  //8dcff2228a5d 为容器的id,此处是我的容器id
复制代码
  登录MySQL:
  1. 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 表示拉取成功
  1. docker images
  2. -a
复制代码

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

修改文件中以下配置项:
  1. 1.将bind 127.0.0.1 -::1注释掉
  2. # bind 127.0.0.1 -::1
  3. 2.将 appendonly no 设置成yes,开启redis数据持久化
  4. appendonly yes  
  5. 3.将  requirepass foobared 解开注释,设置密码
  6. requirepass root
  7. 4.以下两项配置可选(如果不需要从外部连接,可不进行配置,以下配置有风险,请谨慎配置)
  8. 保护模式:如果设置为yes,那么只允许我们在本机的回环连接,其他机器无法连接,即外部无法连接,此处关闭
  9. protected-mode no
  10. 将bind 127.0.0.1注释掉,此项配置的作用是服务绑定监听本机的哪个ip
  11. # bind 127.0.0.1
复制代码
  修改完毕后的完备redis.conf文件如下:
  1. # bind 192.168.1.100 10.0.0.1
  2. # bind 127.0.0.1 ::1
  3. #bind 127.0.0.1
  4. protected-mode no
  5. port 6379
  6. tcp-backlog 511
  7. requirepass root
  8. timeout 0
  9. tcp-keepalive 300
  10. daemonize no
  11. supervised no
  12. pidfile /var/run/redis_6379.pid
  13. loglevel notice
  14. logfile ""
  15. databases 30
  16. always-show-logo yes
  17. save 900 1
  18. save 300 10
  19. save 60 10000
  20. stop-writes-on-bgsave-error yes
  21. rdbcompression yes
  22. rdbchecksum yes
  23. dbfilename dump.rdb
  24. dir ./
  25. replica-serve-stale-data yes
  26. replica-read-only yes
  27. repl-diskless-sync no
  28. repl-disable-tcp-nodelay no
  29. replica-priority 100
  30. lazyfree-lazy-eviction no
  31. lazyfree-lazy-expire no
  32. lazyfree-lazy-server-del no
  33. replica-lazy-flush no
  34. appendonly yes
  35. appendfilename "appendonly.aof"
  36. no-appendfsync-on-rewrite no
  37. auto-aof-rewrite-percentage 100
  38. auto-aof-rewrite-min-size 64mb
  39. aof-load-truncated yes
  40. aof-use-rdb-preamble yes
  41. lua-time-limit 5000
  42. slowlog-max-len 128
  43. notify-keyspace-events ""
  44. hash-max-ziplist-entries 512
  45. hash-max-ziplist-value 64
  46. list-max-ziplist-size -2
  47. list-compress-depth 0
  48. set-max-intset-entries 512
  49. zset-max-ziplist-entries 128
  50. zset-max-ziplist-value 64
  51. hll-sparse-max-bytes 3000
  52. stream-node-max-bytes 4096
  53. stream-node-max-entries 100
  54. activerehashing yes
  55. hz 10
  56. dynamic-hz yes
  57. aof-rewrite-incremental-fsync yes
  58. rdb-save-incremental-fsync yes
复制代码
  在linux服务器中新建/home/redis/目录,将redis.conf文件上传至该目录
  利用如下命令运行redis容器:
  1. 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文件上传至该目录
  1. 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
复制代码
  检察是否运行成功
  1. docker ps
复制代码
  1. docker exec -it myredis redis-cli
  2. 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
  1. docker run  --restart=always -p 6379:6379 --name redis \
  2. -v /data/redis/conf/redis.conf:/etc/redis/redis.conf \
  3. -v /data/redis/data:/data \
  4. -d redis:latest redis-server /etc/redis/redis.conf
复制代码
6.1 docker 拉取mysql镜像

  1. docker pull mongo:latest
复制代码
6.2 运行容器

  1. docker run -itd --name mongo -p 27017:27017 mongo --auth
  2. 参数说明:
  3. -p 27017:27017 :映射容器服务的 27017 端口到宿主机的 27017 端口。外部可以直接通过 宿主机 ip:27017 访问到 mongo 的服务。
  4. --auth:需要密码才能访问容器服务。
复制代码
6.3 创建用户并设置密码

  1. docker exec -it mongo mongo admin(5.0版本以上连接mongo使用命令mongosh)
  2. 创建一个名为 admin,密码为 123456 的用户。
  3. db.createUser({ user:'admin',pwd:'XXXXXX',roles:[ { role:'userAdminAnyDatabase', db: 'admin'},"readWriteAnyDatabase"]});
  4. 尝试使用上面创建的用户信息进行连接。
  5. 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数据库中可用。超等账号,超等权限
    正在利用的版本命令:
  1. docker run -dit --name mongo -p 27017:27017 mongo:latest --auth
  2. -p 27017:27017 :映射容器服务的 27017 端口到宿主机的 27017 端口。外部可以直接通过 宿主机 ip:27017 访问到 mongo 的服务。
  3. --auth:需要密码才能访问容器服务。
  4. docker exec -it mongo mongosh admin // (5.0版本以上连接mongo使用命令mongosh)
  5. 创建一个名为 admin,密码为 123456 的用户。
  6. db.createUser({ user:'admin',pwd:'20004321',roles:[ { role:'userAdminAnyDatabase', db: 'admin'},"readWriteAnyDatabase"]});
  7. 尝试使用上面创建的用户信息进行连接。
  8. db.auth('admin', '20004321');
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

农民

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表