前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >告诉你最简单的方式搭建MySQL、Redis、MongoDB数据库

告诉你最简单的方式搭建MySQL、Redis、MongoDB数据库

作者头像
星星在线
发布2019-07-17 20:21:56
1.5K0
发布2019-07-17 20:21:56
举报

数据库在我们日常开发中接触是很多的,平时自己没事写一些东西也经常会用到,之前专门写过安装MySQL、Redis、MongoDB的文章,各种安装配置还是比较麻烦的,为了记下安装步骤方便后期再安装。现在发现其实docker有现成的,几条命令就能搭建一个数据库出来,方便至极,简单记录一下,方便大家使用。

安装MySQL 5.7

因为8.0的改动比较大,密码验证等需要修改,所以就使用MySQL5.7

下载镜像

docker pull mysql:5.7

启动容器

docker run --name mysql -p 3306:3306 --restart=always -e MYSQL_ROOT_PASSWORD=root -v /var/lib/mysql/:/var/lib/mysql/ -d mysql:5.7 --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci

  • -p:映射本地端口3306
  • --restart:
  • --restart具体参数值详细信息:
    • no - 容器退出时,不重启容器;
    • on-failure - 只有在非0状态退出时才从新启动容器;
    • always - 无论退出状态是如何,都重启容器;
  • MYSQL_ROOT_PASSWORD:设置root密码为root
  • --character-set-server/--collation-server=utf8mb4_unicode_ci:设置默认数据库编码为utf8mb4,默认排序规则为utf8mb4_unicode_ci
  • -v:挂载本地目录 /var/lib/mysql:/var/lib/mysql:映射数据目录到宿主,防止容器重启后数据丢失 /var/mysql/conf:/etc/mysql/conf.d:MySQL配置目录,修改容器中配置(这里启动后,远程就可以访问,所以就不配置了)

PS: -v绑定的目录要新建或者清空

安装Redis

下载镜像

docker pull redis:latest

下载配置文件

将https://raw.githubusercontent.com/antirez/redis/4.0/redis.conf配置文件下载到本地

启动容器

docker run -p 6379:6379 --restart=always -v $PWD/data:/data -v $PWD/conf/redis.conf:/etc/redis/redis.conf --privileged=true --name myredis -d redis redis-server /etc/redis/redis.conf

  • --privileged:配置权限
  • redis-server:启动redis服务命令

启动容器:番外

除了以上方式,我们还可以使用Dockerfile的方式来创建和启动容器

  • 创建Dockerfile文件
FROM redis
COPY redis.conf /etc/redis/redis.conf
CMD [ "redis-server", "/etc/redis/redis.conf" ]

要在redis.conf文件所在目录下创建

  • 生成镜像 docker build -t redis:v1.0 . 最后的.表示使用当前目录下的Dockerfile文件(redis:v1.0===镜像名:版本)

启动容器命令有些改变 docker run -p 6379:6379 --restart=always -v $PWD/data:/data --privileged=true --name myredis -d myredis

安装MongoDB

下载镜像

docker pull mongo docker pull mongo-express 可选,可视化web服务器

启动容器

docker run --name mymongo -p 27017:27017 -v $PWD/data:/data/db -d mongo

启动web访问容器

docker run --link mymongo:mongo -p 8081:8081 mongo-express

扩展

上面有两个容器配合使用,一个是MongoDB容器,一个是提供了可视化网页访问的容器,我们可以使用docker-compose将两个容器配置在yml中,这样每次启动就可以同步启动,不需要手动去分别启动了 stack.yml

version: '3.1'
services:
    mongo:
      image: mongo:latest
      ports:
        - 27017:27017
      volumes:
        - ./data:/data/db

    mongo-express:
      links:
        - mongo
      image: mongo-express
      ports:
        - 8081:8081

docker-compose -f stack.yml up

docker命令

查看绑定目录

docker inspect 容器ID

"Mounts": [
    {
        "Type": "bind",
        "Source": "/home/mysql",
        "Destination": "/var/lib/mysql",
        "Mode": "",
        "RW": true,
        "Propagation": "rprivate"
      }
 ],

Source:本地目录 Destination:容器内目录(一般默认都是这个目录,无需修改)

查看容器IP

docker inspect --format='{{.NetworkSettings.IPAddress}}' 容器ID

查看容器绑定端口

docker port 容器ID

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-07-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 python爬虫实战之路 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 安装MySQL 5.7
    • 下载镜像
      • 启动容器
      • 安装Redis
        • 下载镜像
          • 下载配置文件
            • 启动容器
              • 启动容器:番外
              • 安装MongoDB
                • 下载镜像
                  • 启动容器
                    • 启动web访问容器
                      • 扩展
                      • docker命令
                        • 查看绑定目录
                          • 查看容器IP
                            • 查看容器绑定端口
                            相关产品与服务
                            容器服务
                            腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
                            领券
                            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档