环境:

CentOS 8.5.2111
Docker 20.10.10
Docker-Compose 2.1.0

服务:

db  redis  web nginx

NET Core 6+MySQL 8+Nginx + Redis

Kubernetes 又称 K8s ,是集群的 ,单机用 Docker Compose 编排容器 比较方便

cat /etc/system-release     #查看版本

sudo yum update 

dnf -y update     #更新系统环境

先安装 Docker Engine 和 Docker Compose

1. Docker  安装

Docker三大核心概念:
镜像(Image)
容器(Container)
仓库(Repository)

https://docs.docker.com/compose/install/
https://cloud.tencent.com/document/product/213/46000

DockerHub镜像加速器

使用加速器可以提升获取Docker官方镜像的速度
Docker Version不低于1.10时,建议直接通过daemon config进行配置

配置文件/etc/docker/daemon.json(没有时新建该文件)

1. 创建一个Docker的配置文件

sudo vim /etc/docker/daemon.json

2. 编写配置文件

{
"registry-mirrors": [
"https://个人申请的.mirror.aliyuncs.com",
"https://mirror.ccs.tencentyun.com",
"https://hub-mirror.c.163.com",
"https://mirror.baidubce.com"
]
}

阿里云的个人加速器地址:https://cr.console.aliyun.com/cn-shenzhen/instances/mirrors

安装 Docker

1.添加 Docker 软件源 (docker-ce 社区版)

dnf config-manager --add-repo=https://mirrors.cloud.tencent.com/docker-ce/linux/centos/docker-ce.repo

2.查看已添加的 Docker 软件源

dnf list docker-ce

3.安装 Docker

dnf install -y docker-ce

4.重新加载并重启

sudo systemctl daemon-reload
sudo systemctl restart docker

5.设置Docker开机自启

sudo systemctl enable docker

启动docker

sudo systemctl start docker

关闭docker

sudo systemctl stop docker

更新docker-ce

yum update docker-ce

Docker 常用命令

docker info   #查看信息
docker version #查看版本
docker images #查看已有镜像
docker ps #查看当前运行中的容器
docker ps -a #查看所有容器,包括未运行中的
docker inspect netcoreip #查看容器详细信息
docker exec -it nginx ls #进入容器查看目录结构与文件 docker rm -f $(docker ps -aq) #删除全部容器
docker rmi -f $(docker images -aq) #删除全部镜像 docker run -it ImageId /bin/bash #ImageId docker images 命令获取, 退出容器:执行 exit 命令
docker exec -it 容器ID /bin/bash #进入后台运行的容器
docker logs 容器ID/名称 #如未查看到刚才运行的容器,查看启动日志排错

强制删除镜像 例子

docker rmi -f 60c033c82171
docker rmi -f netcorezeng
docker rmi -f microsoft/dotnet

强制删除容器 例子

docker rm -f mysql8

卸载Docker

sudo yum remove docker-ce docker-ce-cli containerd.io
sudo rm -rf /var/lib/docker
sudo rm -rf /var/lib/containerd

2.Docker-Compose 容器编排

https://cloud.tencent.com/developer/article/1438222

V1 版本安装(不用这个)

https://docs.docker.com/compose/install/

sudo curl -L "https://get.daocloud.io/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

sudo chmod +x /usr/local/bin/docker-compose #设置权限

docker compose version #查看版本

sudo rm /usr/local/bin/docker-compose #删除

V2 版本安装 (当前用这个)

https://docs.docker.com/compose/cli-command/#install-on-linux
https://github.com/docker/compose

1.创建目录

mkdir -p /usr/local/lib/docker/cli-plugins

2.下载

curl -SL https://github.com/docker/compose/releases/download/v2.1.0/docker-compose-linux-x86_64 -o /usr/local/lib/docker/cli-plugins

上面方法 一般都会因为网络原因下载失败 使用下面方法
下载 docker-compose-linux-x86_64 重命名为 docker-compose 放到 /usr/local/lib/docker/cli-plugins

