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

Docker编排工具---Compose的概述及使用

目录

一、Compose工具的概述

二、Compose的常用命令

1、列出容器

2、查看访问日志

3、输出绑定的公共端口

4、重新构建服务

5、启动服务

6、停止服务

7、删除已停止服务的容器

8、创建和启动容器

9、在运行的容器中执行命令

10、指定一个服务启动容器的个数

11、其他管理命令

三、docker-compose.yml文件

1、image标签

2、build标签

3、command标签

4、dns标签

5、environment标签

6、env_file标签

7、expose标签

8、port标签

9、network_mode标签

10、depends_on标签

11、links标签

12、volumes标签

13、volumes_from标签

14、logs标签


一、Compose工具的概述

        Compose是Docker 官方的开源项目,定位是“定义和运行多个Docker 容器应用的工具”,其前身是Fig,负责实现对Docker容器集群的快速编排。Compose 通过YMAL配置文件来创建和运行所有服务。

        在Docker中构建自定义镜像是通过使用Dockerfile 模板文件来实现的,从而使用户方便地定义一个单独的应用容器。而Compose使用的模板文件是一个YAML格式文件,它允许用户通过一个docker-compose.yml 模板文件来定义一-组相关联的应用容器为一个项目。

        Compose 项目使用Python语言编写而成,调用了Docker 服务提供的API来对容器进行管理。因此,只要所操作的平台支持Docker API, 就可以在其上利用Compose工具来进行编排管理。

        Compose有以下两个重要概念。

        (1)服务(Service): 一个应用的容器,实际上可以包括若干运行相同镜像的容器实例。每个服务都有自己的名称、使用的镜像、挂载的数据卷、所属的网络、依赖的服务等。

        (2)项目( Project):由一组关联的应用容器组成的一-个完整业务单元,在docker-compose.yml中定义,即Compose的一个配置文件可以解析为一个项目,Compose 通过分析指定配置文件,得出配置文件所需完成的所有容器管理与部署操作。

        Compose的默认管理对象是项目,通过子命令对项目中的一组容器进行便捷的生命周期管理。

二、Compose的常用命令

        Compose的常用命令常跟在docker-compose主命令后面。

1、列出容器

        ps命令用于列出所有运行的容器。

        其常用选项说明如下。

-q:只显示ID

例如,列出所有运行容器。

docker-compose ps

2、查看访问日志

        logs命令用于查看服务日志输出。

        其常用选项说明如下。

(1) -f,--follow:实时输出日志。

(2) -t,--timestamps:显示时间戳。

(3) --tail="all":从日志末尾显示行。

例如,查看nginx的实时日志。

docker-compose logs -f nginx

3、输出绑定的公共端口

        port命令用于输出绑定的公共端口。

        其常用选项说明如下。

(1) --protocol=proto: TCP或UDP, 默认为TCP。

(2) --index=index: 多个容器时的索引数字,默认为1。

例如,输出eureka 服务8761 端口所绑定的公共端口。

docker-compose port eureka 8761

4、重新构建服务

        build命令用于构建或重新构建服务。

        其常用选项说明如下。

(1) --no-cache: 不使用缓存构建镜像。

(2) --build-arg key=val:设置构建时变量。

例如,构建镜像。

docker-compose build

5、启动服务

        start命令用于自动指定服务已存在的容器。

例如,启动nginx容器。

docker-compose start nginx

6、停止服务

        stop命令用于停止已运行服务的容器。

例如,停止nginx容器。

docker-compose stop nginx

7、删除已停止服务的容器

        rm命令用于删除指定服务的容器。
        其常用选项说明如下。

(1) -f,--force: 强制删除。

(2) -s,--stop: 删除容器时需要先停止容器。

(3)-V,删除与容器相关的任何匿名卷。

例如,删除已停止的nginx容器。

docker-compose rm nginx

