当前位置: 首页 > news >正文

使用DockerCompose部署服务

由于格式或图片解析问题,为了更好的阅读体验,可前往 阅读原文

以前我们总是用命令管理每个容器的启动、停止等等,若有多个容器时可能还存在启动优先级的问题,那就要等到指定的容器启动后再去启动另一个容器,对于整体的应用服务管理极其不方便,简单的docker run命令更适合初学者或者调试使用, docker提供docker compose来解决多容器部署。

Docker Compose是Docker官方提供的一个工具,它允许用户通过配置文件定义和运行多个 Docker 容器,以便更轻松地管理 Docker 应用程序的部署和运行。Docker Compose 可以让用户在单个主机上运行多个容器,也可以在多个主机上运行同一组容器,并且可以实现容器之间的相互通信和协作。

优势

相比启动单个容器,使用docker compose有以下优势:

  • 简化多容器应用部署: Docker Compose 可以将多个容器的部署、启动、停止、删除等操作集成到一起,以便简化多容器应用的部署和管理。
  • 统一配置管理: Docker Compose 允许用户使用 YAML 文件定义容器的配置,从而实现容器的统一管理。这使得在多容器应用中对于环境变量、网络设置、端口映射等配置的管理更加方便和统一。
  • 容器之间的通信: Docker Compose 允许用户自定义容器之间通信的网络,容器之间可以直接通信,方便了应用程序的开发和部署。
  • 可重复性和可移植性: 使用 Docker Compose 可以将应用程序的部署过程进行标准化,降低了部署过程中的错误率。同时,Docker Compose 配置文件可以在不同的环境中使用,从而实现应用程序的可移植性。
  • 管理多个环境: Docker Compose 可以对不同的环境进行管理,比如开发环境、测试环境和生产环境,从而方便了应用程序的开发和测试。

初识DockerCompose

Docker Compose 配置文件是一个 YAML 格式的文件,用于定义多个 Docker 容器的配置和关系。下面是一个简单的 Docker Compose 配置文件示例:

version: '3'
services:web:build:context: .dockerfile: Dockerfile.webports:- "8080:80"depends_on:- redisredis:image: "redis:alpine"

在这个示例配置文件中,version 字段指定了 Docker Compose 的版本号,services 字段用于定义多个 Docker 容器。在 services 字段中,每个容器都是一个子字段,其键名是容器的名称,其值是一个包含容器配置的键值对。

在示例配置文件中,定义了两个容器 web 和 redis,其中:

  1. web 容器使用本地 Dockerfile.web 配置文件构建镜像,将容器的 80 端口映射到主机的 8080 端口,其依赖redis的启动后才会启动自己
  2. redis 容器使用 Redis 官方镜像,并使用 Alpine 版本,没有指定其他特殊的配置。

从以上可以看出docker compose是将整个应用的所有容器全部写在了同一个配置文件中,其也会自动管理容器的启动先后顺序,而对于配置文件的管理也更加方便,接下来看下其常用语法。

语法

docker compose的配置是个yaml文件,在配置文件中容器将作为服务部署,docker compose帮我们统一管理这些服务,包括镜像、启动顺序、网络、数据卷、端口、重启策略等等。配置中services、networks、volumes等这些都可以在最顶端定义表示需要创建的全局network、volume等等。

services

在Docker Compose中,services是定义容器的基本单位

语法:

services:<service_name>:<service_config>

其中,<service_name>是服务名称,可以任意命名,但建议使用有意义的名称。<service_config>是服务的配置信息,包含了运行服务所需的所有信息,如镜像、容器名称、端口映射、环境变量等。

例子:

version: '3'
services:web:image: nginxports:- "8080:80"

image

services中的每个容器都是一个服务,其都会包含镜像文件。镜像可以指定第三方的,也可以使用本地Dockerfile进行构建

语法:

# 省略其他...
<service_config># 使用第三方image: nginx:alpine# 本地构建build:context: .dockerfile: Dockerfile

你可以在容器中通过image指定第三方的镜像文件,也可以使用build来进行本地镜像的构建,build可以简写成build: your dir不需要指定上下文等等,其默认会使用当前目录下的Dockerfile文件进行构建

ports、networks、volumes

除了容器中的镜像外,其他如:端口、数据卷、网络其实都是类似,并且和直接用docker run启动容器时使用差不多

语法:

# 省略其他...
<service_config>image: nginx:alpine# 端口ports:- "<host_port>:<container_port>/<protocol>"- "1000"- "8080:80"- "443:443/tcp"# 数据卷volumes:- myvolume:/etc/data- /root/html:/etc/nginx/html# 网络networks:- mynetwork# 定义数据卷
volumes:myvolume:# 定义网络
networks:mynetwork:

上面展示了端口、数据卷、网络的基本配置:

  • 端口:在容器中使用ports来定义端口的的映射,语法如上,当仅指定一个端口是<container_port>,这种就是告诉外面容器内使用了1000端口,你可以进行映射,实际上并没有和宿主机进行映射而是一种定义,可dockerfile中的expose类似;使用<host_port>:<container_port>时前面表示宿主机端口,后者表示容器端口,二者进行映射;除此还支持协议,直接在最后加上/<protocol>即可
  • 数据卷:容器中使用volumes列表进行卷的映射,你可以直接使用宿主机的目录进行映射,也可以使用docker创建的卷,并且你还可以使用没有创建的数据卷,但同时你必须在顶级定义指定的数据卷,这样docker会帮你自动创建数据卷
  • 网络:使用网络和数据卷类似,当使用不存在的自定义的网络时,也需要在顶级进行定义

depends_on

使用depends_on字段来定义容器之间的依赖关系,以确保在启动容器时,必须先启动其所依赖的容器

语法:

depends_on:- <service_name>- <service_name2>...

其中,<service_name>是所依赖的服务名称,可以是单个服务或多个服务

例子:

version: '3'
services:db:image: mysqlweb:image: my-web-appdepends_on:- db

在这个示例中,我们定义了两个服务:一个名为db的服务,使用了mysql镜像;一个名为web的服务,使用了自定义的web应用镜像,并在depends_on字段中指定了db服务,表示web服务依赖于db服务。

在启动这个Docker Compose文件时,Docker会先启动db服务,然后再启动web服务,以确保web服务可以连接到db服务并正常运行。

environment

可以使用environment字段来设置容器中的环境变量,其与docker run -e、Dockerfile中定义的ENV类似

语法:

environment:- <key>=<value>- <key2>=<value2>...

其中,<key>是环境变量的名称,<value>是环境变量的值。可以设置多个环境变量,每个环境变量之间用-分隔

例子:

version: '3'
services:web:image: my-web-appenvironment:MYSQL_HOST: dbMYSQL_USER: userMYSQL_PASSWORD: password

在这个示例中,我们定义了一个名为web的服务,使用了自定义的web应用镜像,并设置了三个环境变量:MYSQL_HOST、MYSQL_USER和MYSQL_PASSWORD。这些环境变量可以在容器内部使用,例如在web应用的配置文件中。

需要注意的是,如果在Docker Compose文件中定义了环境变量,而在Dockerfile中也定义了同名的环境变量,那么Docker Compose文件中的环境变量会覆盖Dockerfile中的环境变量。

除此之外还可以使用.env文件或命令行参数来设置环境变量。这样可以避免将敏感信息硬编码到Docker Compose文件中
:::warning 注意
Docker Compose文件中定义的环境变量会覆盖.env文件中的同名环境变量
:::

.env配置文件示例:

MYSQL_HOST=db
MYSQL_USER=user
MYSQL_PASSWORD=password

compose文件配置:

version: '3'
services:web:image: my-web-appenvironment:MYSQL_HOST: ${MYSQL_HOST}MYSQL_USER: ${MYSQL_USER}MYSQL_PASSWORD: ${MYSQL_PASSWORD}

使用docker-compose命令的--env-file参数来指定环境变量文件。

restart

使用restart字段来定义容器的重启策略,在容器异常退出或停止时,自动重新启动容器

语法:

restart: <restart_policy>

其中,<restart_policy>是重启策略,可以是以下几种之一:

  • no:不重启容器,默认值
  • always:总是重启容器,除非手动停止容器
  • on-failure:在容器异常退出时重启容器,可以使用-t选项指定重启次数
  • unless-stopped:除非手动停止容器,否则总是重启容器

例子:

version: '3'
services:web:image: my-web-apprestart: always

在这个示例中,我们定义了一个名为web的服务,使用了自定义的web应用镜像,并设置了重启策略为always,表示总是重启容器。需要注意的是,restart字段只会在容器异常退出或停止时才会生效,而不会影响容器的启动顺序或依赖关系。

更多

关于docker compose配置的讲解就到这里,其配置和docker run很相似,关于更多配置可以查看👉官方文档

命令