3.添加可执行权限

chmod +x /usr/local/lib/docker/cli-plugins/docker-compose

3.Docker-Compose 配置

目录结构:

工程目录下 /home/docker_compose/docker-compose.yml

docker-compose.yml 配置

version: "3.9"
services:
db:
image: mysql
container_name: mysql8
restart: always
volumes:
- ./my.cnf:/etc/mysql/my.cnf
- /home/data/mysql:/var/lib/mysql
environment:
MYSQL_ROOT_PASSWORD: "root密码"
MYSQL_DATABASE: "数据库名称"
MYSQL_USER: "用户名"
MYSQL_PASSWORD: "用户密码"
ports:
- 3306:3306
command:
- --default-authentication-plugin=mysql_native_password
- --character-set-server=utf8mb4
- --collation-server=utf8mb4_bin redis:
image: redis
container_name: redis
volumes:
- /home/data/redis:/var/lib/redis
- ./redis.conf:/usr/local/etc/redis/redis.conf
ports:
- 6379:6379
command:
redis-server /usr/local/etc/redis/redis.conf web:
image: ${DOCKER_REGISTRY-}netcorezeng
container_name: netcoreapp
build:
context: /home/app
dockerfile: Dockerfile
restart: always
ports:
- 5000:80
depends_on:
- db
- redis
environment:
TZ: Asia/Shanghai nginx:
image: nginx
container_name: nginx
restart: always
ports:
- 80:80
- 443:443
volumes:
- ./nginx.conf:/etc/nginx/nginx.conf
- /home/sslcrt:/etc/nginx/cert
- /home/log/nginx:/var/log/nginx
- /home/app:/usr/share/nginx/html

my.cnf 配置

[client]

#socket = /usr/mysql/mysqld.sock

default-character-set = utf8mb4

[mysqld]

#pid-file = /var/run/mysqld/mysqld.pid
#socket = /var/run/mysqld/mysqld.sock
#datadir = /var/lib/mysql
#socket = /usr/mysql/mysqld.sock
#pid-file = /usr/mysql/mysqld.pid datadir = /home/data/mysql
character_set_server = utf8mb4
collation_server = utf8mb4_bin
default-time_zone = '+8:00'
secure-file-priv= NULL # Disabling symbolic-links is recommended to prevent assorted security risks symbolic-links=0 # Custom config should go here !includedir /etc/mysql/conf.d/

nginx.conf 配置