8、创建和启动容器

        up命令用于创建和启动容器。

        其常用选项说明如下。

( 1)-d:在后台运行容器。

(2) -t:指定超时时间。

(3) -no-deps:不启动连接服务。

( 4) --no-recreate:如果容器存在,则不重建容器。

(5) --no-build:不构建镜像,即使其会丢失。

(6) --build:启动容器并构建镜像。

(7) --scale SERVICE=NUM:指定-个服务(容器)的启动数量。

例如,创建并启动nginx容器。

docker-compose up -d nginx

9、在运行的容器中执行命令

        exec命令用于在支持的容器中执行命令。

        其常用选项说明如下。

(1) -d:在后台运行命令。

(2) --privileged:给这个进程赋予特殊权限。

(3) -u,--user USER:作为该用户运行该命令。

(4) -T:禁用分配伪终端,默认分配一个终端。

(5) --index=index:多个容器时的索引数字,默认1。

例如,登录到nginx容器中。

docker-compose exec nginx bash

10、指定一个服务启动容器的个数

        scale命令用于指定服务启动容器的个数。

例如,设置指定服务运行容器的个数,以service=num的形式指定。

docker-composo scale user=3 movie=3

11、其他管理命令

(1) restart命令用于重启服务。

(2) kill命令通过发送SIGKILL信号来停止指定服务的容器。

(3) pause命令用于挂起容器。

(4) image命令用于列出本地Docker的镜像。

(5) down命令用于停止容器和删除容器、网络、数据卷及镜像。

(6) create命令用于创建一个服务。

(7) pull命令用于下载镜像。

(8) push命令用于推送镜像。

(9) help命令用于查看帮助信息。

三、docker-compose.yml文件

        docker-compose.yml文件包含version、services、 networks 三部分,其中,services 和networks是关键部分。常见的services书写规则如下。

1、image标签

        image标签用于指定基础镜像。

services:web:image:nginx (image:"nginx:latest")

        在services标签下的web为第二级标签,标签名可由用户自定义,它也是服务名称。

        image可以指定服务的镜像名称或镜像ID,如果镜像在本地不存在,则Compose会尝试获取这个镜像。

2、build标签

        build标签用于指定Dockerfile所在文件夹的路径。该值可以是一个路径, 也可以是一个对象。Compose 会利用它自动构建镜像,并使用构建的镜像启动容器。

build: /path/to/build/dir

        也可以使用相对路径,即

build: ./dir

        还可以设置上下文根目录,并以该目录指定Dockerfile。

build:context: ../dockerfile: path/of/Dockerfile

3、command标签

        command标签用于覆盖容器启动后默认执行的命令。

command: bundle exec thin -P 3000

        也可以写为类似Dockerfile中的格式,例如:

comand: [bundle, exec, thin, -P, 3000]

4、dns标签

        dns标签用于配置DNS服务器,其可以是一个具体值。

dns: 114.114.114.114

        也可以是一个列表。

dns:- 114.114.114.114- 115.115.115.115

        还可以配置DNS搜索域,其可以是一个值或列表。

dns_ search: example.com
dns_ search:- dc1.example.com- dc2.example.com

5、environment标签

        environment标签用于设置镜像变量。与arg标签不同的是,arg 标签设置的变量仅用于构建过程中,而environment标签设置的变量会一直保存在镜像和容器中。

environment:RACK_ ENV: developmentSHOW: 'true'SESSION_SECRET:

        或者:

environment:- RACK_ ENV=development- SHOW=true- SESSION_SECRET

6、env_file标签

        env_file标签用于设置从env文件中获取的环境变量。可以指定一个文件路径或路径表,其优先级低于environment指定的环境变量,即当其设置的变量名称与environment标签设置的变量名称冲突时,以environment标签设置的变量名称为主。

env_file: .env

        可以根据docker.compose.yml设置路径列表。

env_file:- ./common.env- ./apps/web.env- /opt/secrets.env

