百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Docker安装及mysql、redis实战

wptr33 2025-01-13 18:26 23 浏览

1.Docker安装

  • 确定CentOS7及以上版本
  • cat /etc/redhat-release
  • 卸载旧版本
  • yum remove docker \
    docker-client \
    docker-client-latest \
    docker-common \
    docker-latest \
    docker-latest-logrotate \
    docker-logrotate \
    docker-engine
  • 安装gcc、gcc-c++
 yum -y install gcc gcc-c++
  • 安装所需要的依赖软件
  • yum install -y yum-utils
    yum-config-manager \
    --add-repo \
    http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
  • 重建yum索引
  • yum makecache fast
  • 安装docker引擎
  • yum install docker-ce docker-ce-cli containerd.io docker-compose-plugin
  • 启动docker
  • systemctl start docker
    # 使用命令查看
    ps -aux|grep docker
    # 或者使用docker version查看是否已经启动成功
  • 启动成功之后运行一个hello world镜像

2.卸载

 systemctl stop docker # 关闭docker进程
 yum remove docker-ce docker-ce-cli containerd.io 移除docker后台服务
 rm -rf /var/lib/docker # 删除容器
 rm -rf /var/lib/containerd # 删除镜像

3.添加镜像加速器

在阿里云中的镜像容器服务->镜像中心->镜像加速器中可设置加速地址

 您可以通过修改daemon配置文件/etc/docker/daemon.json来使用加速器
 mkdir -p /etc/docker
 tee /etc/docker/daemon.json <<-'EOF'
 {
   "registry-mirrors": ["https://yqzxad6m.mirror.aliyuncs.com"]
 }
 EOF
 systemctl daemon-reload
 systemctl restart docker

4.Docker常用命令

  • 帮助启动类命令
  • systemctl start docker # 启动docker后台服务
    systemctl
    stop docker # 停止docker后台服务
    systemctl
    restart docker # 重启docker后台服务
    systemctl status docker
    # 查看docker状态
    systemctl enable docker
    # 开机启动
    docker info
    # 查看docker概要信息
    docker 具体命令
    --help
  • 镜像命令
  • docker images # 列出本地主机上的镜像 -a 列出所有 -q只现实镜像id
    docker search 某个镜像的名字
    docker pull 某个镜像的名字:TAG
    # 如果不写TAG默认是latest最新版
    docker system df
    # 查看镜像/容器/数据卷占用空间
    docker rmi 某个镜像的id
    # 删除镜像 强制删除全部 docker rmi -f ${docker images -qa}
  • 注意:有的时候有一种镜像的仓库名和tag都是<None>的,称为虚悬镜像。这种镜像是需要被删除的,否则在构建时候会出问题
  • 容器命令
  • docker run [OPTION] IMAGE []
  • (1).OPTION指令详解
    • --name ‘’新容器的名子“ 为容器指定一个名称
      • -d 后台运行容器并返回容器id,也叫启动守护式容器(后台运行)[安装服务常用选项]
      • -i 以交互模式运行容器
      • -t 为容器重新分配一个伪终端
      • -P(大写的P)是随机分配端口号
      • -p(小写的p) 本机端口号:映射容器端口号
  • (2).退出容器
  • exit # 退出终端模式,容器会停止
    ctrl
    +p+q # 退出终端模式,容器不停止
  • (3).启动已停止的容器
  • docker start 容器ID或者容器名字
  • (4).重启容器
  • docker restart 容器ID或者容器名字
  • (5).停止已运行的容器
  • docker stop 容器ID或者容器名字
  • (6).强制停止容器
  • docker kill 容器ID或者容器名字
  • (7).删除已停止的容器
  • docker rm -f 容器ID
  • (8).查看某个容器日志
  • docker logs 容器ID
  • (9).查看容器内部的进程
  • docker top 容器ID
  • (10).查看容器内部细节
  • docker inspect 容器ID
  • (11).重新进入已启用的容器
  • # 第一种方式
    docker exec
    -it 容器ID /bin/bash

    # 第二种方式
    docker attach 容器ID
  • 区别:exec进入容器后使用exit退出不会导致容器停止;并且启用新的进程,而attach进入容器后使用exit退出容器会导致容器直接停止;不会启用新的进程;
  • (12).从容器备份数据到本地
    • 容器内部拷贝数据到本地
    • docker cp [-a] 容器ID:容器内部路径 目的主机路径
    • 导出整个docker容器出为tar包
    • docker export 容器ID > /root/abc.tar
  • (13).导入备份的docker
  • cat abc.tar |docker import - 镜像用户/镜像名:镜像版本号 # 镜像用户/镜像名:镜像版本号可以随便写
  • (14).将docker中的某个服务设为开机自启
  • docker update 容器ID(或者前几位) --restart=always
  • (15).docker如果想查看所有daocker中运行的cpu内存的信息可以使用以下命令
  • docker stats

5.Docker镜像

Docker镜像:实际上是一层一层的文件系统组成的,这种层级的文件系统UnionFS

 制作和提交镜像名
