环境信息

Docker是什么?

Docker就是一个平台,这个平台具备开发、发布和运行应用程序的功能,在项目生命周期中,我们可以运用Docker实现快速交付、测试和部署。Docker通过将运行环境打包成一个镜像,就可以在安装了Docker的任意平台上运行(一次构建,到处运行)。

安装Docker

  1. centos版本推荐7以上,centos6安装docker比较麻烦。如果以前安装过docker,需要先清理:

    sudo yum remove docker \
    docker-client \
    docker-client-latest \
    docker-common \
    docker-latest \
    docker-latest-logrotate \
    docker-logrotate \
    docker-engine
  2. 安装docker需要的工具包

    sudo yum install -y yum-utils

    如果提示下图内容:



    这是由于当前系统没有 CentOS-Base.repo 文件,使用命令重新下载一个:

    curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
  3. 添加yum源

    sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
  4. 安装docker

    // 中途需要输入y进行确认
    sudo yum install docker-ce docker-ce-cli containerd.io
  5. 配置镜像加速地址(阿里云)

    5.1 首先登录阿里云控制台,选择容器镜像服务



    5.2 复制命令并执行

  6. 配置docker自启

    systemctl enable docker

安装mysql

mysql的容器我们可以让docker创建和执行,但是mysql的数据不能仅存在容器内,需要我们开辟一个外部路径专门用来存储mysql数据。

  1. 安装mysql

    docker run -p 3306:3306 --name mysql -v /mydata/mysql/log:/var/log/mysql -v /mydata/mysql/data:/var/lib/mysql -v /mydata/mysql/conf:/etc/mysql -e MYSQL_ROOT_PASSWORD=root -d mysql:5.7
    简单讲解一下,
    -p 3306:3306:将容器的3306端口映射到主机的3306端口
    -v 源地址(宿主机):目标地址(容器),将主机的/mydata/mysql/log挂载到mysql容器的/var/log/mysql目录
    -e 指定容器内的环境变量,这里是指定mysql密码为root
    -d 后台运行容器,并返回容器ID
    mysql:5.7 指定mysql版本,具体版本可以在https://hub.docker.com 查询
  2. 验证mysql是否安装成功

    docker ps

    如下,如果显示了mysql就是安装成功了

  3. 开启mysql远程访问权限:

    先进入mysql容器
    docker exec -it mysql /bin/bash
    登录mysql,密码就是我们初始化时设置的root
    mysql -uroot -p
    然后开始开启远程访问权限
    use mysql;
    select host,user from user;



    查看host不是%,需要先更新成%(如果是%跳过,直接进行下面的授权):

    update user set host = '%' where user = 'root';

    然后开始授权

    // 此句会开启root的远程访问权限,实际根据场景应该开一个权限小的账号
    GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;
    // 刷新权限
    flush privileges;
  4. 上面对mysql本身开启了远程访问权限,下面需要配置防火墙,阿里云还需要在控制台配置安全组开放3306端口。

    # 如果firewalld 没有开启,先开启下
    service firewalld start
    #开放3306端口
    firewall-cmd --permanent --add-port=3306/tcp;
    #重启防火墙(修改配置后要重启防火墙)
    firewall-cmd --reload

    最后配置mysql自启:

    docker update --restart=always mysql

    此时使用navicat 可以访问MySQL了

安装redis

  1. 首先创建redis数据存放目录和配置文件

    mkdir -p /mydata/redis/conf
    touch /mydata/redis/conf/redis.conf
    // 编辑配置文件,开启持久化
    vi /mydata/redis/conf/redis.conf
    // 配置文件中加入下面的命令
    appendonly yes
  2. 安装redis

    docker run -p 6379:6379 --name redis -v /mydata/redis/data:/data -v /mydata/redis/conf/redis.conf:/etc/redis/redis.conf -d redis redis-server /etc/redis/redis.conf --requirepass "123456"
    
     简单讲解一下,
    -p 6379:6379:将容器的6379端口映射到主机的6379端口
    -v /mydata/redis/data:/data,将主机的/mydata/redis/data挂载到redis容器的/data目录
    -v /mydata/redis/conf/redis.conf:/etc/redis/redis.conf,将主机的redis.conf文件替换容器的redis.conf文件,这样我们可以在主机上对redis进行配置
    redis-server /etc/redis/redis.conf,通过redis.conf运行redis
    --requirepass "123456",设置密码为123456

    添加防火墙规则开启redis远程访问(阿里云还需要配置安全组开放6379端口):

    #开放6379端口
    firewall-cmd --permanent --add-port=6379/tcp;
    #重启防火墙(修改配置后要重启防火墙)
    firewall-cmd --reload

    配置redis自启:

    docker update --restart=always redis