7、expose标签

        expose标签用于设置暴露端口,只将端口暴露给连接的服务,不暴露给主机。

expose:- "8000"- "8010"

8、port标签

        port标签用于对外暴露端口定义,使用host:container格式,或者只指定容器的嘴口号,宿主机会随机映射端口。

ports:- "3000"- "8763:8763"- "宿主机端口:容器端口"

        注意:当使用host:container格式来映射端口时,如果使用的容器端口号小于60,则可能会得到错误的结果,因为YAML会将<xx:yy>格式的数字解析为60进制,所以建议使用字符串格式。

9、network_mode标签

        network_mode标签用于设置网络模式。

network_mode: "bridge"
network_mode: "host"
network_mode: "none"
network_mode: "service:[service name]"
network_mode: "container:[container name/id]"

10、depends_on标签

        depends_on标签用于指定容器服务的启动顺序。

version: '2'
services: web:build: .depends_on:- db- redisredis:image: redisdb:image: postgres

        这里,容器会先启动Redis和DB两个服务,再启动Web服务。

11、links标签

        links标签用于指定容器连接到当前连接,可以设置别名。

links:- db- db:database- redis

12、volumes标签

        volumes标签用于指定卷挂载路径,可以挂载一个日录或者一个已存在的数据卷容器。可以直接使用"host:container”格式,或者使用"host:container:ro" 格式,对于容器来说,后者的数据卷是只读的,这样可以有效保护宿主机的文件系统。

volumes://只是指定一个路径,Docker会自动创建个数据卷 (该路径是容器内部的)- /var/1ib/mysq1//使用绝对路径挂载数据卷- /opt/data:/var/lib/mysq1//以Compose配置文件为中心的相对路径作为数据卷挂载到容器- ./cache:/tmp/cache//使用用户的相对路径( ~/ 表示的目录是/home/<用户目录>/ 或者 /root/)- ~/configs:/etc/configs/:ro//已经存在的命名的数据卷- datavolume:/var/1ib/mysq1

        如果不使用宿主机的路径,则可以指定一个volume_driver。

volume_ driver: mydriver

13、volumes_from标签

        volumes_from标签用于设置从其他容器或服务挂在数据卷,可选的参数是:ro或者:rw,前者表示容器只读,后者表示容器对数据卷是可读可写的。默认情况下是可读可写的。

volumes_ from:- service_ name- service_ name:ro- container:container_name- container:container_name:rw

14、logs标签

        logs标签用于设置日志输出信息。

logging :driver: syslogoptions:syslog-address: "tcp://192.168.0.42:123"

相关文章:

Docker编排工具---Compose的概述及使用

目录 一、Compose工具的概述 二、Compose的常用命令 1、列出容器 2、查看访问日志 3、输出绑定的公共端口 4、重新构建服务 5、启动服务 6、停止服务 7、删除已停止服务的容器 8、创建和启动容器 9、在运行的容器中执行命令 10、指定一个服务启动容器的个数 11、其…...

Matlab实现绘制任意自由曲线

Matlab实现绘制任意自由曲线&#xff0c;实现Photoshop中的钢笔路径功能&#xff0c;用光顺连接的B样条/贝塞尔曲线实现&#xff0c;鼠标点击生成控制点&#xff0c;拖动形成任意曲线。 可描绘多路径&#xff0c;也可旋转、平移、缩放。经调试可用。 ByangtiaoSculpt/Byangti…...

如何保证Kafka生产者的消息顺序性? (单分区内有序,需确保同一Key的消息发送到同一分区)

Kafka 生产者消息顺序性保障方案 1. 核心实现原理 消息顺序性保障公式&#xff1a; 同一 Key → 同一 Partition → 严格顺序写入2. 关键配置参数 Properties props new Properties(); props.put("acks", "all"); // 确保消息持久化 props.put("ma…...

[D1,2] 贪心刷题

