Docker-Compose单机多容器应用编排与管理

news/2024/5/18 11:52:04

前言

Docker Compose 作为 Docker 生态系统中的一个重要组件,为开发人员提供了一种简单而强大的方式来定义和运行多个容器化应用。本文将介绍 Docker Compose 的使用背景、优劣势以及利用 Docker Compose 简化应用程序的部署和管理。

目录

一、Docker Compose 简介

1. 使用背景

2. 简介

3. Docker Compose 分层介绍

4. Docker Compose 优势 

5. Docker Compose 缺点

二、Docker Compose 部署

1. 环境安装

1.1 下载 Docker Compose 并安装

2. YAML 文件格式及编写注意事项

2.1 概述

2.2 特点

2.3 注意事项

2.4 数据结构

2.4.1 对象映射(字典)

2.4.2 序列数组(列表)

2.4.3 布尔值

2.4.4 混合结构

2.4.5 示例

3. 配置常用字段

4. 常用命令

5. 文件结构

6. 构建 nginx 镜像

6.1 准备依赖文件

6.2 编写配置文件 docker-compose.yaml

6.3 启动 yaml 文件中定义的服务

6.4 查看容器基本信息

6.5 访问服务

三、多容器应用编排

1. 修改 yaml 文件

2. 删除 nginx 容器、镜像、网络

3. tomcat 工作目录以及相关文件准备

4. 启动服务

5. 访问页面


一、Docker Compose 简介

1. 使用背景

尽管 Dockerfile 是定义单个容器镜像所必需的工具,但它也存在一些缺点,特别是在多容器应用程序的情况下,如:编排过程复杂且难以维护、Dockerfile 并不直接支持容器间的依赖关系管理、Dockerfile 主要关注于单个容器的构建;

Docker Compose 能够弥补这些缺点,通过一个简单的 YAML 文件,它提供了一种更高级的抽象,能够轻松管理多个相关联的容器,并定义它们之间的依赖关系,从而简化了多容器应用程序的编排和管理过程。

2. 简介

Docker Compose 负责实现在单机上完成容器集群编排的管理,是单机多应用容器编排;在生产环境中,适用于纵向扩展,从而降低成本。当需要进行多主机(跨节点)的集群管理和容器编排时,则需要用到 Docker Swarm 工具。在实际使用中,两者也可以结合使用,比如使用 Docker Compose 来定义应用程序的服务组成,然后利用 Docker Swarm 在集群中进行部署和管理。

3. Docker Compose 分层介绍

Docker Compose 将所管理的容器分为三层,分别是工程(project),服务(service)以及容器(container):

  • Docker-Compose 运行目录下的所有文件(docker-compose.yml,extends 文件或环境变量文件等)组成一个工程,若无特殊指定工程名即为当前目录名,比如 LNMP; 
  • 一个工程当中可包含多个服务,每个服务中定义了容器运行的镜像、参数、依赖;比如:nginx、mysql、php;
  • 一个服务当中可包括多个容器实例,Docker-Compose并没有解决负载均衡的问题,因此需要借助其它工具实现服务发现及负载均衡,比如 Consul。

即使用 Docker Compose 可以完成多个 docker run 的所有操作。

Compose 允许用户通过一个单独的 docker-compose.yml 模板文件(YAML 格式)来定义一组相关联的应用容器为一个项目(project)。包括:容器的数量、容器之间的依赖关系、环境变量、端口映射以及数据卷等设置;

然后,用户使用 docker-compose 命令根据指定配置模板文件的配置来启动和管理容器集群。

4. Docker Compose 优势 

Docker Compose简化了多容器应用的管理与编排,提供了一种简单且强大的方式来定义和运行多个相关联的容器,有助于提高开发、部署和管理效率。

① 简化多容器应用编排:Docker Compose允许用户通过一个简单的YAML文件定义和运行多个相关联的容器;

② 一键部署:通过Docker Compose文件,用户可以将整个应用程序的配置信息集中在一个地方,实现一键式的部署,极大地简化了部署流程;

③ 微服务架构支持:对于采用微服务架构的应用程序,Docker Compose能够帮助开发人员管理各个微服务之间的依赖关系,简化了微服务架构下的应用部署和管理。