docker commit -m "提交的信息" -a="作者" 容器ID 要创建的目标镜像名:[标签名]

6.Docker私服搭建

下载镜像Docker Registry,这相当于是一个Docker hub私有的镜像仓库
docker pull registry # 拉取镜像

(2).运行docker Registry

docker run -d -p 5000:5000 -v 本地机器上的绝对路径:容器内部的映射绝对路径 --privileged=true registry

? (3).将新镜像修改成符合私服规范的tag

docker tag 镜像:tag Host:Port/Repostory:Tag

? (4).在传输之前先查看远程仓库中有哪些镜像

curl -XGET htt://192.168.1.2:5000/_catalog

7.查看数据卷是否映射成功

docker inspect 容器ID 

数据返回的部分数据如下

   "Mounts": [
               {
                   "Type": "bind",
                   "Source": "/tmp/abc", // 映射的宿主机目录(如果不存在会自动创建)
                   "Destination": "/tmp", // 容器中需要映射的目录
                   "Mode": "",
                   "RW": true,
                   "Propagation": "rprivate"
             }
           ]

8.使用容器的继承达到共享数据的目的

docker run -d --volumes-from 容器名 ...

--volumes-from 容器名 表示当前运行的容器继承某个容器,继承之后父容器的数据卷当前容器也有。也就是说父容器映射路径的挂在规则当前容器也具有

9.安装一般常用软件的步骤,如nginx\redis\mysql\rabbitmq\tomcat等遇到的一些坑

9.1.安装tomcat

新版的tomcat(10.0)需要将webapp删除,重新将webapps.dist命名为webapps在外面才可以访问这只猫

9.2.安装mysql

   # 简单安装
   docker run -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root -d mysql:5.7
   
   # 实战安装
   docker run -p 3306:3306 --privileged=true --name mysql5.7 \
   -v /tmp/mysql/log:/var/log/mysql \
   -v /tmp/mysql/data:/var/lib/mysql \
   -v /tmp/mysql/conf:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=root -d mysql:5.7

安装完成之后需要设置字符集

如果安装完成之后没有设置字符集,默认使用的是“latin1”,这样在插入字符串时就会因字符集的问题导致报错

   show variables like '%char%';
   +--------------------------+----------------------------+
   | Variable_name            | Value                      |
   +--------------------------+----------------------------+
   | character_set_client     | latin1                       |
   | character_set_connection | latin1                       |
   | character_set_database   | latin1                     |
   | character_set_filesystem | binary                     |
   | character_set_results    | utf8                       |
   | character_set_server     | latin1                     |
   | character_set_system     | utf8                       |
 | character_sets_dir       | /usr/share/mysql/charsets/ |
   +--------------------------+--

/tmp/mysql/conf/下创建一个my.cnf配置文件,添加如下参数:

   [client]
   default_character_set=utf8
   [mysqld]
 collation_server=utf8_general_ci
   character_set_server=utf8

改完之后重启mysql

   mysql> show variables like '%char%';
   +--------------------------+----------------------------+
   | Variable_name            | Value                      |
   +--------------------------+----------------------------+
   | character_set_client     | utf8                       |
   | character_set_connection | utf8                       |
   | character_set_database   | utf8                       |
   | character_set_filesystem | binary                     |
   | character_set_results    | utf8                       |
   | character_set_server     | utf8                       |
   | character_set_system     | utf8                       |
   | character_sets_dir       | /usr/share/mysql/charsets/ |
 +--------------------------+----------------------------+
   8 rows in set (0.00 sec)

9.3.安装redis

  • 安装redis命令
  • docker run -p 6379:6379 --name redis6.0.8 --privileged=true \
    -v /tmp/redis/redis.conf:/etc/redis/redis.conf \
    -v /tmp/redis/data:/data \
    -d redis:6.0.8 redis-server /etc/redis/redis.conf
  • 重新拷贝一份redis.conf文件到指定目录
    • 需要修改一下配置文件中的几处
      • 允许redis外地连接,需要注视掉 # bind 127.0.0.1
      • 将daemonize 的yes改为Daemonize no否则会和run -d 的参数有冲突。导致容器启动失败

相关推荐

MySQL进阶五之自动读写分离mysql-proxy

自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...

Postgres vs MySQL_vs2022连接mysql数据库

...

3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?

引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...

一文由浅入深带你完全掌握MySQL的锁机制原理与应用

本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...

验证Mysql中联合索引的最左匹配原则

后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...

MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)

目录1.索引基础...

你会看 MySQL 的执行计划(EXPLAIN)吗?

SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...

MySQL 从入门到精通(四)之索引结构

索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...

mysql总结——面试中最常问到的知识点

mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...

mysql总结——面试中最常问到的知识点(2)

首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...

MySQL基础全知全解!超详细无废话!轻松上手~

本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...

深入剖析 MySQL 中的锁机制原理_mysql 锁详解

在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...

Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析

引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...

MySQL基础篇:DQL数据查询操作_mysql 查

一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...

MySql:索引的基本使用_mysql索引的使用和原理

一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...