# For more information on configuration, see:
# * Official English Documentation: http://nginx.org/en/docs/
# * Official Russian Documentation: http://nginx.org/ru/docs/ user nginx;
worker_processes auto;
error_log error.log;
pid /run/nginx.pid; # Load dynamic modules. See /usr/share/nginx/README.dynamic.
include /usr/share/nginx/modules/*.conf; events {
worker_connections 1024;
}
http {
log_format main '$remote_addr $http_x_forwarded_for - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"'; access_log access.log main; sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
types_hash_max_size 2048; include /etc/nginx/mime.types;
default_type application/octet-stream; # Load modular configuration files from the /etc/nginx/conf.d directory.
# See http://nginx.org/en/docs/ngx_core_module.html#include
# for more information.
include /etc/nginx/conf.d/*.conf; server {
listen 80;
server_name xx.com www.xx.com;
location / {
root /usr/share/nginx/html;
index index.html;
proxy_pass http://web;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_cache_bypass $http_upgrade;
add_header Access-Control-Allow-Methods *;
add_header Access-Control-Allow-Origin $http_origin;
}
} server {
listen 443 ssl;
server_name xx.com www.xx.com;
ssl_certificate "cert/1_bundle.crt";
ssl_certificate_key "cert/2_.key";
ssl_session_timeout 5m;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on; # Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf; location / {
root /usr/share/nginx/html;
index index.html;
proxy_pass http://web;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_cache_bypass $http_upgrade;
add_header Access-Control-Allow-Methods *;
add_header Access-Control-Allow-Origin $http_origin;
}
}
}

Dockerfile 配置

FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS base
WORKDIR /app
EXPOSE 80
EXPOSE 443 FROM base AS final
WORKDIR /app
# 将本地应用拷贝到 容器/app 目录下
COPY ./ ./
ENTRYPOINT ["dotnet", "NETCoreZeng.dll"]

1.创建工程目录

mkdir /home/docker_compose
cd /home/docker_compose

2.创建 Dockerfile 模板文件

注意:一定要是UNIX格式,不能是windows格式

/home/app/Dockerfile

3.配置服务文件 docker-compose.yml

注意:不可以有制表符

语法错误: found character that cannot start any token (不可以有制表符)
did not find expected key

使用 YAML 时需要注意下面事项:
●不支持制表符 tab 键缩进,需要使用空格缩进
●通常开头缩进2个空格
●字符后缩进1个空格,如冒号 : 、逗号 , 、横杠 -
●用 # 号注释
●如果包含特殊字符用单引号 ‘’ 引起来
●布尔值必须用引号 “” 括起来

4.运行 Compose

错误提示:can't find a suitable configuration file in this directory or any parent: not found

切换到工程目录下
cd /home/docker_compose

再运行
docker compose up -d

错误提示:yaml: line 33: did not find expected key(格式要规范 不能多空格 如 web db redis 前面的空格)
错误提示:cannot load certificate No such file or directory(证书默认目录 /etc/nginx )

docker compose version #查看版本
docker compose info
docker compose up #创建并启动所有服务
docker compose up -d #在后台所有启动服务
docker compose images #所有镜像
docker compose ps #查看当前正在运行的容器
docker compose ps -a #查看所有容器,包括未运行中的
docker compose stop #停止所有容器
docker compose stop web #停止某个服务
docker compose rm -f web #移除已经停止的服务容器
docker compose restart #重启 docker compose logs -t --tail="10" #查看nginx最新10条日志 sudo rm /usr/local/lib/docker/cli-plugins/docker-compose #卸载 Docker Compose

容器时间与宿主机不一致

docker-compose.yml 里面添加
environment:
TZ: Asia/Shanghai

容器之间连接

SERVICE 服务分别是 :db redis  web nginx

nginx.conf

proxy_pass http://web;

appsettings.json

 "ConnectionStrings": {
"MySqlConnection": "server=db;xxxxxxxx;"
},

最后

看起来 很多东西配置  其实 配置好 docker_compose 里面几个服务的配置   灵魂的东西都在里面了

切换到工程目录下
cd /home/docker_compose

再运行
docker compose up -d

就可以了

Docker Compose 容器编排 NET Core 6+MySQL 8+Nginx + Redis的更多相关文章

  1. AspNetCore容器化(Docker)部署(三) —— Docker Compose容器编排

    一.前言 上一篇部署了一个最基础的helloworld应用,创建了两个容器和一个network,还算应付得过来. 如果该应用继续引入mysql.redis.job等若干服务,到时候发布一次得工作量之大 ...

  2. Docker Compose容器编排

    Compose是Docker官方的开源项目,可以实现对Docker容器集群的快速编排.Compose 中有两个重要的概念:服务(service):一个应用的容器,实际上可以包括若干运行相同镜像的容器实 ...

  3. Docker Compose 容器编排

    1. 前言 Docker Compose 是 Docker 容器进行编排的工具,定义和运行多容器的应用,可以一条命令启动多个容器. 使用Compose 基本上分为三步: Dockerfile 定义应用 ...

  4. 八、docker compose容器编排

    一. Docker-Compose 1.1. 什么是Docker Compose Compose 项目是 Docker 官方的开源项目,负责实现 Docker 容器集群的快速编排,开源代码在 http ...

  5. asp.net core容器&mysql容器network互联 & docker compose方式编排启动多个容器

    文章简介 asp.net core webapi容器与Mysql容器互联(network方式) docker compose方式编排启动多个容器 asp.net core webapi容器与Mysql ...

  6. 物联网架构成长之路(24)-Docker练习之Compose容器编排

    0.前言 一开始学的之后,是想一步到位直接上Kubernetes(K8s)的,后面没想到,好像有点复杂,有些概念不是很懂.因此学习东西还是要循序渐进,慢慢来.先了解单机编排技术Docker Compo ...

  7. 通过 Docker Compose 组合 ASP NET Core 和 SQL Server

    目录 Docker Compose 简介 安装 WebApi 项目 创建项目 编写Dockfile Web MVC 项目 创建项目 编写Dockfile 编写 docker-compose.yml文件 ...

  8. Docker | 第七章:Docker Compose服务编排介绍及使用

    前言 前面章节,我们学习了如何构建自己的镜像文件,如何保存自己的镜像文件.大多都是一个镜像启动.当一个系统需要多个子系统进行配合时,若每个子系统也就是镜像需要一个个手动启动和停止的话,那估计实施人员也 ...

  9. 在Windows Server 2019通过Docker Compose部署Asp.Net Core

    一.安装Docker Enterprise 安装文档是: https://docs.docker.com/install/windows/docker-ee/ 安装完成后,如下图 二.首先,拉取一个W ...

随机推荐

  1. nsq topic

    与Topic相关的代码主要位于nsqd/topic.go中. 上一篇文字我们讲解了下nsq的启动流程.对nsq的整体框架有了一个大概的了解.本篇文章就是由大到小.对于topic这一部分进行详尽的讲解. ...

  2. Verilog的数据流、行为、结构化与RTL级描述

    Verilog语言可以有多种方式来描述硬件,同时,使用这些描述方式,又可以在多个抽象层次上设计硬件,这是Verilog语言的重要特征. 在Verilog语言中,有以下3种最基本的描述方式: 数据流描述 ...

  3. Head First Python 代码和实例下载

    http://python.itcarlow.ie/resources.html

  4. C++编译Dlib库出现LNK2001错误(原因是在Python中安装过Dlib)

    问题 使用CMake编译Dlib库,编译得到lib文件后,新建一个VS工程想使用Dlib,却出现LNK2001:无法解析的外部符号的错误,且都与JPEG和PNG相关: 1>dlib19.17.9 ...

  5. 80. 删除有序数组中的重复项 II

    题目 给你一个有序数组 nums ,请你原地删除重复出现的元素(不需要考虑数组中超出新长度后面的元素),使每个元素最多出现两次 ,返回删除后数组的新长度. 不要使用额外的数组空间,你必须在原地修改输入 ...

  6. centos7 配置ftp服务器搭建(匿名访问,以及本地登录)

    大家好,今天来给大家分享一个基于centos 7的ftp服务器搭建 实现功能:匿名访问,本地登录 查看系统版本: [root@localhost ~]# cat /etc/redhat-release ...

  7. [no_code][Beta]设计和计划

    2020春季计算机学院软件工程(罗杰 任健) 2020春季计算机学院软件工程(罗杰 任健) 作业要求 Beta设计和计划 我们在这个课程的目标是 远程协同工作,采用最新技术开发软件 这个作业在哪个具体 ...

  8. [对对子队]Alpha阶段项目展示博客

    Alpha阶段项目展示博客 1 团队成员的简介和个人博客地址 成员 头像 岗位 博客 个人介绍 黄贤昊 PM 17373253 喜欢玩游戏和做游戏,项目经验基本都和游戏相关,擅长摸鱼,偶尔敬业. 刘子 ...

  9. Spring Security Resource Server的使用

    Spring Security Resource Server的使用 一.背景 二.需求 三.分析 四.资源服务器认证流程 五.实现资源服务器 1.引入jar包 2.资源服务器配置 3.资源 六.测试 ...

  10. NorFlash、NandFlash在技术和应用上有些什么区别?

    首先你要搞懂什么是Flash Memory? Flash Memory(快闪存储器),是一种电子式可清除程序化只读存储器的形式,允许在操作中被多次擦或写的存储器.这种科技主要用于一般性数据存储,以及在 ...