1. 安装docker
Docker 要求 CentOS 系统的内核版本高于 3.10 ,首先验证你的CentOS 版本是否支持 Docker 。
通过 uname -r 命令查看你当前的内核版本
yum -y install docker
- 启动 Docker 服务
systemctl start docker
- 设置开启启动
systemctl enable docker
4. 验证是否安装成功
docker version
2. docker常用命令
- 启动已停止运行的容器:docker start ID
- 停止容器:docker stop <容器 ID>
- 重启容器:docker restart ID
- 删除容器:docker rm -f <容器 ID>
- 进入容器:docker exec -it 应用名 bash
- 查看运行的容器状态:docker ps
- 查看所有容器状态(包括未运行的):docker ps -a
- docker cp e0d9c2a11847:/var/lib/mysql /usr/local/ 将docker里面的文件复制出来
- 在docker中安装vim
apt-get update
apt-get install vim
(说明:命令中的ID都可以用容器名称NAMES代替)
3. 安装mysql5.7并进行文件挂载
1. 拉取mysql镜像
docker pull mysql:5.7
2. 启动测试mysql,复制配置文件到宿主机(先启动测试mysql,目的是为了将配置文件复制出来)
docker run --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7
配置文件必须要宿主已经存在,才能正常启动,所以创建文件夹,然后复制配置文件出来
mkdir -p /opt/docker/mysql/conf
docker cp mysql:/etc/mysql/mysql.conf.d/mysqld.cnf /opt/docker/mysql/conf
(注意:mysql5.7的默认配置文件不是/etc/my.cnf也不是/etc/mysql/my.cnf,而是/etc/mysql/mysql.conf.d/mysqld.cnf)
3. 删除测试mysql,重新启动mysql,并挂载配置文件和data
删除测试mysql
docker rm -f mysql
重新启动mysql
docker run -d -p 3306:3306 --privileged=true --restart always -v /opt/docker/mysql/conf/mysqld.cnf:/etc/mysql/mysql.conf.d/mysqld.cnf -v /opt/docker/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql mysql:5.7 --character-set-server=utf8mb4 --collation-server=utf8mb4_general_ci
参数说明:
run:运行一个容器
-d:表示后台运行
-p:表示容器内部端口和服务器端口映射关联
--privileged=true:设值MySQL 的root用户权限, 否则外部不能使用root用户登陆
--restart always:设置开机启动
-v /opt/docker/mysql/conf/mysqld.cnf:/etc/mysql/mysql.conf.d/mysqld.cnf:将宿主机中的mysqld.cnf配置映射到docker中的/etc/mysql/mysql.conf.d/mysqld.cnf
-v /opt/docker/mysql/data:/var/lib/mysql:同上,映射数据库的数据目录, 避免以后docker删除重新运行MySQL容器时数据丢失
-e MYSQL_ROOT_PASSWORD=123456:设置MySQL数据库root用户的密码
--name mysql:设值容器名称为mysql
mysql:5.7:表示从docker镜像mysql:5.7中启动一个容器
--character-set-server=utf8mb4 --collation-server=utf8mb4_general_ci:设值数据库默认编码和默认排序规则
4. 安装redis并进行文件挂载
1. 拉取redis镜像
docker pull redis
2. 在宿主机中创建redis.conf配置文件
创建配置文件路径
mkdir -p /opt/docker/redis/conf
将配置文件放到该目录下,配置文件根据自己的版本,自行到官网下载。如何查看自己的redis版本:进入redis容器,执行redis-server -v即可。
3. 启动redis
docker run -d --privileged=true -p 6379:6379 --restart always -v /opt/docker/redis/conf/redis.conf:/etc/redis/redis.conf -v /opt/docker/redis/data:/data --name redis redis redis-server /etc/redis/redis.conf --appendonly yes --requirepass "123456"
-d:以守护进程的方式启动容器
-p:绑定宿主机端口
--name myredis: 指定容器名称
--restart always:开机启动
--privileged=true:提升容器内权限
-v /opt/docker/redis/conf/redis.conf:/etc/redis/redis.conf:映射配置文件
-v /opt/docker/redis/data:/data:映射数据目录
redis-server /etc/redis/redis.conf:在容器里执行redis-server命令,以挂载的配置文件启动
--appendonly yes:打开redis持久化
--requirepass:密码
4. 开启远程连接
此时我们的redis虽然启动成功了,但是远程还无法连接。此时将/opt/docker/redis/conf/redis.conf文件中的bind 127.0.0.1注释掉。
正好验证下挂载的配置文件是否生效。然后重启redis,重启之后,如果能够进行远程连接,则说明大功告成。
5.安装nginx并进行文件挂载
1. 拉取nginx镜像
docker pull nginx:latest
2. 启动测试nginx容器
docker run --name nginx -p 80:80 -d nginx
直接在浏览器输入宿主机的ip,出现如下界面,则说明启动成功
3. 复制配置文件到宿主机
先创建文件夹
mkdir -p /opt/docker/nginx/{conf,conf.d,html,log}
然后复制对应的配置文件到宿主机
docker cp nginx:/etc/nginx/nginx.conf /opt/docker/nginx/conf
docker cp nginx:/etc/nginx/conf.d/default.conf /opt/docker/nginx/conf.d
docker cp nginx:/usr/share/nginx/html /opt/docker/nginx
4. 启动nginx
先删除测试的nginx容器
docker rm -f mysql
重新启动nginx
docker run --name nginx -p 80:80 -v /opt/docker/nginx/html:/usr/share/nginx/html -v /opt/docker/nginx/conf/nginx.conf:/etc/nginx/nginx.conf -v /opt/docker/nginx/log:/var/log/nginx -v /opt/docker/nginx/conf.d/default.conf:/etc/nginx/conf.d/default.conf -d nginx
5. 部署项目
将打包好的前端项目放到/opt/docker/nginx/html,重启nginx即可。nginx配置文件具体细节这里就不讲了。
docker run -d -p 8080:8080 -e TZ="Asia/Shanghai" -v /etc/localtime:/etc/localtime:ro -v /opt/app/logs:/home/app/logs springboot
(启动的时候要指定容器时间和宿主时间一致,并挂载日志的路径)
- 【Docker】1、 前后端分离项目 下载启动运行
人人开源前后端分离项目下载与配置 文章目录 人人开源前后端分离项目下载与配置 前后端分离框架介绍 后端项目下载与配置 1.renren-fast后台项目介绍 2.开发环境搭建 3.下载后端renren ...
- 海纳百川无所不容,Win10环境下使用Docker容器式部署前后端分离项目Django+Vue.js
原文转载自「刘悦的技术博客」https://v3u.cn/a_id_179 随着现代化产品研发的不断推进,我们会发现,几乎每个产品线都会包含功能各异的服务,而且服务与服务之间存在也会存在着错综复杂的依 ...
- Docker环境下的前后端分离项目部署与运维
本教程将从零开始部署一个前后端分离的开源项目,利用docker虚拟机的容器技术,采用分布式集群部署,将项目转换成为高性能.高负载.高可用的部署方案.包括了MySQL集群.Redis集群.负载均衡.双机 ...
- 《京东上千页面搭建基石——CMS前后端分离演进史》阅读笔记
一.背景 CMS即内容管理系统,目的是用于快速进行网站建设或者网页开发. 对于京东网站部门来说,CMS核心目的是用来快速开发和上线各种页面,诸如各种垂直频道页. 二.CMS核心目的 进行数据和模板的统 ...
- docker+nginx+redis部署前后端分离项目!!!
介绍本文用的经典的前后端分离开源项目.项目的拉取这些在另一篇博客!!! 其中所需要的前后端打包本篇就不做操作了!!不明白的去看另一篇博客!!! 地址:http://www.cnblogs.com/ps ...
- luffy项目搭建流程(Django前后端分离项目范本)
第一阶段: 1.版本控制器:Git 2.pip安装源换国内源 3.虚拟环境搭建 4.后台:Django项目创建 5.数据库配置 6.luffy前 ...
- Docker环境下的前后端分离项目部署与运维(六)搭建MySQL集群
单节点数据库的弊病 大型互联网程序用户群体庞大,所以架构必须要特殊设计 单节点的数据库无法满足性能上的要求 单节点的数据库没有冗余设计,无法满足高可用 单节点MySQL的性能瓶领颈 2016年春节微信 ...
- Docker环境下的前后端分离项目部署与运维(七)Redis高速缓存
Redis高速缓存 利用内存保存数据,读写速度远超硬盘:可以减少I/O操作,降低I/O压力. 发红包.抢红包的数据可以存在高速缓存中,加快处理速度,不需要经过数据库 淘宝首页一些优惠活动商品等热数据可 ...
- Docker环境下的前后端分离项目部署与运维(十一)Docker Swarm技术
Docker Swarm技术 docker swarm技术(之前的docker集群都是在 一个虚拟主机上的,但是如果这个主机挂掉了over了,docker技术就是多个虚拟主机形成一个集群) Swarm ...
随机推荐
- 计算机、程序和java简介
内存 计算机的内存是由一个有序的字节序列组成,用于存储程序及程序需要的数据.你可以将内存想象成计算机执行程序的工作区域.一个程序和它的数据在被CPU执行前必须移到计算机的内存中. 每个字节都是有一个唯 ...
- Windows10:虚拟机开机导致win10黑屏、蓝屏
管理员身份打开cmd(命令提示符) 执行如下5个命令 netsh winsock reset net stop VMAuthdService net start VMAuthdService net ...
- java 的 IO简单理解
首先要先理解什么是 stream ? stream代表的是任何有能力产出数据的数据源,或是任何有能力接收数据的接收源. 一.不同导向的 stream 1)以字节为单位从 stream 中读取或往 st ...
- C语言字符串处理库函数大全(转)
一.string.h中字符串处理函数 在头文件<string.h>中定义了两组字符串函数.第一组函数的名字以str开头:第二组函数的名字以mem开头. 只有函数memmove对重叠对象间的 ...
- QT从入门到入土(三)——信号和槽机制
摘要 信号槽是 Qt 框架引以为豪的机制之一.所谓信号槽,实际就是观察者模式.当某个事件发生之后,比如,按钮检测到自己被点击了一下,它就会发出一个信号 (signal).这种发出是没有目的的,类似广播 ...
- js学习-es6实现枚举
最近大部分时间再写dart,突然用到js,发现js不能直接声明一个枚举.搜索发现还是有实现的方式,于是总结一下. 目录 枚举特点 Object.freeze() Symbol 实现 体现不可更改 体现 ...
- 【LeetCode】86. 分隔链表
86. 分隔链表 知识点:链表: 题目描述 给你一个链表的头节点 head 和一个特定值 x ,请你对链表进行分隔,使得所有 小于 x 的节点都出现在 大于或等于 x 的节点之前. 你应当 保留 两个 ...
- 未开通js之前的纯css网页主题
本主题修改自其他大佬:Rocket1184/MaterialCnblogs: Material Theme for cnblogs.com (github.com) 只需在博客后台选择"禁用 ...
- Leetcode:169. 多数元素
Leetcode:169. 多数元素 传送门 思路 一开始想到的一个很简单的做法就是hash法,直接利用打表记录次数再输出结果. 而利用BM算法可以令算法复杂度同样也在\(O(n)\)的情况下,将空间 ...
- Kafka流处理内幕详解
1.概述 流处理是一种用来处理无穷数据集的数据处理引擎.通常无穷数据集具有以下几个特点: 无穷数据:持续产生的数据,它们通常会被称为流数据.例如:银行信用卡交易订单.股票交易就.游戏角色移动产生的数据 ...