文章目录 摆动序列最大子数组合买卖股票跳跃游戏跳跃2 摆动序列 不像是贪心&#xff0c;只要抓住摆动这个点&#xff0c;前一个上升&#xff0c;那下一个就要下降&#xff0c;记录上一次的状态为1的话&#xff0c;那下一次就要更新为-1&#xff0c;如果上一次为1&#xff0c;这…...

springboot使用阿里云OSS实现文件上传

在Spring Boot中集成阿里云OSS&#xff08;对象存储服务&#xff09;可以通过以下步骤实现&#xff1a; 添加Maven依赖 在pom.xml中添加阿里云OSS SDK依赖&#xff1a; <dependency><groupId>com.aliyun.oss</groupId><artifactId>aliyun-sdk-oss<…...

nginx之proxy_redirect应用

一、功能说明 proxy_redirect 是 Nginx 反向代理中用于修改后端返回的响应头中 Location 和 Refresh 字段的核心指令&#xff0c;主要解决以下问题&#xff1a;协议/地址透传错误&#xff1a;当后端返回的 Location 包含内部 IP、HTTP 协议或非标准端口时&#xff0c;需修正为…...

FAISS(Facebook AI Similarity Search)

First steps with Faiss for k-nearest neighbor search in large search spaces - Davide’s GitHub pages FAISS&#xff08;Facebook AI Similarity Search&#xff09;是由Meta&#xff08;原Facebook&#xff09;AI团队开发的高效相似性搜索库&#xff0c;主要用于处理大规…...

创建虚拟服务时实现持久连接。

在调度器中配置虚拟服务&#xff0c;实现持久性连接&#xff0c;解决会话保持问题。 -p 【timeout】 -p 300 这5分钟之内调度器会把来自同一个客户端的请求转发到同一个后端服务器。【不管使用的调度算法是什么。】【称为持久性连接。】 作用&#xff1a;将客户端一段时间…...

RabbitMQ中Exchange交换器的类型

在RabbitMQ中&#xff0c;Exchange&#xff08;交换器&#xff09;是消息路由的核心组件&#xff0c;它接收生产者发送的消息&#xff0c;并根据不同的规则将消息转发到一个或多个队列。 RabbitMQ主要支持以下几种类型的交换器&#xff1a; 1. Direct Exchange&#xff08;直连…...

JavaSE核心知识点01基础语法01-05(字符串)

&#x1f91f;致敬读者 &#x1f7e9;感谢阅读&#x1f7e6;笑口常开&#x1f7ea;生日快乐⬛早点睡觉 &#x1f4d8;博主相关 &#x1f7e7;博主信息&#x1f7e8;博客首页&#x1f7eb;专栏推荐&#x1f7e5;活动信息 文章目录 JavaSE核心知识点01基础语法01-05&#xff0…...

Vue 项目中二维码生成功能全解析

Vue 项目中二维码生成功能全解析 在信息快速传递的时代&#xff0c;二维码以其简洁高效的特点&#xff0c;成为数据交互的重要媒介。无论是用于支付、信息分享&#xff0c;还是活动参与&#xff0c;二维码都扮演着关键角色。在 Vue 项目开发中&#xff0c;如何实现二维码生成功…...

【AWS+Wordpress】将本地 WordPress 网站部署到AWS

前言 自学笔记&#xff0c;解决问题为主&#xff0c;亲测有效&#xff0c;欢迎补充。 本地开发机&#xff1a;macOS&#xff08;Sequoia 15.0.1&#xff09; 服务器&#xff1a;AWS EC2&#xff08;Amazon Linux 2023&#xff09; 目标&#xff1a;从本地迁移 WordPress 到云…...

性能优化-初识(C++)

性能优化-初识 一、内联与优化&#xff08;Inlining and Optimization&#xff09;什么是内联&#xff08;inline&#xff09;&#xff1f;使用方式&#xff1a;适用场景&#xff1a;注意事项&#xff1a; 二、缓存友好设计&#xff08;Cache-Friendly Design&#xff09;原理简…...