有了配置文件后可以通过命令行对整个服务进行发布、构建、删除等等

docker compose [-f <arg>...] [--profile <name>...] [options] [COMMAND] [ARGS...]

build

docker compose build [OPTIONS]

用于构建Docker镜像,可以通过一些参数来自定义构建过程:

  • --no-cache:禁止使用缓存进行构建。如果使用了缓存,Docker会在构建镜像时尽可能地复用之前构建过的镜像层,以提高构建速度。使用–no-cache选项可以强制Docker从头开始构建镜像
  • --pull:在构建镜像之前,拉取最新的基础镜像。如果基础镜像版本已经过时,使用–pull选项可以确保构建的镜像使用最新的基础镜像
  • --parallel:并行构建多个Docker镜像。如果同时构建多个镜像,可以使用–parallel选项加快构建速度

up

docker compose up [OPTIONS]

用于启动Docker Compose定义的所有服务,可以通过一些参数来自定义启动过程:

  • -d:在后台模式下启动服务。如果不使用-d选项,则docker-compose up命令会在前台模式下启动服务,并输出日志信息
  • --build:在启动服务之前,自动构建镜像。如果服务的镜像已经存在,使用–build选项可以强制重新构建镜像
  • --scale:扩展指定服务的容器数量。使用–scale选项可以根据实际需要动态地扩展服务的容器数量。

stop

docker compose stop [OPTIONS] [SERVICE...]

用于停止由Docker Compose定义的服务的容器,不会删除容器、网络和卷:

  • -t:停止服务的超时时间。使用-t选项可以指定停止服务的超时时间,单位为秒
  • SERVICE:指定要停止的服务,如果只需要停止一个或几个服务的容器,可以在stop命令后面指定要停止的服务名

rm

docker compose rm [OPTIONS]

用于停止并删除由Docker Compose定义的服务的容器、网络和卷:

  • -f:强制停止并删除服务的容器、网络和卷。如果服务的容器正在运行或者网络和卷正在被使用,使用-f选项可以强制停止并删除它们
  • --stop:停止服务的容器,但不删除它们。如果只想停止服务的容器而不删除它们,可以使用–stop选项

kill

docker compose kill [OPTIONS] [SERVICE...]

用于强制停止由Docker Compose定义的服务的容器:

  • -s:指定信号量。使用-s选项可以指定要发送的信号量

更多

更多关于docker compose命令使用方法参考👉官方文档

实战

本次将部署两个容器服务:前端和后端,其中前端使用nginx进行部署,后端使用nodejs作为api服务,将nginx端口映射到宿主机,然后通过宿主机IP:Port形式访问前端页面,页面中请求后端服务,点击这里👉下载示例源码。

  1. 创建前端页面静态文件index.html:页面包括一个输入框和一个按钮,点击发送请求到/api,这里会请求nginx,nginx做反向代理到nodejs
    <input type="text">
    <button>发送</button>
    <script>const btn = document.querySelector("button")const input = document.querySelector("input")btn.addEventListener("click", () => {fetch(`/api?q=${input.value}`, {mode: "cors",method: "get"}).then(res => res.json()).then(res => console.log(res))})
    </script>
    
  2. 创建default.conf进行nginx的配置与转发:当访问/是返回前端页面,页面中的请求/api会被代理到compose-nodejs:10010,这里的compose-nodejs是nodejs的服务名,只有当compose中的容器使用同一个网络时才可以使用服务名的形式访问
    upstream backend {server compose-nodejs:10010;
    }
    server {listen 80;server_name localhost;# 首页静态页面location / {root /usr/share/nginx/html;index index.html index.htm;}# 反向代理到 nodejslocation /api {# 允许跨域add_header Access-Control-Allow-Origin $http_origin always;add_header Access-Control-Allow-Credentials true always;add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS';add_header Access-Control-Allow-Headers 'content-type';if ($request_method = "OPTIONS") {return 204;}proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forward-For $proxy_add_x_forwarded_for;proxy_set_header Host $http_host;proxy_set_header X-Nginx-Proxy true;proxy_pass http://backend;}
    }
    
  3. 创建nodejs作为后端服务:nodejs使用express作为http服务,并监听10010端口,当访问时返回code和时间戳
    const express = require("express");
    const app = express();
    app.use((req, res) => {console.log(req.url);res.json({code: 200,date: +new Date(),});
    });
    app.listen(10010, () => console.log("server is runnning on port 10010"));
    
  4. 创建docker-compose.yml配置文件:里面包含了nginx和nodejs容器,两者都是用本地的Dockerfile进行构建镜像,nginx映射宿主机10010端口到容器的80端口,并且两者的启动顺序为compose-nodejscompose-nginx,使用相同的网络compose