5. Docker Compose 缺点

① 适用范围受限:Docker Compose 更适用于单机或者开发测试环境下的应用部署,对于生产环境中复杂的多主机集群管理需求,其能力相对较弱。

② 缺乏自动恢复机制:当容器发生故障时,Docker Compose 本身并没有提供完善的自动恢复机制,需要额外的监控系统或工具来实现容器级别的自动恢复。

尽管存在这些缺点,但在适当的使用场景下, Docker Compose 仍然是一个非常有价值的容器编排工具。

二、Docker Compose 部署

1. 环境安装

1.1 下载 Docker Compose 并安装

[root@localhost ~]# curl -L https://github.com/docker/compose/releases/download/1.21.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
# `uname -s`-`uname -m`也可以写成$(uname -s) 和 $(uname -m):分别会自动替换为你的系统类型(如:Linux)和机器架构(如:x86_64),确保你下载的是适合你系统的版本。
# curl -L:这部分表示使用curl命令进行下载,并且使用-L参数来跟随重定向
# -o /usr/local/bin/docker-compose: 表示将下载的文件保存为/usr/local/bin目录下的docker-compose文件
[root@localhost bin]# pwd
/usr/local/bin
[root@localhost bin]# ls
docker-compose
[root@localhost bin]# chmod +x /usr/local/bin/docker-compose
[root@localhost bin]# ll
总用量 16636
-rwxr-xr-x. 1 root root 17031592 4月  29 16:08 docker-compose
[root@localhost bin]# docker-compose --version     # 查看版本
docker-compose version 1.25.0-rc4, build 8f3c9c58

2. YAML 文件格式及编写注意事项

2.1 概述