[人机交互]交互设计过程

*一.设计 1.1什么是设计 设计是一项创新活动&#xff0c;旨在为用户提供可用的产品 –交互设计是“设计交互式产品、以支持人们的生活和工作” 1.2设计包含的四个活动 – 识别用户的需要&#xff08; needs &#xff09;并建立需求&#xff08; requirements &#xff09; …...

密码学基石:哈希、对称/非对称加密与HTTPS实践详解

密码学是现代信息安全的基石&#xff0c;它提供了一系列强大的数学工具和技术&#xff0c;用于保护数据的机密性、完整性和真实性&#xff0c;并确保通信双方的身份可被认证。在纷繁复杂的网络世界中&#xff0c;无论是安全的网页浏览 (HTTPS)、安全的软件更新、还是用户密码的…...

WebRTC通信原理与流程

1、服务器与协议相关 1.1 STUN服务器 图1.1.1 STUN服务器在通信中的位置图 1.1.1 STUN服务简介 STUN&#xff08;Session Traversal Utilities for NAT&#xff0c;NAT会话穿越应用程序&#xff09;是一种网络协议&#xff0c;它允许位于NAT&#xff08;或多重 NAT&#xff09;…...

ChromaDB调用BGE模型的两种实践方式

ChromaDB调用BGE模型 前言1.chromadb调用BGE模型api2.调用本地模型 前言 在语义搜索、知识库构建等场景中&#xff0c;文本向量化&#xff08;Embedding&#xff09;是核心技术环节。作为一款开源的向量数据库&#xff0c;ChromaDB允许开发者通过自定义嵌入函数灵活对接各类模…...

解构与重构:自动化测试框架的进阶认知之旅

目录 一、自动化测试的介绍 &#xff08;一&#xff09;自动化测试的起源与发展 &#xff08;二&#xff09;自动化测试的定义与目标 &#xff08;三&#xff09;自动化测试的适用场景 二、什么是自动化测试框架 &#xff08;一&#xff09;自动化测试框架的定义 &#x…...

如何巧妙解决 Too many connections 报错?

1. 背景 在日常的 MySQL 运维中&#xff0c;难免会出现参数设置不合理&#xff0c;导致 MySQL 在使用过程中出现各种各样的问题。 今天&#xff0c;我们就来讲解一下 MySQL 运维中一种常见的问题&#xff1a;最大连接数设置不合理&#xff0c;一旦到了业务高峰期就会出现连接…...

【卡特兰数】不同的二叉搜索树

文章目录 96. 不同的二叉搜索树解法一:动态规划状态表示状态转移方程初始化遍历顺序返回值💥解法二:卡特兰数96. 不同的二叉搜索树 96. 不同的二叉搜索树 ​ 给你一个整数 n ,求恰由 n 个节点组成且节点值从 1 到 n 互不相同的 二叉搜索树 有多少种?返回满足题意的二叉…...

《饶议科学》阅读笔记

《饶议科学》 《偷窃的生物学机制&#xff1a;&#xff08;有些&#xff09;小偷有药可治》阅读笔记 核心内容&#xff1a;探讨偷窃狂&#xff08;kleptomania&#xff09;的生物学机制及相关研究。具体要点 偷窃狂的特征&#xff1a;患者不可抑制地反复偷窃个人不需要、与金钱…...

ShardingJdbc-公共表

ShardingJdbc-公共表 公共表 公共表属于系统中数据量小&#xff0c;变动少&#xff0c;但是却高频联合查询的表&#xff0c;参数表&#xff0c;字典表等属于此类型。可以将此类表在每个数据库中存储一份&#xff0c;所有更新操作将同时发送到所有分库执行。 案例 建立库 shar…...

低成本监控IPC模组概述