version: "3"
services:compose-nginx:build:context: .dockerfile: Dockerfile.nginxcontainer_name: compose-nginxports:- "10010:80"depends_on:- compose-nodejsnetworks:- composecompose-nodejs:build:context: .dockerfile: Dockerfile.nodejscontainer_name: compose-nodejsnetworks:- composenetworks:compose:
  1. 创建镜像构建文件:分别使用Dockerfile.nginxDockerfile.nodejs来构建nginx和nodejs镜像,具体配置文件如下

    Dockerfile.nginx

    FROM nginx:alpine
    COPY index.html /usr/share/nginx/html
    COPY default.conf /etc/nginx/conf.d
    EXPOSE 80
    ENTRYPOINT [ "nginx", "-g", "daemon off;" ]
    

    Dockerfile.nodejs

    FROM node:alpine
    WORKDIR /app
    COPY package.json .
    RUN npm install
    COPY server.js .
    EXPOSE 10010
    ENTRYPOINT [ "npm", "run", "server.js" ]
    
  2. 启动整体服务:

    docker compose up -d
    

由于格式或图片解析问题,为了更好的阅读体验,可前往 阅读原文

参考文档

  • Compose file build reference
  • The Compose file
  • Version and name top-level element
  • Services top-level element
  • Networks top-level element
  • Volumes top-level element
  • Configs top-level element
  • Secrets top-level element
  • Command line Guides
  • NodeJS Guides

由于格式或图片解析问题,为了更好的阅读体验,可前往 阅读原文

相关文章:

使用DockerCompose部署服务

由于格式或图片解析问题&#xff0c;为了更好的阅读体验&#xff0c;可前往 阅读原文 以前我们总是用命令管理每个容器的启动、停止等等&#xff0c;若有多个容器时可能还存在启动优先级的问题&#xff0c;那就要等到指定的容器启动后再去启动另一个容器&#xff0c;对于整体的…...

第P5周-Pytorch实现运动鞋品牌识别

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 具体实现 &#xff08;一&#xff09;环境 语言环境&#xff1a;Python 3.10 编 译 器: PyCharm 框 架: Pytorch &#xff08;二&#xff09;具体步骤 时间…...

react-quill 富文本组件编写和应用

