从零开始 - Docker部署前后端分离项目(一)

简介: 从零开始 - Docker部署前后端分离项目(一)Docker是一个开源的应用容器引擎,使用GO语言开发,并利用 Linux 内核的几个特性来提供其功能。Docker 使应用程序与基础设施分开,以便可以快速交付软件。

从零开始 - Docker部署前后端分离项目(一)

Docker是一个开源的应用容器引擎,使用GO语言开发,并利用 Linux 内核的几个特性来提供其功能。Docker 使应用程序与基础设施分开,以便可以快速交付软件。

一、前言

此系列的文章基于以下环境:


阿里云服务器ECS


CPU&内存 :1核(vCPU) 2 GiB


操作系统:Ubuntu 20.04 64位


二、安装Docker

安装 docker 最简单的方法是使用官方脚本自动安装


安装命如下:


先保证apt是最新版本,更新apt

apt update

进行docker下载

curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun

image.png

各种 Linux 系统的手动安装步骤见:https://docs.docker.com/engine/install/

1、镜像加速

修改/etc/docker/daemon.json 文件,如果没有先建一个即可

sudo vim /etc/docker/daemon.json

修改配置文件内如下:

{
"registry-mirrors": ["https://registry.docker-cn.com"]
}

然后重启服务

$ sudo systemctl daemon-reload
$ sudo systemctl restart docker

2、验证docker

查看docker服务是否启动:

systemctl status docker

image.png

若未启动,则启动docker服务:

systemctl start docker

3、docker开机自启

# 查看是否设置开机启动
systemctl list-unit-files | grep docker.service.*enabled
# 设置开机启动
systemctl enable docker.service
# 关闭开机启动
systemctl disable docker.service

image.png

三、容器的常用命令

容器就是根据镜像启动的一个进程,它就是一个运行的系统。

1. 创建容器

根据一个镜像创建容器,命令格式如下:

docker container run [options] image [command]
docker run [options] image [command]

run:就是运行容器的命令

options: 一系列的参数,可以省略

image: 启动容器的镜像

command: 容器要执行的命令

例如:

docker run ubuntu:latest /bin/echo "hello world"

表示根据镜像ubuntu:latest启动一个容器,运行命令/bin/echo "hello world",如果本地没有ubuntu:latest镜像,会自动去仓库下载。

image.png

注意,如果容器运行的命令结束了(不管是正常结束,还是有错误结束),容器会退出。

2. 创建容器的常用参数

docker run --name redis -d --network mwj --restart=always -v redis_data:/data

参数

描述

-i

交互式创建容器
-t 分配一个伪终端

-d

运行容器到后台
-e 设置环境变量
-p 映射容器端口到主机
-h 设置容器主机名
–link 添加连接到另一个容器
–network 连接容器到一个网络
-v 挂载宿主机目录到容器
–restart 容器退出后的重启策略,默认 no[always|failure]
–name 给容器命令

启动容器

启动一个停止的容器

$ sudo docker container start 容器名/ID
docker ps -a #查看所有容器


3. 查看容器

docker container ls
docker ps
# 上面两个命令只能看运行中的容器
docker container ls -a
docker ps -a 
# 下面两个命令可以查看所有的容器,包含以退出的容器

4. 停止容器

docker container stop 容器名/id
docker stop 容器名/id

5. 删除容器

docker container rm 容器名/id
docker rm 容器名/id

6. 启动一个退出的容器

docker container start 容器名/id
docker start 容器名/id
相关文章
|
6天前
|
人工智能 API 数据安全/隐私保护
使用 Docker 一键免费部署 63.8k 的私人 ChatGPT 网页应用
NextChat 是一个可以在 GitHub 上一键免费部署的私人 ChatGPT 网页应用,支持 GPT3、GPT4 和 Gemini Pro 模型。该项目在 GitHub 上获得了 63.8k 的 star 数。部署简单,只需拉取 Docker 镜像并运行容器,设置 API Key 后即可使用。此外,NextChat 还提供了预设角色的面具功能,方便用户快速创建对话。
54 22
使用 Docker 一键免费部署 63.8k 的私人 ChatGPT 网页应用
|
17天前
|
SQL 关系型数据库 数据库
国产数据实战之docker部署MyWebSQL数据库管理工具
【10月更文挑战第23天】国产数据实战之docker部署MyWebSQL数据库管理工具
56 4
国产数据实战之docker部署MyWebSQL数据库管理工具
|
7天前
|
运维 开发者 Docker
Docker Compose:简化容器化应用的部署与管理
Docker Compose:简化容器化应用的部署与管理
|
7天前
|
Docker 微服务 容器
使用Docker Compose实现微服务架构的快速部署
使用Docker Compose实现微服务架构的快速部署
17 1
|
19天前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
46 2
|
20天前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
29 3
|
7天前
|
前端开发 开发者 Docker
深入探索Docker Compose:简化多容器应用的部署
深入探索Docker Compose:简化多容器应用的部署
27 0
|
3月前
|
运维 Java Devops
阿里云云效操作报错合集之部署docker时遇到报错,该怎么办
本合集将整理呈现用户在使用过程中遇到的报错及其对应的解决办法,包括但不限于账户权限设置错误、项目配置不正确、代码提交冲突、构建任务执行失败、测试环境异常、需求流转阻塞等问题。阿里云云效是一站式企业级研发协同和DevOps平台,为企业提供从需求规划、开发、测试、发布到运维、运营的全流程端到端服务和工具支撑,致力于提升企业的研发效能和创新能力。
|
运维 Kubernetes 前端开发
【云原生】阿里云服务器部署 Docker Swarm集群
阿里云服务器 一键部署 Docker Swarm 集群!
673 0
【云原生】阿里云服务器部署 Docker Swarm集群
|
弹性计算 数据可视化 关系型数据库
使用阿里云部署基于docker的mysql云服务
本篇文章将介绍如何使用阿里云安装docker、部署mysql服务,并远程连接至远端mysql
683 1
使用阿里云部署基于docker的mysql云服务