1、低成本sigmastar ssc335\ssc377摄像机方案&#xff0c;配合AI边缘计算终端即插即用&#xff0c;差异化AI训练及样 本采集 2、支持200万、500万H265\H264视频编码&#xff0c;支持网络Rtsp,Rtmp,Onvif&#xff0c;web,GB28181,tf卡本地录像&#xff0c; 视频平台接入等...

携手高校科研团队,共建TWS耳机芯片技术新生态

TWS&#xff08;真无线立体声&#xff09;蓝牙耳机已成为人们生活中不可或缺的一部分。而在这背后&#xff0c;有一家名为华芯邦的公司&#xff0c;其专注于TWS蓝牙仓耳机芯片的研发&#xff0c;并不断取得令人瞩目的突破。 一、芯片领域的实力玩家 华芯邦作为一家在芯片行业崭…...

动态规划-91.解码方法-力扣(LeetCode)

一、题目解析 将对应字符转化为数字&#xff0c;我们知道有的大写字母范围是在[1&#xff0c;9]&#xff0c;剩下的则是[10&#xff0c;26]&#xff0c;这个对应关系使我们解题的关键。 二、算法原理 1.状态表示 dp[i]表示&#xff1a;以i位置为结尾时&#xff0c;解码方法总…...

(三)Java数据类型与进制详解

一、Java数据类型概述 Java是一种强类型语言&#xff0c;这意味着每个变量和表达式在编译时都必须有明确的类型。Java的数据类型系统是其核心基础之一&#xff0c;它决定了如何存储数据、能存储什么样的数据以及能对数据执行哪些操作。 1.1 为什么需要数据类型 数据类型在编…...

用 CodyBuddy 帮我写自动化运维脚本

我正在参加CodeBuddy「首席试玩官」内容创作大赛&#xff0c;本文所使用的 CodeBuddy 免费下载链接&#xff1a;腾讯云代码助手 CodeBuddy - AI 时代的智能编程伙伴”。 #CodeBuddy首席试玩官 背景 我个人是非常喜欢 Jenkins 自动化部署工具的&#xff0c;之前都是手写 Jenki…...

【Linux庖丁解牛】—程序地址空间【进程地址空间 | 虚拟地址空间】

1. 再谈空间分布图 我们之前在学C/C的时候必然学过上面的空间分布图。 可是我们对他并不理解&#xff01;这里先对其进行各区域分布验证&#xff1a; #include <stdio.h> #include <unistd.h> #include <stdlib.h> int g_unval; int g_val 100; int ma…...

nginx 上传文件,413 request entity too large

目录 1 问题2 解决 1 问题 前端后端项目&#xff0c;上传文件&#xff0c;接口没问题&#xff0c;但是就是上传不成功 &#xff0c;然后打开f12 &#xff0c;发现这个接口出现413 request entity too large 这个报错 2 解决 1.1 修改nginx配置文件 在Nginx中&#xff0c;cli…...

Nacos源码—5.Nacos配置中心实现分析二

大纲 1.关于Nacos配置中心的几个问题 2.Nacos如何整合SpringBoot读取远程配置 3.Nacos加载读取远程配置数据的源码分析 4.客户端如何感知远程配置数据的变更 5.集群架构下节点间如何同步配置数据 4.客户端如何感知远程配置数据的变更 (1)ConfigService对象使用介绍 (2)客…...

数智管理学(八)

四、未来管理学可能的新拓展方向 &#xff08;一&#xff09;人工智能与机器学习的融合形成智能决策管理职能 随着人工智能和机器学习技术的不断发展&#xff0c;它们将在管理学中得到更广泛的应用。传统决策方法难以快速处理海量数据并准确把握复杂的市场动态。人工智能与机…...

Compose Multiplatform iOS 稳定版发布:可用于生产环境,并支持 hotload