index.tsx文件 import React, { useRef, useState } from react; import { Modal, Button } from antd; import RichEditor from ./RichEditor;const AnchorTouchHistory: React.FC () > {const editorRef useRef<any>(null);const [isModalVisible, setIsModalVis…...

因泰立科技激光车检器,高速公路的精准流量统计专家

高速公路自由流门架激光车检器&#xff0c;专为解决高速公路交通管理中的各种挑战而设计。该产品采用先进的激光测量技术&#xff0c;能够对动态通过的车辆进行高速动态扫描&#xff0c;通过测量物体表面点的反射距离&#xff0c;迅速换算成三维空间坐标&#xff0c;实现对车辆…...

windows中,git bash 使用conda命令

1、首先在Anaconda的安装路径如/Anaconda3/Scripts下&#xff0c;打开git bash窗口&#xff0c;然后输入下面的命令。 ./conda init bash 运行之后&#xff0c;会在用户目录下面生成.bash_profile文件&#xff0c;文件内容如下&#xff1a; # >>> conda initialize…...

《繁星路》V1.8.3(Build16632266)官方中文学习版

《繁星路》官方中文版https://pan.xunlei.com/s/VODae2_2Z3QyMF02I5y321uHA1?pwdqgsh# 作为一款星际模拟游戏&#xff0c;完美融合了硬科幻元素与基地建设玩法&#xff0c;体验改造行星的恢弘与壮阔。化身人工意识AMI&#xff0c;遵照基本指示推进火星改造的各项工作&#xf…...

vscode 无法使用npm, cmd命令行窗口可以正常执行

解决方法&#xff1a; 执行命令获得命令的位置 get-command npm 得到如下 然后删除或者修改 npm.ps1文件 让其不能使用就行。然后重启vscode即可。 pnpm 同理即可 另外加速源 国内镜像源&#xff08;淘宝&#xff09;&#xff1a; npm config set registry https://regist…...

html + css 顶部滚动通知栏示例

前言 在现代网页设计中&#xff0c;一个吸引人的顶部滚动通知栏不仅能够有效传达重要信息&#xff0c;还能提升用户体验。通过使用HTML和CSS&#xff0c;我们可以创建既美观又功能强大的组件&#xff0c;这些组件可以在不影响网站整体性能的情况下提供实时更新或紧急通知。 本…...

阿里mod_asr3.0集成webrtc静音算法

alibabacloud-nls-cpp-sdk-master 先到阿里官网下载nls库的源代码&#xff0c;编译生成对应的库文件和头文件。 我编译的放到了以下目录。 /home/jp/2025/alibabacloud-nls-cpp-sdk-master/build/install/NlsSdk3.X_LINUX/include/ /home/jp/2025/alibabacloud-nls-cpp-sdk-…...

【MySQL】表的基本查询

文章目录 1. 插入 insert1.1 单行插入2.2 多行插入2.3 插入 否则更新2.4 替换 2. 查找 select2.1 select 列2.2 where 条件2.3 order by 排序2.4 筛选分页结果 3. 更新 update4. 删除 delete5. 截断 truncate6. 插入查询结果7. 聚合函数8. group by子句 我们经常说数据库就是CR…...

2025-01-07日SSH钓鱼日志

今天发现了挖矿程序部署脚本&#xff0c;可针对性排查。 时间来源类型详情20:16:08146.190.50.206:36694CHANNEL_REQUEST通道&#xff1a;1&#xff0c;类型&#xff1a;exec(command:uname -a)20:16:08146.190.50.206:36694OPEN_CHANNEL通道&#xff1a;1&#xff0c;类型&am…...

C++语言的计算机基础

C语言的计算机基础 引言 C是一种通用的编程语言&#xff0c;由Bjarne Stroustrup于1979年开发。它在C语言的基础上增加了面向对象的特性&#xff0c;使得程序设计变得更加灵活和高效。C广泛应用于系统软件、游戏开发、实时仿真等领域。本文将深入探讨C语言的基础知识&#xf…...

怎么把word试题转成excel?

在教育行业、学校管理以及在线学习平台中&#xff0c;试题库的高效管理是一项核心任务。许多教育工作者和系统开发人员常常面临将 Word 中的试题批量导入 Excel 的需求。本文将详细介绍如何快速将试题从 Word 转换为 Excel&#xff0c;帮助您轻松解决繁琐的数据整理问题&#x…...

在线商城系统设计与开发-代码(源码+数据库+文档)

亲测完美运行带论文&#xff1a;文末获取源码 文章目录 项目简介&#xff08;论文摘要&#xff09;运行视频包含的文件列表&#xff08;含论文&#xff09;前端运行截图后端运行截图 项目简介&#xff08;论文摘要&#xff09; 现代经济快节奏发展以及不断完善升级的信息化技术…...

HCIE-day10-ISIS

ISIS ISIS&#xff08;Intermediate System-to-Intermediate System&#xff09;中间系统到中间系统&#xff0c;属于IGP&#xff08;内部网关协议&#xff09;&#xff1b;是一种链路状态协议&#xff0c;使用最短路径优先SPF算法进行路由计算&#xff0c;与ospf协议有很多相…...

解决SSH连接时遇到的“远程主机身份验证已更改 (WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!)”警告

文章目录 引言警告信息解读造成原因解决方案 引言 在使用SSH协议进行远程服务器管理的过程中&#xff0c;可能会遇到这样的情况&#xff1a;当尝试通过SSH连接到某个远程主机时&#xff0c;终端突然弹出一条警告信息&#xff0c;提示“远程主机身份验证已更改”。 警告信息解…...

C语言的循环实现

C语言的循环实现 C语言是一种功能强大且广泛使用的编程语言&#xff0c;其语法简单易懂&#xff0c;适用于系统软件、嵌入式系统和高性能应用程序等多个领域。在C语言中&#xff0c;控制程序执行流程的基本结构之一就是循环。循环允许程序在满足某个条件的情况下重复执行一段代…...

如何使用vue引入three.js

在 Vue.js 项目中引入和使用 Three.js 是一个常见的需求&#xff0c;Three.js 是一个用于在浏览器中创建和显示动画 3D 计算机图形的 JavaScript 库。以下是一个基本的示例&#xff0c;展示如何在 Vue 项目中引入和使用 Three.js。 1. 创建 Vue 项目 如果你还没有一个 Vue 项…...

【C++】深入理解迭代器(Iterator)

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 &#x1f4af;前言&#x1f4af;什么是迭代器&#xff1f;迭代器与指针的比较 &#x1f4af;std::string 中的迭代器示例代码与图示分析运行结果&#xff1a;图示说明&#xff1a; 小提示 &#x1f4af;正…...

微信小程序实现长按录音,点击播放等功能,CSS实现语音录制动画效果

有一个需求需要在微信小程序上实现一个长按时进行语音录制&#xff0c;录制时间最大为60秒&#xff0c;录制完成后&#xff0c;可点击播放&#xff0c;播放时再次点击停止播放&#xff0c;可以反复录制&#xff0c;新录制的语音把之前的语音覆盖掉&#xff0c;也可以主动长按删…...

QPS和TPS 的区别是什么?QPS 大了会有什么问题,怎么解决?

QPS 和 TPS 的区别是什么&#xff1f;QPS 大了会有什么问题&#xff0c;怎么解决&#xff1f; QPS&#xff08;Queries Per Second&#xff09;和 TPS&#xff08;Transactions Per Second&#xff09;都是衡量系统性能的重要指标&#xff0c;尤其是在 Web 服务、数据库和分布…...

小程序开发-页面事件之上拉触底实战案例

&#x1f3a5; 作者简介&#xff1a; CSDN\阿里云\腾讯云\华为云开发社区优质创作者&#xff0c;专注分享大数据、Python、数据库、人工智能等领域的优质内容 &#x1f338;个人主页&#xff1a; 长风清留杨的博客 &#x1f343;形式准则&#xff1a; 无论成就大小&#xff0c;…...

[读书日志]从零开始学习Chisel 第六篇:Scala面向对象编程——特质(敏捷硬件开发语言Chisel与数字系统设计)

3.4特质 3.4.1什么是特质 特质使用trait开头&#xff0c;它与单例对象很像&#xff0c;两者都不能有输入参数&#xff0c;但单例对象是具体的&#xff0c;特质是抽象的。两者都不能用new实例化&#xff0c;类&#xff0c;单例对象&#xff0c;特质三者内部都可以包含字段和方…...

导航技术的分类

导航技术可以根据不同的分类标准进行划分&#xff0c;以下是从不同角度对导航技术的分类&#xff1a; 一、按导航信息获取原理分类 无线电导航&#xff1a;利用无线电波的传播特性来测定运动体的位置、速度等导航参数。常见的无线电导航系统包括罗兰-C、奥米加、台卡等。卫星…...

学习标准库atomic_base.h中typedef enum memory_order

1、背景 在多线程编程中&#xff0c;特别是在使用原子操作时&#xff0c;内存顺序&#xff08;Memory Order&#xff09;是一个关键的概念。在C11及其之后的标准中&#xff0c;memory_order 枚举类型&#xff08;typedef enum memory_order&#xff09;用于控制原子操作的内存…...

git push -f 指定分支

要将本地代码推送到指定的远程分支&#xff0c;你可以使用以下步骤和命令&#xff1a; 确认远程仓库&#xff1a; 确保你的本地仓库已经与远程仓库关联。你可以使用以下命令查看当前的远程仓库状态&#xff1a; git remote -v查看本地分支&#xff1a; 使用命令查看当前存在的本…...

ADO.NET知识总结3---SqlCommand命令对象

目录 4.1 SqlCommand对象介绍 4.2 SqlCommand创建 4.3 Command执行方法 4.1 SqlCommand对象介绍 SqlCommand&#xff1a;Ado.Net中执行数据库命令的对象。 它对SQLServer数据库执行一个T-SQL语句或存储过程。 重要属性: Connection: SqlCommand对象使用的SqlConnection对…...

CANopen转EtherCAT网关连接伺服驱动

在现代工业自动化领域&#xff0c;CANopen和EtherCAT是两种常见的通信协议&#xff0c;各自在不同的应用场景中发挥着重要作用。然而&#xff0c;随着工业自动化系统的日益复杂化&#xff0c;不同设备间的通信需求也变得多样化。因此&#xff0c;如何实现不同协议设备之间的无缝…...

前端基础技术全解析:从HTML前端基础标签语言开始,逐步深入CSS样式修饰、JavaScript脚本控制、Ajax异步通信以及WebSocket持久通信

目录 前言&#xff1a; 1.前端技术html简单了解&#xff1a; 1.1HTML代码是由标签构成的。 1.2.HTML 文件基本结构 1.3.HTML 常见标签 标题标签: 段落标签: p 文本格式化标签 图片标签&#xff1a; 超链接标签: a 测试代码&#xff1a; 展示效果&#xff1a; 表单…...

试用kotlin multiplatform

目录 多平台框架简介 示例工程建立与运行 常用库 桌面平台遇到的一些问题 使用总结 多平台框架简介 多平台的框架不少,flutter,rust,每一个都是优点明显,缺点也明显. flutter的桌面端控件少,质量不一.dart语言丑陋又慢.我不喜欢它. rust,桌面gui不成熟,成熟一些的slint…...

Scratch023-(沙漠变绿洲)

提示&#xff1a; 知识回顾&#xff1a; 1、画笔的各个属性 2、“将笔的颜色设为”积木 3、“将笔的颜色增加”积木 文章目录 前言一、案例展示二、功能分析三、步骤拆解1.背景角色和画笔的初始化&#xff08;1&#xff09;初始化画笔2、一起绘制一个小雨滴3、绘制多个随机的小…...

【Linux】深入理解文件系统(超详细)

目录 一.磁盘 1-1 磁盘、服务器、机柜、机房 &#x1f4cc;补充&#xff1a; &#x1f4cc;通常网络中用高低电平&#xff0c;磁盘中用磁化方向来表示。以下是具体说明&#xff1a; &#x1f4cc;如果有一块磁盘要进行销毁该怎么办&#xff1f; 1-2 磁盘存储结构 ​编辑…...

基于 Apache Commons Pool 实现的 gRPC 连接池管理类 GrpcChannelPool 性能分析与优化

基于 Apache Commons Pool 实现的 gRPC 连接池管理类 GrpcChannelPool 性能分析与优化 1. 输出关键信息的代码示例 日志记录方法 使用以下代码记录连接池的关键信息&#xff0c;帮助分析连接池的状态和性能瓶颈&#xff1a; import org.apache.commons.pool2.impl.GenericO…...

微信小程序实现登录注册

文章目录 1. 官方文档教程2. 注册实现3. 登录实现4. 关于作者其它项目视频教程介绍 1. 官方文档教程 https://developers.weixin.qq.com/miniprogram/dev/framework/路由跳转的几种方式&#xff1a; https://developers.weixin.qq.com/miniprogram/dev/api/route/wx.switchTab…...

网络安全-kail linux 网络配置(基础篇)

一、网络配置 1.查看网络IP地址&#xff0c; 我的kail&#xff1a;192.168.15.128 使用ifconfig查看kail网络连接情况&#xff0c;ip地址情况 又复制了一台kail计算机的IP地址。 再看一下windows本机&#xff1a;使用ipconfig进行查看&#xff1a; 再看一下虚拟机上的win7I…...

Lua语言的软件工程

Lua语言的软件工程 引言 在软件工程领域&#xff0c;编程语言的选择对项目的成功与否有着至关重要的影响。Lua语言作为一种轻量级、高效、可扩展的脚本语言&#xff0c;近年来在游戏开发、嵌入式系统以及其他高性能应用程序中得到了广泛应用。本文将深入探讨Lua语言的特点、优…...

【Rust自学】11.4. 用should_panic检查恐慌

喜欢的话别忘了点赞、收藏加关注哦&#xff08;加关注即可阅读全文&#xff09;&#xff0c;对接下来的教程有兴趣的可以关注专栏。谢谢喵&#xff01;(&#xff65;ω&#xff65;) 11.4.1. 验证错误处理的情况 测试函数出了验证代码的返回值是否正确&#xff0c;还需要验证…...

基于深度模型的印章检测(c++)

效果展示&#xff1a; 有点&#xff1a; &#xff08;1&#xff09;快速&#xff08;几十毫秒级别&#xff09;&#xff1b; &#xff08;2&#xff09;精度高&#xff1b; int main() {std::string imagePath;// 提示用户输入图像路径std::cout << "请输入图像路…...

C#Struct堆栈

Struct若其内部含有堆对象&#xff0c;Struct的该对象放在堆上&#xff1b; Struct当做参数传递时&#xff0c;其堆属性作为引用传递&#xff0c;值属性还是作为值传递&#xff1b; struct TS { public int[] t1; public int t2; } public void TF1(TS t) { int[] t1 t.t1; …...

STM32之一种双通路CAN总线消息备份冗余处理方法(十三)

STM32F407 系列文章 - Dual-CANBus-ProMethod&#xff08;十三&#xff09; 目录 前言 一、现状分析 二、解决思路 1.应用场景网络结构图 2.数据发送流程 3.数据接收流程 4.用到的模块 1.CAN网络速率及时间片分配 2.CAN网络消息ID组成 3.设备节点定义 4.数据格式说明…...

深入学习RabbitMQ的Direct Exchange(直连交换机)

RabbitMQ作为一种高性能的消息中间件&#xff0c;在分布式系统中扮演着重要角色。它提供了多种消息传递模式&#xff0c;其中Direct Exchange&#xff08;直连交换机&#xff09;是最基础且常用的一种。本文将深入介绍Direct Exchange的原理、应用场景、配置方法以及实践案例&a…...

客户端 ORA-12537: TNS: 连接已关闭

现象&#xff1a; 1、双节点数据库. 2、客户端连接 db1 正常 3、客户端连接db2 显示&#xff1a;ORA-12537: TNS: 连接已关闭 4、数据库正常启动 5、lsnrctl status 检查 监听正常 6、lsnrctl stop/start 重启监听正常 过程&#xff1a; 冲浪 查看网友的解决方法。 连接&…...

.net开发环境安装配置以及程序发布 详细教程

文章目录 一、安装visual studio1.1推荐win10操作系统1.2推荐vs20221.3选择工作负载 二、新建基于.net的winform应用程序2.1为什么要.net 2.22.2.1 选择Window窗体应用 三、发布.net应用 一、安装visual studio 1.1推荐win10操作系统 1.2推荐vs2022 社区版、专业版、企业版都…...

盛最多水的容器

一、题目 给定一个长度为n的整数数组height。有n条垂线&#xff0c;第i条线的两个端点是(i, 0)和(i, height[i])。找出其中的两条线&#xff0c;使得它们与x轴共同构成的容器可以容纳最多的水。返回容器可以储存的最大水量。也就是求x轴与y轴的面积。 说明&#xff1a;你不能倾…...

spring boot解决swagger中的v2/api-docs泄露漏洞

在配置文件中添加以下配置 #解决/v2/api-docs泄露漏洞 springfox:documentation:swagger-ui:enabled: falseauto-startup: false 处理前&#xff1a; 处理后&#xff1a;...

MySQL和Hive中的行转列、列转行

水善利万物而不争&#xff0c;处众人之所恶&#xff0c;故几于道&#x1f4a6; 文章目录 MySQL1.行转列2.列转行 Hive1.行转列2.列转行(1)侧窗(2)union MySQL 1.行转列 把多行转成列。直接group&#xff0c;sum(if()) 2.列转行 Hive 1.行转列 select name,sum(if(kmshuxu…...

【关于 vite 使用plugin-legacy兼容低版本浏览器仍出现的问题的情况】

项目使用了vitevue3ts的方案&#xff0c;采用plugin-legacybabel适配低版本浏览器 在开发工作中&#xff0c;项目使用了vitevue3ts的方案&#xff0c;但是需要适配低版本浏览器。首先使用了vitejs/plugin-legacy插件&#xff0c;配置完成后发现并不能解决问题&#xff0c; 出现…...

【集成学习】Bagging算法详解及代码实现

文章目录 1. Bagging集成学习算法1.1 简介1.2 基本步骤1.3 Bagging优缺点1.4 随机森林&#xff1a;Bagging的一个重要应用1.5 总结 2. Python代码实现3. 如何理解偏差与方差3.1 偏差&#xff08;Bias&#xff09;3.2 方差&#xff08;Variance&#xff09;3.3 方差与偏差的权衡…...

HTML5实现好看的中秋节网页源码

HTML5实现好看的中秋节网页源码 前言一、设计来源1.1 网站首页界面1.2 登录注册界面1.3 节日由来界面1.4 节日习俗界面1.5 节日文化界面1.6 节日美食界面1.7 节日故事界面1.8 节日民谣界面1.9 联系我们界面 二、效果和源码2.1 动态效果2.2 源代码 源码下载结束语 HTML5实现好看…...

OBS Zoom to Mouse 脚本安装与使用指南

前言&#xff1a;OBS有两个不错的放大插件&#xff0c;经过多台电脑测试发现&#xff0c;唯一好用的就是下面介绍的obs-zoom-to-mouse.lua这个插件&#xff0c;因为它安装简单&#xff0c;不需要python&#xff0c;设置更人性化性价比极高。 zoom_and_follow_mouse.py 这个pyth…...