Centos7.2 安装docker、mysql和redis的更多相关文章

  1. Centos7上安装docker (转)

    Centos7上安装docker Docker从1.13版本之后采用时间线的方式作为版本号,分为社区版CE和企业版EE. 社区版是免费提供给个人开发者和小型团体使用的,企业版会提供额外的收费服务,比如 ...

  2. docker(一) Centos7下安装docker

    docker(一) Centos7下安装dockerdocker(二) windows10下安装dockerdocker(三) 镜像和容器常用命令 docker(四) 使用Dockerfile构建镜像 ...

  3. CentOS7下安装docker(Docker系列1)

    CentOS7下安装docker 系统要求 为了安装docker,需要准备 64-bit的CentOS 7 删除非官方的Docker包 yum的仓库中有一个很旧的Docker包, 现在Docker官方 ...

  4. centos7上安装docker社区版

    container(容器) docker(集装箱) 容器的优点 1. 启动速度快 2. 节省资源 3. 兼容性高 保证机器正常上网 #ping www.baidu.com CPU需要支持虚拟化 # g ...

  5. centos7下安装docker与镜像加速

    1.背景 centos7下安装docker 2.安装 第一步:检查是否为centos7版本 第二步:依赖环境安装 执行如下两个命令: yum -y install gcc yum -y install ...

  6. 在Centos7中安装Docker并实例化Mysql

    首先 本文是一篇安装流程,从初始的Centos7安装Docker后实例化一个Mysql的整个流程,其中会包含一些需要注意的疑点和坑. 实例化的Mysql是将数据和配置保存在宿主机. 注意,在安装Doc ...

  7. centos7.0安装docker报错

    使用centos7.0安装dockers时出现Transaction check error错误. yum install docker Transaction check error: file / ...

  8. Linux(centos7)下安装Docker

    近期公司开始推Docker技术.这个系列的文章都是基于CentOS7系统下进行讲解的. Docker简介 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器 ...

  9. Centos7快速安装docker

    偶然间发现,docker的安装好容易啊 系统环境:centos7.3 yum源: docker:https://mirrors.aliyun.com/docker-ce/linux/centos/do ...

随机推荐

  1. 【USACO】Strolling Cows

    Strolling Cows 给定有 \(n\) 个点 \(n\) 条边的有向图,每个点的出度都为 \(1\),求图中的最大环. 显然入度为 \(0\) 的点不可能为最大环上的点,所以考虑删点. 然后 ...

  2. JS数组去重的9种方法(包括去重NaN和复杂数组类型)

    其实网上已经有很多js数组的去重方法,但是我看了很多篇并自己通过代码验证,发现都有一些缺陷,于是在研究多篇代码之后,自己总结了9种方法,如果有哪里不对请及时纠正我哈~ 转载请表明出处 测试代码 let ...

  3. tensorflow的广播机制

    TensorFlow支持广播机制(Broadcast) TensorFlow支持广播机制(Broadcast),可以广播元素间操作(elementwise operations).正常情况下,当你想要 ...

  4. sendfile zero-copy

    传统read/write进行网络文件传输过程当中,文件数据实际上经过四次copy操作: 硬盘->内核buf->用户buf->socket相关缓冲区->协议引擎 而sendfil ...

  5. 也谈模块加载,吐槽CMD

    先吐槽CMD,不要没头没脑的搞出个CMD,没意思. 大家都看AMD好了,异步模块加载机制,CMD并没有改变这个模式. 模块加载的关口就是getCurrentScript,每次define被调用的时候, ...

  6. gcc入门(下)

    一 头文件与库文件(模块化,可重用,好维护)在使用C语言和其他语言进行程序设计的时候,我们需要头文件来提供对常数的定义和对系统以及库函数调用的声明库文件是一些预先编译好的函数的集合,那些函数都是按照可 ...

  7. CSS 常用列表样式

    CSS 常用列表样式 CSS没学扎实,复习记录一下.下面是一些常用的属性 list-style-image 指定一个图片作为列表项的标记 默认值none,可设置为图片的url list-style-i ...

  8. Linux(CentOS6.8)配置Docker

    Centos6.8 1.查看自己的内核 [1].uname [root@host79 ~]# uname -r 2.6.32-642.el6.x86_64 [2].查看CentOS版本信息 CentO ...

  9. K8S环境的Jenkin性能问题描述

    Return Homezq2599 CnBlogsHomeContactAdminPosts - 75 Articles - 0 Comments - 16 K8S环境的Jenkin性能问题处理 环境 ...

  10. ASP.NET Core使用HostingStartup增强启动操作

    概念 在ASP.NET Core中我们可以使用一种机制来增强启动时的操作,它就是HostingStartup.如何叫"增强"操作,相信了解过AOP概念的同学应该都非常的熟悉.我们常 ...