随着 Compose Multiplatform 1.8.0 的发布&#xff0c;iOS 版本也引来的第一个稳定版本&#xff0c;按照官方的原话&#xff1a;「iOS Is Stable and Production-Ready」 &#xff0c;而 1.8.0 版本&#xff0c;也让 Kotlin 和 Compose 在移动端有了完整的支持。 在 2023 年 4 …...

spark基本介绍

一、Spark概述 Spark是一种基于内存的快速、通用、可拓展的大数据分析计算引擎。 Hadoop是一个分布式系统结构的基础架构。 二、Spark与Hadoop相比较的优势&#xff1a; 1. 处理速度&#xff1a;Hadoop&#xff1a;数据处理速度相对较慢 Spark&#xff1a;速度比Hadoop快很…...

DeepSeek智能时空数据分析(九):NL2SQL绘制河流名字-如何给轨迹添加说明文字

序言&#xff1a;时空数据分析很有用&#xff0c;但是GIS/时空数据库技术门槛太高 时空数据分析在优化业务运营中至关重要&#xff0c;然而&#xff0c;三大挑战仍制约其发展&#xff1a;技术门槛高&#xff0c;需融合GIS理论、SQL开发与时空数据库等多领域知识&#xff1b;空…...

管家婆实用贴-如何在Excel中清除空格

我们在使用管家婆软件时&#xff0c;经常会用到Excel表格导入导出数据&#xff0c;在使用Excel整理数据时&#xff0c;数据中的空格可能会导致计算和分析出现问题。无论是多余的前导空格、尾部空格还是单元格中的不必要空格&#xff0c;清除它们都是确保数据准确性的关键。今天…...

《软件项目管理》笔记一

软件项目管理概述 项目管理属于软件工程的组成之一&#xff0c;另外两部分为&#xff1a;软件开发&#xff0c;过程改进。 参考书如下&#xff1a; 1.1 项目与软件项目 1、项目&#xff1a; 为了创造一个唯一的产品或提供一个唯一的服务而进行 的临时性的努力。 2、项目的…...

前端线上错误日志收集与定位指南

想象一下&#xff1a;你的Web应用上线后&#xff0c;用户反馈“按钮点不动”或“页面白屏”&#xff0c;但你却无从下手&#xff01;前端线上错误如JavaScript异常、网络失败&#xff0c;稍不注意就让用户流失&#xff0c;业务受损。令人抓狂的是&#xff0c;80%的错误悄无声息…...

可视化魔法指南

🎨 ECharts数据可视化魔法指南 🌟 ECharts:数据的艺术画笔 #mermaid-svg-ARwFHUrXBJ03Gpo9 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-ARwFHUrXBJ03Gpo9 .error-icon{fill:#552222;}#mermaid-svg-ARwFHUr…...

使用ffmpeg截取MP3等音频片段

可以使用以下命令通过 ffmpeg 截取 MP3 音频文件的指定片段: ffmpeg的安装方法参考:linux 安装包方式安装ffmpeg,并在环境中设定或指定ffmpeg地址_linux 通过ffmpeg访问地址-CSDN博客 ffmpeg -ss [start_time] -i input.mp3 -to [end_time] -codec copy output.mp3 参数说…...

FFmpeg(7.1版本)编译生成ffplay

FFmpeg在编译的时候,没有生成ffplay,怎么办? 1. 按照上一篇文章:FFmpeg(7.1版本)在Ubuntu18.04上的编译_ffmpeg-7.1-CSDN博客 在build.sh脚本里配置了ffplay 但是,实际上却没有生成ffplay,会是什么原因呢? 2. 原因是编译ffplay的时候,需要一些依赖库 sudo apt-get i…...

CAN学习之--不使用收发器进行通讯测试