YAML(YAML Ain't Markup Language) 是一种人类可读的数据序列化格式,常用于配置文件和数据传输。它以缩进、换行和符号结构来表示数据,具有简洁、清晰的特点。YAML 旨在成为一个易于阅读和编写的数据格式,同时也适合机器解析和生成。它使用空格缩进来表示层级关系,不需要显式的标记符号(如 XML 或 JSON 中的尖括号或大括号),这使得它更加直观和易读。

YAML 官方网站:The Official YAML Web Site

2.2 特点

  • YAML 数据结构通过缩进来表示
  • 连续的项目通过减号来表示
  • 键值对用冒号分隔
  • 数组用中括号 [ ] 括起来,[ ]通常用于表示列表(数组)
  • hash 用花括号 { } 括起来,{ }通常用于表示字典(键值对)

2.3 注意事项

  • 大小写敏感
  • 通过缩进表示层级关系
  • 不支持制表符 tab 键缩进,只能使用空格缩进
  • 缩进的空格数目不重要,只要相同层级左对齐,通常开头缩进 2 个空格
  • 用 # 号注释
  • 符号字符后缩进1个空格,如冒号:  逗号 ,    横杠 -    
  • 如果包含特殊字符用单引号 ('') 引起来会作为普通字符串处理,双引号 (" ") 特殊字符作为本身想表示的意思,name:"Hi,\nTom"
  • 以 .yml 或者 .yaml 结尾
  • 以 --- 开始,以 ... 结束,但开始和结束标志都是可选的

2.4 数据结构

2.4.1 对象映射(字典)

字典在 YAML 中使用键值对的形式表示,使用冒号 : 将键和值分隔开,键值之间需要有一个空格。字典可以包含嵌套的字典或者列表作为值。

  • 键值对的字典
  • 对象映射指的是在docker-compose.yml文件中定义的服务和它们的配置
  • 这些对象映射定义了每个服务的配置,以及如何运行这些服务
name: Using Ansible
code: D1234
#符号字符“: ”后必须缩进1个空格
#转换为 python 的 Dict
#{'name': 'Using Ansibel','code': 'D1234'}
2.4.2 序列数组(列表)

在 YAML 中,列表使用短横线 - 表示,后面跟着一个空格。列表可以包含任意类型的元素,例如字符串、数字、布尔值或者其他嵌套的列表。

  • 一组按次序排列的列表
  • 序列数组是一种数据结构,用于表示一组有序的元素
  • 在docker-compose.yml文件中,序列数组通常用于定义多个相似的配置项,例如多个服务或多个环境变量
- red
- green
- blue
# 以上的值假如转换成 python 的 List 会是这样:
# ['red', 'green', 'blue']
2.4.3 布尔值
  • 布尔值可以用来表示真假值
  • 在 YAML 中,以下是表示布尔值的方式:

① true 和 false:分别表示真和假
② yes 和 no:分别表示真和假
③ on 和 off:分别表示真和假
④ 1 和 0:分别表示真和假 

debug: true
debug: false
2.4.4 混合结构

但在日常生产中,往往需要的数据结构会特别复杂,有可能会是字符串、列表、字典的组合形式。这里举一个例子:学校里是以班级为单位。我们去使用列表和字典的形式去描述一个班级的组成。

class:- name: stu1num: 001- name: stu2num: 002- name: stu3num: 003
#{'class': [{'name': 'stul, 'num': 1},{'name': 'stu2', 'num': 2), ...]}
2.4.5 示例
# yaml 格式
languages:       #序列的映射- Java- Golang- Python
websites:        #映射的映射cpu: 2memory: 1024Mswap: 2048Mdisk: 60G 键:{值}# Json 格式
{languages: ['Java','Golang','Python'	],resources: {cpu: '2',memory: '1024M',swap: '2048M',disk: '60G'}
}Baidu:www.baidu.com
wangyi: www.163.com
tengxun: www.qq.com

3. 配置常用字段

字段描述
build指定 Dockerfile 文件名,要指定Dockerfile文件需要在build标签的子级标签中使用dockerfile标签指定
dockerfile构建镜像上下文路径
context可以是 dockerfile 的路径,或者是指向 git 仓库的 url 地址
image指定镜像
command执行命令,覆盖容器启动后默认执行的命令
container_name指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法scale指定容器数量
deploy指定部署和运行服务相关配置,只能在 Swarm 模式使用
environment添加环境变量
networks加入网络,引用顶级networks下条目
network_mode设置容器的网络模式,如 host,bridge,...
ports暴露容器端口,与 -p 相同,但端口不能低于 60
volumes挂载一个宿主机目录或命令卷到容器,命名卷要在顶级 volumes 定义卷名称
volumes_from从另一个服务或容器挂载卷,可选参数 :ro 和 :rw,仅版本 '2' 支持
hostname容器主机名
sysctls在容器内设置内核参数
links连接到另外一个容器,- 服务名称[:服务别名]
privileged用来给容器root权限,注意是不安全的,true | false
restart设置重启策略,no,always,nounless-st-failure,oped
no,默认策略,在容器退出时不重启容器。
on-failure,在容器非正常退出时(退出状态非0),才会重启容器。
on-failure:3,在容器非正常退出时重启容器,最多重启3次。
always,在容器退出时总是重启容器。
unless-stopped,在容器退出的容器时总是重启容器,但是不考虑在 Docker 守护进程启动时就已经停止了。
depends_on在使用Compose时,最大的好处就是少打启动命令,但一般项目容器启动的顺序是有要求的,如果直接从上到下启动容器,可能会因为容器依赖问题而启动失败。例如在没启动数据库容器的时候启动应用容器,应用容器会因为找不到数据库而退出。depends_on标签用于解决容器的依赖、启动先后的问题。
php:
  depends_on:
    - apache
    - mysql

4. 常用命令

字段描述
build重新构建服务
ps列出容器
up创建和启动容器
exec在容器里面执行命令
scale指定一个服务容器启动数量
top显示容器进程
logs查看容器输出
down删除容器、网络、数据卷和镜像
stop/start/restart停止/启动/重启服务

5. 文件结构

[root@localhost nginx]# tree /opt/compose_nginx/
/opt/compose_nginx/
├── nginx
│   ├── Dockerfile
│   └── nginx-1.12.0.tar.gz
└── wwwroot└── index.html

6. 构建 nginx 镜像

6.1 准备依赖文件

① 创建工作目录,添加相关文件 

[root@localhost ~]# mkdir -p /opt/compose_nginx/{nginx,wwwroot}
[root@localhost ~]# cd /lnmp/nginx/
[root@localhost nginx]# cp Dockerfile nginx-1.12.0.tar.gz /opt/compose_nginx/nginx/
[root@localhost nginx]# cd /opt/compose_nginx/nginx
[root@localhost nginx]# ls
Dockerfile  nginx-1.12.0.tar.gz

② 修改 Dockerfile 文件 

[root@localhost nginx]# vim Dockerfile
FROM centos:7
MAINTAINER nginx image <fql>
RUN yum -y install pcre-devel zlib-devel gcc gcc-c++ make
RUN useradd -M -s /sbin/nologin nginx
ADD nginx-1.12.0.tar.gz /usr/local/src/
WORKDIR /usr/local/src/nginx-1.12.0
RUN ./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module && make -j 4 && make install
ENV PATH /usr/local/nginx/sbin:$PATH
EXPOSE 80
EXPOSE 443
ENTRYPOINT [ "/usr/local/nginx/sbin/nginx", "-g", "daemon off;" ]

③ 添加 web 文件 

[root@localhost nginx]# echo "<h1>welcome</h1>" > /opt/compose_nginx/wwwroot/index.html

6.2 编写配置文件 docker-compose.yaml

[root@localhost compose_nginx]# vim docker-compose.yaml
version: '2'                 # 指定了Docker Compose文件的版本,2:多机编排;3:多+单
services:                    # 定义了要运行的服务nginx:                     # 服务的名称,表示要运行一个Nginx容器container_name: web10    # 这指定了容器的名称为web10hostname: nginx          # 容器的主机名为nginxbuild:                   # 使用本地的Dockerfile构建镜像context: ./nginx       # 指定了Dockerfile的构建上下文为当前目录下的./nginx文件夹dockerfile: Dockerfile # 指定了要使用的Dockerfile的名称为Dockerfileports:                   # 定义了将容器内部端口映射到主机上的端口- 100:80               # 将容器的80端口映射到主机的100端口- 101:443              # 将容器的443端口映射到主机的101端口networks:                # 定义了容器连接的网络lnmp:                  # 这是网络的名称ipv4_address: 172.20.0.10       # 指定了容器在lnmp网络中的IPv4地址为172.20.0.10volumes:                 # 将主机上的目录挂载到容器内部的目录- ./wwwroot:/usr/local/nginx/html # 将主机上的./wwwroot目录挂载到容器内的/usr/local/nginx/html目录
networks:                    # 定义了Docker网络lnmp:                      # 这是网络的名称driver: bridge           # 指定了网络的模式为bridgeipam:                    # 定义了IP地址管理config:                # 这是配置IP地址的部分- subnet: 172.20.0.0/16         # 指定了网络的子网为172.20.0.0/16

6.3 启动 yaml 文件中定义的服务

[root@localhost compose_nginx]# ls   # 必须在docker-compose.yaml所在目录执行此命令
docker-compose.yaml  nginx  wwwroot
[root@localhost compose_nginx]# docker-compose -f docker-compose.yaml up -d
# -f, --file FILE:使用特定的compose模板文件,默认为 docker-compose.yaml
# -p, --project-name NAME:指定项目名称,默认使用目录名称
# -d:在后台运行

6.4 查看容器基本信息

[root@localhost compose_nginx]# docker ps
CONTAINER ID   IMAGE                 COMMAND                  CREATED          STATUS          PORTS                                                                        NAMES
b57da6f20339   compose_nginx_nginx   "/usr/local/nginx/sb…"   17 minutes ago   Up 17 minutes   0.0.0.0:100->80/tcp, :::100->80/tcp, 0.0.0.0:101->443/tcp, :::101->443/tcp   web10
[root@localhost compose_nginx]# docker inspect b57da6f20339"Gateway": "172.20.0.1","IPAddress": "172.20.0.10",

6.5 访问服务

访问192.168.190.108:100

三、多容器应用编排

nginx + tomcat docker-compose编排

1. 修改 yaml 文件

[root@localhost compose_nginx]# vim docker-compose.yaml
version: '3'
services:nginx:container_name: web10hostname: nginxbuild:context: ./nginxdockerfile: Dockerfileports:- 100:80- 101:443networks:tm:ipv4_address: 172.20.0.10volumes:- ./wwwroot:/usr/local/nginx/htmltomcat:hostname: tomcatbuild:context: ./tomcatdockerfile: Dockerfileports:- 8080:8080networks:tm:# ipv4_address: 172.20.0.20
networks:tm:driver: bridgeipam:config:- subnet: 172.20.0.0/16

2. 删除 nginx 容器、镜像、网络

[root@localhost compose_nginx]# docker ps
CONTAINER ID   IMAGE                 COMMAND                  CREATED          STATUS          PORTS                                                                        NAMES
b57da6f20339   compose_nginx_nginx   "/usr/local/nginx/sb…"   31 minutes ago   Up 31 minutes   0.0.0.0:100->80/tcp, :::100->80/tcp, 0.0.0.0:101->443/tcp, :::101->443/tcp   web10
[root@localhost compose_nginx]# docker rm -f b57da6f20339
b57da6f20339[root@localhost compose_nginx]# docker images
REPOSITORY            TAG       IMAGE ID       CREATED          SIZE
compose_nginx_nginx   latest    9b349cf24e1c   32 minutes ago   569MB
php                   lnmp      d36e706ae5d6   25 hours ago     1.4GB
nginx                 lnmp      a6b0e83b8ff8   26 hours ago     569MB
mysql                 lnmp      2b328d4ecd04   30 hours ago     10.1GB
nginx                 latest    7383c266ef25   5 days ago       188MB
centos                7         eeb6ee3f44bd   2 years ago      204MB
[root@localhost compose_nginx]# docker rmi 9b349cf24e1c[root@localhost compose_nginx]# docker network ls
NETWORK ID     NAME                 DRIVER    SCOPE
be4ecfaae8fa   bridge               bridge    local
05a4abf62706   compose_nginx_lnmp   bridge    local
52f938e47449   host                 host      local
d2b40d071ba3   mynetwork            bridge    local
8adfae2f9020   none                 null      local
[root@localhost compose_nginx]# docker network rm compose_nginx_lnmp
compose_nginx_lnmp

或者直接使用: docker-compose  -f  docker-compose-yml  down

删除容器、网络、数据卷、镜像 

3. tomcat 工作目录以及相关文件准备

192.168.190.107:
[root@localhost ~]# cd /opt
[root@localhost opt]# ls
apache      debian-7.0-x86-minimal.tar.gz  mysqld  nginx.conf  sshd       tomcat
containerd  docker-26.0.2.tgz              nginx   rh          systemctl
[root@localhost opt]# ls tomcat/
apache-tomcat-9.0.16.tar.gz  Dockerfile  jdk-8u291-linux-x64.tar.gz
[root@localhost opt]# scp -r tomcat/ 192.168.190.108:/opt/compose_nginx/192.168.190.108:
[root@localhost compose_nginx]# ls
docker-compose.yaml  nginx  tomcat  wwwroot
[root@localhost compose_nginx]# cd tomcat/
[root@localhost tomcat]# ls
apache-tomcat-9.0.16.tar.gz  Dockerfile  jdk-8u291-linux-x64.tar.gz
[root@localhost tomcat]# cat Dockerfile 
FROM centos:7
MAINTAINER tomcat image <fql>
ADD jdk-8u291-linux-x64.tar.gz /usr/local/
WORKDIR /usr/local/
RUN mv jdk1.8.0_291 /usr/local/java
ENV JAVA_HOME /usr/local/java
ENV JRE_HOME ${JAVA_HOME}/jre
ENV CLASSPATH .:${JAVA_HOME}/lib:${JRE_HOME}/lib
ENV PATH $JAVA_HOME/bin:$PATH
ADD apache-tomcat-9.0.16.tar.gz /usr/local/
WORKDIR /usr/local/
RUN mv apache-tomcat-9.0.16 /usr/local/tomcat
EXPOSE 8080
#CMD ["/usr/local/tomcat/bin/catalina.sh","run"]
ENTRYPOINT ["/usr/local/tomcat/bin/catalina.sh","run"]
CMD ["/usr/local/tomcat/bin/startup.sh","start"]

4. 启动服务

[root@localhost compose_nginx]# ls
docker-compose.yaml  nginx  tomcat  wwwroot
[root@localhost compose_nginx]# docker-compose -f docker-compose.yaml up -d
[root@localhost compose_nginx]# docker ps
CONTAINER ID   IMAGE                  COMMAND                  CREATED          STATUS          PORTS                                                                        NAMES
544dee4ad153   compose_nginx_tomcat   "/usr/local/tomcat/b…"   48 seconds ago   Up 47 seconds   0.0.0.0:8080->8080/tcp, :::8080->8080/tcp                                    compose_nginx_tomcat_1
dd6bde2af9ee   compose_nginx_nginx    "/usr/local/nginx/sb…"   48 seconds ago   Up 47 seconds   0.0.0.0:100->80/tcp, :::100->80/tcp, 0.0.0.0:101->443/tcp, :::101->443/tcp   web10

5. 访问页面

访问192.168.190.108:8080


http://www.mrgr.cn/p/57845773

相关文章

8.k8s中网络资源service

目录 一、service资源概述 二、service资源类型 1.ClusterIP类型 2.service的nodeport类型 3.service的loadbalancer类型&#xff08;了解即可&#xff09; 4.service的externalname类型&#xff08;了解即可&#xff09; 三、nodeport的端口范围设置和svc的endpoint列表 1.修…

DP Record

从 2024/5/4 往后开始记录捏。 T1.给你一棵树,定义一个集合的权值为 \(\dfrac{\sum_{x\in S}V_x}{\sum_{x\in S}C_x}\)。若一个点 \(\in S\),则其父亲也必须 \(\in S\) 并且 \(|S| = k\)。求满足条件的所有集合的最大价值。\(n,k \le 2500\)。Solution: 注意到那一个奇妙的式…

QQBot Cqhttp服务器配置

配这个一开始的时候还有点蒙,在这里记录一下。 看到QQ指令机器人,心血来潮打算自己也下个cqhttp配一配,然后就有了这篇博客。 QQ指令机器人的历史还是相当古老的。10年左右QQ推出了webQQ,基于http协议下的通信特别方便进行抓包篡改,于是就有了酷Q机器人这个小东西。 而cqh…

阿里云API网关 产品的使用笔记

阿里云的产品虽多&#xff0c;还是一如既往的一用一个看不懂&#xff0c;该模块的文档依旧保持“稳定”发挥&#xff0c;磕了半天才全部跑通。 用阿里云API网关的原因是&#xff0c;在Agent中写插件调用API的时候&#xff0c;需要使用Https协议&#xff0c;又嫌搞备案、证书等事…

26.统一网关Gateway

网关的功能 1.身份认证&#xff0c;权限的校验。 2.服务的路由&#xff0c;负载均衡。用户请求被分配到哪一个微服务。一个微服务可以有多个实例&#xff0c;所以使用负载均衡。 3.请求限流。 springcloud网关实现有两种&#xff1a;gateway, zuul zuul是基于servlet实现的…

SVN--基本原理与使用(超详细)

目录 一、SVN概述二、SVN服务端软件安装三、SVN服务端配置四、SVN客户端软件安装与使用五、SVN三大指令六、SVN图标集与忽略功能6.1 图标集6.2 忽略功能 七、SVN版本回退八、SVN版本冲突九、SVN配置多仓库与权限控制9.1 配置多仓库9.2 权限控制 十、服务配置与管理十一、模拟真…

广泛广泛广泛广泛股份该股刚刚

给贵方贵方贵方广泛广泛风格

golang 官方代码 汇总

go1.22.2 --序章 golang 官网的 代码汇总,汇总到一起,方便查阅。注,如有侵权,请通知我 处理🥂。go.dev 首页 同 https://golang.google.cn 首页。 说明,go.dev 访问时,可能存在访问失败的情况。搜索:Try Go package mainimport "fmt"func main() {fmt.Prin…

德国工业4.0和智能制造

智能制造是当前制造业升级的重要方向,本质是软件定义的工业技术和生产关系。世界工业大国在10年前就筹谋规划,美国提出了“工业互联网”,中国提出了“中国制造2025”,德国则提出了“工业4.0”。本文以德国工业4.0为例,分析智能制造的深刻内涵。 01 从工业1.0到工业4.0 人类…

kube-prometheus部署到 k8s 集群

文章目录 **修改镜像地址****访问配置****修改 Prometheus 的 service****修改 Grafana 的 service****修改 Alertmanager 的 service****安装****Prometheus验证****Alertmanager验证****Grafana验证****卸载****Grafana显示时间问题** 或者配置ingress添加ingress访问grafana…

HTML5实用大全(Part.2)

引言&#xff1a; 哈喽&#xff0c;各位小伙伴们大家好呀&#xff0c;学习了上一篇关于HTML5的文章后&#xff0c;你是否对于入门HTML5有了一定的基础了呢&#xff0c;本篇博客我们将继续学习HTML5的不同标签&#xff0c;跟上队伍&#xff0c;准备出发咯&#xff01; 1.标签之…

Python 植物大战僵尸

文章目录 效果图项目结构实现思路源代码 效果图 项目结构 实现思路 下面是代码的实现思路&#xff1a; 导入必要的库和模块&#xff1a;首先&#xff0c;我们导入了Python的os、time库以及pygame库&#xff0c;还有植物大战僵尸游戏中用到的各个植物和僵尸的类。 初始化游戏和…

微服务总览

微服务保护 微服务总览 微服务总览 接入层&#xff1a;反向代理功能&#xff0c;可以将用户域名访问的地址以负载均衡的方式代理到网关地址&#xff0c;并且并发能力非常高&#xff0c;并且会采用主备nginx的方式防止nginx寄了&#xff0c;备份nginx监控主nginx状态&#xff0c…

MLX90640热像仪测温采集 科研实验 非接触测温

​ 1、描述 这是一款小巧迷你科研实验测温热成像多功能热像记录仪,模块带一路ALARM报警信号2.8v电平,一路IIC SDA SCL接口,一路TTL串口TXD RXD接口,自带USB串口芯片,TYPEC直插电脑显示串口,搭配多功能电脑软件,温度数据看得清楚,是家庭、实验室、工业等不可缺少的工具。…

【JVM】Java工具(Arthas,APM,Java Agent,JMX)

Java工具 常见的Java工具有以下几类&#xff1a; 1、诊断类工具&#xff0c;如Arthas、VisualVM等。 2、开发类工具&#xff0c;如Idea、Eclipse。 3、APM应用性能监测工具&#xff0c;如Skywalking、Zipkin等。 4、热部署工具&#xff0c;如Jrebel等。 Arthas中 Java Ag…

基于.NET WinForms 数据的CURD实现

开发工具 VS 2022 C#&#xff0c;数据库MS SQL SERVER 2019 1.WinForms界面 2.使用SqlDataApater DataSet DataGridView 读取数据 private void ReadData() {//数据库连接串string strConn "Data Source127.0.0.1;Initial CatalogTEST;Persist Security InfoTrue;Us…

ABAP-MB56字段增强

MB56增强字段,效果如下: 实施步骤:1、在显示结构ALV_TREE_CHVW中附加所需要增强字段 2、TCODE:SE19 实施新BADI :ES_BATCH_WHERE_USED_LIST,在方法COMPLETE_BWUL_MAINTAIN下补充字段相应取数逻辑即可,显示数据存储于内表CT_SHADOW。

TCP协议在物联网中的实战

一、TCP协议介绍 网上对TCP协议介绍众多&#xff0c;本人按照自己的理解简单介绍一下。 TCP&#xff08;Transmission Control Protocol&#xff0c; 传输控制协议&#xff09;是一种面向连接的、可靠的、基于字节流的传输控制层通信协议。 1.1 协议机制 1.1.1 三次握手 &…

FLIR LEPTON3.5 热像仪wifi 科研实验测温采集仪

​点击查看详情!点击查看详情点击查看详情点击查看详情点击查看详情点击查看详情点击查看详情点击查看详情点击查看详情点击查看详情点击查看详情点击查看详情点击查看详情点击查看详情点击查看详情 1、描述 这是一款桌面科研实验测温热成像多功能热像记录仪,小巧轻便,机身标…

jsp校园商城派送系统Myeclipse开发mysql数据库web结构java编程计算机网页项目

一、源码特点 JSP 校园商城派送系统 是一套完善的web设计系统&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统采用serlvetdaobean mvc 模式&#xff0c;系统主要采用B/S模式 开发。开发环境为TOMCAT7.0,Myeclipse8.…