在实际调试或者学习CAN通讯过程中&#xff0c;在需要进行CAN调试的时候&#xff0c;但是手头有只有MCU的评估板&#xff0c;没有CAN的收发器&#xff0c;比如ATA6561、MCP2518这类芯片的时候&#xff0c;该怎么办呢&#xff1f; 因为我们知道&#xff0c;CAN收发器只是做信号的…...

律所项目管理全攻略:人力分配 / 案件管控 / 知识沉淀三维度解析(附专用工具清单)

引言&#xff1a;律所项目管理破局 ——从经验驱动到体系化运营 在法律服务行业数字化转型加速的背景下&#xff0c;律所项目管理能力已成为决定服务质量、客户满意度及团队效能的核心竞争力。从人力分配失衡导致的效率损耗&#xff0c;到案件流程模糊引发的客户信任危机&…...

Linux电源管理(7)_Wakeup events framework

原文链接&#xff1a;Linux电源管理(7)_Wakeup events framework 1. 前言 本文继续“Linux电源管理(6)_Generic PM之Suspend功能”中有关suspend同步以及PM wakeup的话题。这个话题&#xff0c;是近几年Linux kernel最具争议的话题之一&#xff0c;在国外Linux开发论坛&…...

Nvidia-smi 运行失败(Failed to initialize NVML: Driver/library version mismatch)

问题排查 在linux服务器上运行 nvidia-smi 命令&#xff0c;提示以下错误&#xff1a; Failed to initialize NVML: Driver/library version mismatch 首先查看内核驱动版本&#xff1a; cat /proc/driver/nvidia/version然后查看当前NVIDIA驱动版本&#xff1a; sudo dpkg …...

算法设计与分析实验题-序列对齐

基于 C 的序列最大对齐得分算法实现 在生物信息学和文本处理领域&#xff0c;序列对齐是一种常见的需求。本文将介绍如何使用 C 实现一个序列最大对齐得分算法&#xff0c;该算法可以计算两个序列在最优对齐方式下的最大得分。 问题描述 给定两个序列 S1 和 S2&#xff0c;我…...

第8章-1 查询性能优化-优化数据访问

上一篇&#xff1a;《 下一篇&#xff1a;《第7章-3 维护索引和表》》 在前面的章节中&#xff0c;我们介绍了如何设计最优的库表结构、如何建立最好的索引&#xff0c;这些对于提高性能来说是必不可少的。但这些还不够——还需要合理地设计查询。如果查询写得很糟糕&a…...

每日一题洛谷P1025 [NOIP 2001 提高组] 数的划分c++

P1025 [NOIP 2001 提高组] 数的划分 - 洛谷 (luogu.com.cn) #include<iostream> using namespace std; int n, k; int res 0; void dfs(int num,int step,int sum) {//判断if (sum n) {if (step k) {res;return;}}if (sum > n || step k)return;//搜索for (int i …...

【python】使用Python和BERT进行文本摘要:从数据预处理到模型训练与生成

《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 解锁Python编程的无限可能:《奇妙的Python》带你漫游代码世界 随着信息爆炸时代的到来,海量文本数据的高效处理与理解成为亟待解决的问题。文本摘要作为自然语言处理(NLP)中的关键任务,旨在自动生成…...

WHAT - Rust 智能指针

文章目录 常见的智能指针类型1. Box<T> — 堆上分配的数据2. Rc<T> — 引用计数的共享所有权&#xff08;单线程&#xff09;3. Arc<T> — 原子引用计数&#xff08;多线程&#xff09;4. RefCell<T> — 运行时可变借用&#xff08;单线程&#xff09;…...

用go从零构建写一个RPC(仿gRPC,tRPC)--- 版本1(Client端)

这里我们来实现这个RPC的client端 为了实现RPC的效果&#xff0c;我们调用的Hello方法&#xff0c;即server端的方法&#xff0c;应该是由代理来调用&#xff0c;让proxy里面封装网络请求&#xff0c;消息的发送和接受处理。而上一篇文章提到的服务端的代理已经在.rpc.go文件中…...