【Docker】容器化应用程序的配置管理策略与实践

news2024/10/6 18:32:47

一、引言

1.1 Docker的背景和优势

Docker是一种开源的容器化平台,简化应用程序的打包、交付和运行过程。基于Linux容器技术,通过提供一个轻量级、可移植和自包含的容器来实现应用程序的隔离和部署。

在传统的应用程序开发和部署中,往往需要考虑各种依赖关系、配置问题和环境差异,这导致了许多挑战和复杂性。开发人员需要在不同的环境中测试和部署应用程序,而运维人员则需要处理不同的软件包和配置管理。这些问题使得应用程序的交付和运行变得困难和耗时。

Docker的出现解决了这些问题。利用容器技术,将应用程序及其所有依赖项打包为一个独立的容器,该容器可以在任何支持Docker的环境中运行,无论是开发、测试还是生产环境。Docker提供了一种标准化的部署方式,使得应用程序的交付和运行变得简单、可靠和可重复。

轻量级和快速启动:Docker容器是轻量级的,它们与宿主操作系统共享内核,因此启动速度非常快。相比于传统的虚拟机,Docker容器更加高效,可以在几秒钟内启动和停止。

隔离性和环境一致性:每个Docker容器都是相互隔离的,具有自己的文件系统、进程空间和网络接口。这种隔离性确保了应用程序之间的互不干扰,同时也避免了与宿主操作系统的冲突。此外,Docker容器提供了一致的运行环境,消除了开发、测试和生产环境之间的差异。

可移植性和可扩展性:Docker容器可以在不同的主机和云平台上运行,而不需要担心环境配置和依赖项的问题。这种可移植性使得应用程序的部署更加灵活,并且可以轻松地进行水平扩展,以满足不同的负载需求。

版本控制和快速部署:Docker使用镜像来构建容器,镜像可以被版本控制和共享。通过版本控制,可以跟踪应用程序的变化,并轻松地回滚到之前的版本。Docker容器可以快速部署和复制,使得应用程序的交付变得高效和可靠。

生态系统和社区支持:Docker拥有庞大的生态系统和活跃的社区支持。有许多开源工具和服务可以与Docker集成,例如Docker Compose、Kubernetes、监控和日志管理工具等。这些工具和服务提供了丰富的功能和解决方案,进一步增强了Docker的价值和可用性。

image-20230728101619961

1.2 使用Docker进行应用程序开发和部署的需求

使用Docker进行应用程序开发和部署可以带来许多好处:

【1】环境一致性和依赖管理:如果应用程序在不同的环境中运行,确保环境一致性非常重要。使用Docker可以封装应用程序及其依赖项,以确保在不同的环境中具有相同的运行结果。Docker还可以管理和解决依赖关系,使得开发人员可以更轻松地管理和升级依赖项。

【2】快速部署和扩展:部署应用程序是一个重要的考虑因素。使用Docker可以将应用程序打包为一个容器镜像,并在任何支持Docker的环境中快速部署。Docker还支持水平扩展,可以根据负载需求自动或手动扩展容器的数量。

【3】持续集成和持续部署:Docker与持续集成和持续部署(CI/CD)流程的集成非常紧密。通过使用Docker容器,可以创建一个一致的开发、测试和生产环境,从而简化CI/CD流程,并实现快速、可靠的部署。

【4】资源利用和性能优化:使用Docker可以更有效地利用系统资源,并提高应用程序的性能。Docker容器是轻量级的,可以在同一主机上运行多个容器,从而提高资源利用率。Docker还提供了一些优化技术,如多阶段构建和容器编排,以进一步优化性能。

【5】监控和日志管理:在容器化环境中,监控和日志管理是必不可少的。Docker生态系统提供了许多监控和日志管理工具,可以帮助开发人员和运维人员实时监控应用程序的状态,并收集和分析日志数据。

二、Docker基础知识回顾

2.1 Docker的核心概念和术语解释

在使用Docker之前,了解其核心概念和术语是非常重要的。

【1】Docker:Docker是一个开源的容器化平台,用于简化应用程序的打包、交付和运行过程。

【2】Docker镜像(Docker Image):Docker镜像是一个只读的模板,包含了运行应用程序所需的所有文件系统、库和依赖项。可以将Docker镜像看作是一个应用程序的静态快照。

【3】Docker容器(Docker Container):Docker容器是Docker镜像的运行实例。容器是一个独立、可执行的应用程序,包含了运行应用程序所需的所有内容,如代码、运行时环境、系统工具和库。

【4】Docker仓库(Docker Registry):Docker仓库是用于存储和共享Docker镜像的地方。官方的Docker仓库称为Docker Hub,可以在其中找到各种公共的Docker镜像。除了Docker Hub,还可以搭建私有的Docker仓库来存储自己的镜像。

【5】Dockerfile:Dockerfile是一个文本文件,用于定义Docker镜像的构建过程。通过编写Dockerfile,可以指定基础镜像、添加文件、运行命令等操作,以构建自定义的Docker镜像。

【6】Docker Compose:Docker Compose是一个工具,用于定义和管理多个Docker容器的应用程序。通过编写一个YAML文件,可以定义容器之间的关系、网络配置、卷挂载等信息,以便一次性启动和管理多个容器。

【7】Docker网络:Docker提供了多种网络模式,用于容器之间的通信和连接。默认情况下,Docker使用桥接网络模式,每个容器都有自己的IP地址,并可以通过容器名称进行访问。

【8】Docker卷(Docker Volume):Docker卷是用于在容器和宿主机之间共享数据的机制。可以将Docker卷挂载到容器中的特定路径,以便容器和宿主机之间进行数据传输和持久化存储。

2.2 Docker镜像和容器的关系与使用方法

Docker镜像和容器是Docker的两个核心概念,它们之间有着紧密的关系。

Docker镜像是一个只读的模板,包含了应用程序运行所需的所有文件系统、库和依赖项。可以通过Dockerfile定义和构建自定义的Docker镜像,也可以从Docker仓库中获取现有的镜像。Docker镜像是静态的,不可更改的。

Docker容器是Docker镜像的运行实例。容器是一个独立、可执行的应用程序,包含了运行应用程序所需的所有内容。可以将Docker容器看作是一个隔离的、可移植的运行环境。容器可以启动、停止、删除和重启。

使用Docker镜像和容器的一般步骤如下:

【1】获取Docker镜像:可以从Docker Hub等公共或私有的Docker仓库中获取现有的Docker镜像,也可以通过编写Dockerfile来构建自定义的镜像。

【2】创建Docker容器:使用docker run命令创建一个新的Docker容器,并指定要使用的镜像。可以通过命令行参数来配置容器的各种选项,如端口映射、环境变量、卷挂载等。

【3】运行应用程序:一旦容器创建成功,可以在容器中运行应用程序。可以使用docker exec命令在运行的容器中执行命令,或者通过Docker Compose定义多个容器之间的关系和依赖关系。

【4】管理容器:可以使用docker start、docker stop、docker restart等命令来管理容器的生命周期。可以使用docker ps命令查看正在运行的容器,使用docker rm命令删除不需要的容器。

【5】持久化数据:可以使用Docker卷来共享和持久化容器中的数据。可以将宿主机的目录挂载到容器中的特定路径,以实现数据的共享和持久化存储。

三、工程化的Dockerfile设计

在使用Docker构建镜像时,编写可重复、可维护的Dockerfile是非常重要的。

3.1 编写可重复、可维护的Dockerfile

【1】注释和文档:在Dockerfile中添加注释和文档,解释每个步骤的用途和意义。可以使其他开发人员更容易理解和维护Dockerfile。

【2】参数化:使用ARG指令定义参数,以便在构建过程中动态传递值。可以提高Dockerfile的灵活性和可重复性。

【3】使用环境变量:使用ENV指令设置环境变量,以便在容器运行时配置应用程序。可以使容器更加可配置和可移植。

【4】清理不必要的文件:在构建过程中,删除不必要的中间文件和缓存,以减小镜像的大小。可以使用RUN指令执行清理操作。

3.2 使用多阶段构建优化镜像大小和性能

【1】多阶段构建:使用多阶段构建可以减小最终镜像的大小,并提高构建过程的性能。可以将构建环境和运行环境分开,只将必要的文件和依赖项复制到最终镜像中。

【2】适当选择基础镜像:选择合适的基础镜像是优化镜像大小和性能的关键。应选择轻量级的基础镜像,避免包含不必要的组件和依赖项。

【3】减少层次:在Dockerfile中,每个指令都会创建一个新的镜像层。为了减小镜像的大小,可以合并多个指令,减少层次的数量。可以使用&&运算符将多个命令合并到一行。

3.3 最佳实践:减少层次、使用有效的基础镜像、合理安排指令顺序等

【1】减少层次:尽量减少镜像的层次数量,可以使用&&运算符将多个命令合并到一行,避免不必要的中间层。

【2】使用有效的基础镜像:选择一个有效的基础镜像,可以减小镜像的大小并提高构建和运行的性能。可以选择官方的基础镜像或经过验证的第三方基础镜像。

【3】合理安排指令顺序:在Dockerfile中,指令的顺序也会影响镜像的构建性能。将耗时的指令放在后面,可以利用Docker的缓存机制,避免重复执行耗时的操作。

【4】使用.dockerignore文件:在构建镜像时,可以使用.dockerignore文件来排除不必要的文件和目录。可以减小上下文的大小,加快构建过程。

【5】使用COPY而不是ADD:在Dockerfile中,使用COPY指令而不是ADD指令来复制文件到镜像中。COPY指令只复制文件,而ADD指令还支持解压缩和URL下载等功能,但会增加镜像的复杂性和大小。

四、容器化应用程序的配置管理

容器化应用程序的配置管理是确保应用程序在不同环境中正确配置的重要方面。

4.1 使用环境变量和配置文件进行应用程序配置

【1】环境变量:使用环境变量可以在容器运行时动态配置应用程序。可以在Dockerfile中使用ENV指令设置环境变量的默认值,并在容器启动时通过docker run命令的-e选项传递具体的值。

【2】配置文件:将应用程序的配置存储在配置文件中,可以在容器启动时通过挂载文件或者通过配置卷的方式将配置文件传递给容器。应用程序可以读取配置文件中的值来进行配置。

4.2 外部化配置:将配置从镜像中分离

【1】将配置从镜像中分离:为了实现配置的外部化,可以将配置文件或者配置数据从镜像中分离出来。这样可以在容器启动时动态加载配置,而不需要重新构建镜像。

【2】使用配置卷:可以使用Docker的配置卷功能,将配置文件挂载到容器中的指定路径。这样可以在容器启动时将具体的配置文件传递给容器,实现配置的外部化。

4.3 使用配置管理工具(如Consul、etcd)实现动态配置

【1】配置管理工具:可以使用配置管理工具(如Consul、etcd)来实现动态配置。这些工具提供了分布式的键值存储,可以存储和管理应用程序的配置信息。

【2】动态加载配置:应用程序可以在启动时从配置管理工具中动态加载配置。这样可以实现配置的集中管理和动态更新,而不需要重新启动容器。

【3】配置变更通知:配置管理工具通常提供配置变更通知的功能,可以实时通知应用程序配置的变化。应用程序可以订阅配置变更事件,及时更新配置。

五、容器编排与集群管理

容器编排与集群管理可以通过使用Docker Compose编排多个容器的组合,使用容器编排工具(如Kubernetes)进行容器集群管理,以及遵循最佳实践(如服务发现、负载均衡、自动伸缩)来实现。这些方法可以简化容器部署和管理的复杂性,提高应用程序的可靠性、可扩展性和弹性。

5.1 使用Docker Compose编排多个容器的组合

【1】Docker Compose:Docker Compose是一个用于定义和运行多个容器的工具。通过编写一个YAML文件,可以定义多个容器之间的关系、依赖和配置。

【2】服务定义:在Docker Compose文件中,可以定义多个服务,每个服务对应一个容器。可以指定每个服务的镜像、容器配置、网络设置等。

【3】容器间通信:Docker Compose提供了网络功能,可以将多个容器连接到同一个网络中,使它们可以相互通信。可以使用服务名称作为主机名来实现容器间的通信。

5.2 使用容器编排工具(如Kubernetes)进行容器集群管理

【1】容器编排工具:容器编排工具(如Kubernetes)提供了更强大的容器集群管理功能,可以自动化管理和调度容器。

【2】集群管理:容器编排工具可以管理多个容器节点组成的集群。它可以自动在集群中调度和部署容器,实现高可用性和负载均衡。

【3】自动伸缩:容器编排工具可以根据应用程序的负载情况自动进行容器的伸缩。可以根据预设的规则,自动增加或减少容器的数量,以满足应用程序的需求。

5.3 最佳实践:服务发现、负载均衡、自动伸缩

【1】服务发现:在容器集群中,服务发现是一个重要的功能。容器编排工具可以提供服务发现的功能,使容器能够自动发现和连接到其他容器或服务。

【2】负载均衡:容器编排工具可以自动进行负载均衡,将流量均匀地分配给多个容器。这样可以提高应用程序的性能和可扩展性。

【3】自动伸缩:通过容器编排工具的自动伸缩功能,可以根据应用程序的负载情况自动调整容器的数量。这样可以根据需求动态地扩展或缩减容器的规模。

六、日志管理和监控

日志管理和监控是容器化应用程序不可或缺的一部分。通过制定合适的日志管理策略、使用日志聚合工具进行集中式日志管理,以及进行容器监控和性能调优,可以更好地理解和管理容器化应用程序的运行情况,提高应用程序的可靠性和性能。

6.1 容器化应用程序的日志管理策略

【1】日志生成和格式:容器化应用程序应该生成有意义的日志,并使用一致的格式。这样可以方便后续的日志分析和处理。

【2】日志输出和存储:应该将容器的日志输出到标准输出(stdout)和标准错误(stderr)。可以使用容器运行时的日志驱动程序将日志发送到适当的目标,如文件、日志收集器等。

【3】日志轮转和清理:为了避免日志文件过大,应该设置日志轮转和清理策略。可以使用日志轮转工具(如logrotate)定期压缩和删除旧的日志文件。

6.2 使用日志聚合工具(如ELK Stack)进行集中式日志管理

【1】日志聚合工具:日志聚合工具可以将多个容器的日志收集到一个集中的位置进行管理和分析。ELK Stack(Elasticsearch、Logstash、Kibana)是一个常用的日志聚合解决方案。

【2】日志收集和传输:使用日志收集器(如Logstash)收集容器的日志,并将其传输到Elasticsearch进行存储和索引。

【3】日志分析和可视化:使用Kibana可以对日志进行分析和可视化,通过查询和图表展示日志数据,帮助我们理解应用程序的运行情况和发现潜在的问题。

6.3 容器监控与性能调优

【1】容器监控指标:容器监控可以收集和分析容器的各种指标,如CPU使用率、内存使用率、网络流量等。这些指标可以帮助我们了解容器的性能和资源使用情况。

【2】监控工具:有许多监控工具可以用于容器监控,如Prometheus、Grafana等。这些工具可以收集和展示容器的监控指标,并提供警报功能。

【3】性能调优:通过监控容器的性能指标,可以进行性能调优。可以根据监控数据进行容器资源的调整、应用程序的优化等,以提高容器的性能和效率。

七、安全性和权限管理

通过遵循容器安全性最佳实践、进行用户和权限管理,以及配置容器网络安全和防火墙,可以提高应用程序和数据的安全性,并降低潜在的安全风险。

7.1 容器安全性最佳实践:镜像验证、容器隔离

【1】镜像验证:在使用容器镜像时,应该验证镜像的来源和完整性。可以使用数字签名或哈希值验证镜像的真实性,以避免使用被篡改或恶意注入的镜像。

【2】容器隔离:容器之间应该进行隔离,以防止恶意容器对其他容器或主机造成影响。可以使用容器运行时的隔离机制,如命名空间、控制组等,确保容器之间的资源和环境隔离。

【3】漏洞管理:容器镜像中的软件包可能存在漏洞,应该定期更新和修复这些漏洞。可以使用漏洞扫描工具来检测容器镜像中的漏洞,并及时应用修复补丁。

7.2 用户和权限管理:最小权限原则、用户隔离

【1】最小权限原则:为容器内的进程和服务分配最小必需的权限。避免使用具有过高权限的用户或服务账号,以减少潜在的安全风险。

【2】用户隔离:应该为每个容器分配独立的用户身份,避免不同容器共享同一个用户账号。这样可以限制容器之间的权限和访问范围。

【3】访问控制:使用访问控制机制,如访问控制列表(ACL)或基于角色的访问控制(RBAC),对容器内的资源和功能进行权限控制。只允许授权的用户或服务访问特定资源。

7.3 容器网络安全和防火墙配置

【1】网络隔离:容器之间应该进行网络隔离,以防止未经授权的访问。可以使用网络命名空间、虚拟局域网(VLAN)等技术实现容器的网络隔离。

【2】防火墙配置:配置防火墙规则来限制容器的网络流量。只允许必要的网络连接,并禁止不必要的入站和出站连接。可以使用网络防火墙工具,如iptables,来配置容器的防火墙规则。

【3】加密通信:对容器之间的通信进行加密,以保护数据的机密性和完整性。可以使用安全传输协议(如TLS)来加密容器之间的通信。

八、持续集成与持续部署

持续集成与持续部署是现代软件开发中的重要实践。通过使用Docker构建持续集成和持续部署流水线、集成Docker镜像注册表和仓库,并采用自动化测试和部署策略,团队可以实现快速、高效、可靠的软件交付,提高开发效率和质量。

8.1 使用Docker构建持续集成和持续部署流水线

【1】流水线定义:使用流水线工具(如Jenkins、GitLab CI、Travis CI等)定义持续集成和持续部署的流程。流水线包括构建、测试、部署等阶段。

【2】Docker化构建环境:使用Docker容器来创建一致的构建环境,确保构建过程的可重复性和一致性。可以使用Docker镜像作为构建环境,并在流水线中使用这些镜像来执行构建任务。

【3】构建步骤:在流水线中定义构建步骤,如代码检查、编译、静态分析等。可以使用Docker容器来执行这些构建步骤,并确保构建环境的一致性。

8.2 集成Docker镜像注册表和仓库

【1】Docker镜像注册表:使用Docker镜像注册表来存储和管理Docker镜像。可以使用公共的Docker镜像注册表(如Docker Hub)或私有的注册表(如Harbor、Azure Container Registry)。

【2】仓库管理:在持续集成和持续部署流水线中,需要对Docker镜像进行版本管理和仓库管理。可以使用版本控制系统(如Git)来管理Dockerfile和相关配置文件,并使用仓库管理工具(如Artifactory、Nexus)来管理Docker镜像的发布和分发。

【3】镜像标签和版本控制:为每个构建的Docker镜像打上唯一的标签,以便在部署和回滚时进行版本控制和管理。可以使用Git提交ID、流水线号码等作为标签,确保镜像的唯一性和可追溯性。

8.3 自动化测试和部署策略

【1】自动化测试:在持续集成流水线中,应该包括自动化测试环节。可以使用单元测试、集成测试、端到端测试等不同层次的测试来验证应用程序的功能和质量。可以使用测试框架和工具(如JUnit、Selenium、Cypress等)来执行自动化测试。

【2】部署策略:在持续部署流水线中,应该定义合适的部署策略。可以使用蓝绿部署、金丝雀部署等策略来实现无缝的应用程序更新和回滚。可以使用部署工具和编排工具(如Kubernetes、Docker Compose)来自动化应用程序的部署和扩展。

【3】持续监控和反馈:在持续部署后,应该进行持续监控和反馈。可以使用监控工具(如Prometheus、Grafana)来监控应用程序的性能和健康状况,并及时反馈给开发团队。

九、故障排查和故障恢复

故障排查和故障恢复是容器化应用程序管理中的重要方面。通过使用容器故障排查工具和技术、制定故障恢复策略和最佳实践,并实施容器的备份和恢复策略,可以提高应用程序的可用性、稳定性和容灾能力。

9.1 容器故障排查工具和技术

【1】日志分析:容器化应用程序的日志是故障排查的重要信息来源。通过分析容器的日志,可以了解应用程序的运行状态和潜在问题。常用的日志分析工具包括ELK Stack(Elasticsearch、Logstash、Kibana)、Fluentd、Splunk等。

【2】容器监控:使用容器监控工具可以实时监测容器的资源使用情况、性能指标和健康状态。常用的容器监控工具包括Prometheus、Grafana、Datadog等。通过监控数据,可以发现异常情况并进行故障排查。

【3】追踪和调试:使用分布式追踪工具(如Jaeger、Zipkin)可以跟踪容器化应用程序中的请求和调用链,帮助定位潜在的性能问题和故障点。调试工具(如Docker Exec、Kubectl Exec)可以在容器内部执行命令和调试应用程序。

9.2 容器故障恢复策略和最佳实践

【1】自动重启策略:在容器运行时,可以配置自动重启策略,以便在容器崩溃或退出时自动重新启动容器。可以使用Docker的–restart选项或容器编排工具(如Kubernetes)的重启策略来实现自动重启。

【2】故障转移和负载均衡:通过使用容器编排工具(如Kubernetes、Docker Swarm)的故障转移和负载均衡功能,可以将请求自动转移到其他健康的容器实例上,实现高可用性和故障恢复。

【3】健康检查和容器健康状态:配置容器的健康检查机制,定期检查容器的运行状态和健康状况。可以使用Docker的健康检查选项或容器编排工具的健康检查功能来实现容器的自动故障恢复。

9.3 容器的备份和恢复策略

【1】数据备份:对于容器化应用程序中的重要数据,应该定期进行备份。可以使用容器卷(Volume)来存储数据,并使用备份工具(如Velero、Duplicati)对容器卷进行定期备份。另外,也可以将数据备份到云存储服务(如AWS S3、Azure Blob Storage)中。

【2】应用程序状态备份:除了数据备份外,还应该备份应用程序的状态和配置信息。可以使用配置管理工具(如Ansible、Chef、Puppet)来管理和备份应用程序的配置文件和状态。

【3】灾难恢复:在面临灾难性故障时,需要有灾难恢复计划。可以使用容器编排工具(如Kubernetes)的跨区域部署和备份策略来实现容器的灾难恢复。

十、总结和展望

10.1 工程化Docker最佳实践的重要性和好处

工程化Docker最佳实践对于容器化应用程序的管理和运维具有重要作用。

【1】可重复性和一致性:通过使用Docker镜像和容器编排工具,可以实现应用程序的可重复性和一致性。不同环境下的部署和运行都可以基于相同的镜像和配置文件,确保应用程序的一致性和可预测性。

【2】快速部署和扩展:使用Docker可以实现快速部署和扩展应用程序。通过将应用程序和其依赖项打包成镜像,可以快速部署和启动容器实例。同时,可以使用容器编排工具来自动化应用程序的扩展和负载均衡。

【3】资源利用率和隔离性:Docker可以提供更好的资源利用率和隔离性。通过容器化,可以在同一物理机上运行多个容器实例,充分利用物理资源。同时,容器之间相互隔离,避免了应用程序之间的冲突和干扰。

【4】持续集成和持续部署:Docker可以与持续集成和持续部署流程无缝集成。通过使用Docker构建持续集成和持续部署流水线,可以实现快速、高效的软件交付,提高开发效率和质量。

10.2 期待Docker和容器技术的发展方向

容器技术在过去几年中取得了巨大的发展,并在软件开发和运维领域得到广泛应用,期待以后的发展。

【1】更强大的编排和管理工具:容器编排工具(如Kubernetes)在容器管理和调度方面已经取得了很大的成功,但仍有进一步发展的空间。未来的发展将聚焦于更强大、更智能的编排和管理工具,以进一步简化容器的部署、扩展和管理。

【2】更高级的安全性和隔离性:容器技术在安全性和隔离性方面已经有了很大的改进,但仍然存在一些挑战。未来的发展将集中在更高级的安全性措施和隔离技术,以确保容器化应用程序的安全性和可信度。

【3】更多领域的应用扩展:目前,容器技术主要应用于云原生应用程序和微服务架构。未来,容器技术有望扩展到更多的领域,如边缘计算、物联网、人工智能等,为这些领域的应用程序提供更灵活、可扩展的部署和管理方式。

【4】容器与虚拟机的融合:容器技术和虚拟机技术都在应用程序管理和隔离方面发挥着重要作用。未来,我们可以期待容器与虚拟机的融合,以提供更灵活、更高效的混合部署和管理方案。

工程化Docker最佳实践对于容器化应用程序的管理和运维至关重要,可以带来可重复性、快速部署、资源利用率和持续集成等好处。未来,可以期待容器技术在编排和管理工具、安全性和隔离性、应用扩展以及容器与虚拟机的融合等方面的进一步发展和创新。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/991926.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

九科-模块化-创建目录_如果不存在

python代码 # 创建目录_如果不存在 def create_directory_if_not_exists(dir_path):# 如果目录不存在if not os.path.exists(dir_path):# 创建目录os.makedirs(dir_path) 九科组件模块 总图 查询目录是否存在 IF判断目录是否存在 如果目录不存在,创建目录

syn洪流原理

TCP三次握手 建立连接发送或回应第一次握手客户端发送报文,标志位为SYN(seqa)第二次握手服务器发送报文,标志位为SYN,ACK(seqb,acka1)第三次握手客户端回应服务器报文,标志位为ACK&…

Java 设置免登录请求接口被拦截问题

1、在设置免登录时,前端将请求的路由添加到白名单后,请求接口还是被拦截到了,将请求接口也设置后还是会被拦截跳转到登录页面 通过JAVA 注解 Anonymous 进行设置匿名访问就可以了

Docker 的常用命令

0 基本命令 概述 [root192 home]# docker --helpUsage: docker [OPTIONS] COMMANDA self-sufficient runtime for containersOptions:--config string Location of client configfiles (default "/root/.docker")-c, --context string Name of the context…

js中如何判断一个对象是否为空对象?

聚沙成塔每天进步一点点 ⭐ 专栏简介⭐ 使用 Object.keys()⭐ 使用 for...in 循环⭐ 使用 JSON.stringify()⭐ 使用 ES6 的 Object.getOwnPropertyNames()⭐ 写在最后 ⭐ 专栏简介 前端入门之旅:探索Web开发的奇妙世界 记得点击上方或者右侧链接订阅本专栏哦 几何带…

windows本地认证

来自帅气学弟得经验 阅读流程 windows系统认证包括**本地交互式认证 **和 网络认证 交互式登录:向本地计算机或域账户确认用户的身份 网络登录:对用户尝试访问的网络服务或资源提供用户认证 若是本地用户本地认证需要了解**windows密码 **,…

【C++心愿便利店】No.5---构造函数和析构函数

文章目录 前言一、类的6个默认成员函数二、构造函数三、析构函数 前言 👧个人主页:小沈YO. 😚小编介绍:欢迎来到我的乱七八糟小星球🌝 📋专栏:C 心愿便利店 🔑本章内容:类…

通过curl命令分析http接口请求各阶段的耗时等

目录 一、介绍二、功能1、-v 输出请求 响应头状态码 响应文本等信息2、-x 测试代理ip是否能在该网站使用3、-w 额外输出查看接口请求响应的消耗时间4、-o 将响应结果存储到文件里面5、-X post请求测试 (没测成功用的不多) 一、介绍 Curl是一个用于发送和接收请求的命令行工具和…

TCP/IP传输协议学习

了解完整的通信过程 1.发送方源终端设备的应用创建数据。 2.当数据在源终端设备中沿协议栈向下传递,对其分段和封装。 3.在协议栈网络接入层的介质上生成数据。 4.通过由介质和任意中间设备组成的网际层网络传输数据。 5.在目的终端设备中沿协议栈向上传递时对其…

用队列实现栈(C语言版本)

🎈个人主页:🎈 :✨✨✨初阶牛✨✨✨ 🐻强烈推荐优质专栏: 🍔🍟🌯C的世界(持续更新中) 🐻推荐专栏1: 🍔🍟🌯C语言初阶 🐻推荐专栏2: 🍔…

ArcGIS 10.5安装教程!

软件介绍: ArcGIS Desktop 10.5中文特别版是一款功能强大的GSI专业电子地图信息编辑和开发软件,ArcGIS Desktop 包括两种可实现制图和可视化的主要应用程序,即 ArcMap 和 ArcGIS Pro。ArcMap 是用于在 ArcGIS Desktop 中进行制图、编辑、分析…

滴滴:二季度中国出行营收同比增长57%,6月日均单量超3000万单

9月9日,滴滴在其官网发布2023年第二季度业绩报告,二季度滴滴实现总收入488亿元,同比增长52.6%;归属于滴滴普通股股东的净亏损为3亿元,经调整EBITA亏损1000万元。 分业务来看,二季度滴滴中国出行&#xff0…

北京运营《乡村振兴战略下传统村落文化旅游设计》许少辉八一新书

北京运营《乡村振兴战略下传统村落文化旅游设计》许少辉八一新书

当所有行业都在数字化转型时,企咨行业如何快速“破局”

党的二十大报告指出,“加快发展数字经济,促进数字经济和实体经济深度融合,打造具有国际竞争力的数字产业集群。”随着新一轮科技革命和产业变革深入发展,数字化转型已经不是一道“选择题”,而是一堂“必修课”。 数字…

国产触控笔哪个牌子好?开学平价好用触控笔排行榜

很多学生在新学期的时候,都会用到电容笔,这说明电容笔的重要性。苹果推出了ipad专用的电容笔后,这种电容笔便成为了市场上最热门的产品,只是因为Apple Pencil的价格过于昂贵,所以很多人并没有购买得起。所以&#xff0…

一文读懂官方给出torch.nn.RNN API的参数及手写RNN API复现

理论部分 官方给出的文档解释: 计算公式: 该公式对应的结构框图: 其中 xt 表示当前 t 时刻的输入,Wih表示 “输入层” 到 “隐藏层” 的权重矩阵。即 Wih 会将输入映射至隐藏层。bih表示输入层到隐藏层的偏置,ht-1表…

【我的第一千篇文章】

作为一名Java开发者,我很自豪地宣布,这里是我输出的第一千篇文章。在过去的六年里,我一直坚持每月输出优质内容,并将其分享给了全世界的读者们。这一千篇文章中,有很多关于Java编程的技巧、经验分享、优秀实践示例、案…

16 “count(*)“ 和 “count(1)“ 和 “count(field1)“ 的差异

前言 经常会有面试题看到这样的问题 “ select count(*) ”, “ select count(field1) ”, “ select count(1) ” 的效率差异啥的 然后 我们这里 就来探索一下 这个问题 我们这里从比较复杂的 select count(field1) 开始看, 因为 较为复杂的处理过程 会留一下一些关键的调试…

C4D国潮场景3D模型合集

110个国潮场景3D模型,C4D源文件,部分效果图如下: 微信扫描下方二维码 回复关键字获取 100004

神经网络输出中间特征图

在进行神经网络的训练过程中,会生成不同的特征图信息,这些特征图中包含大量图像信息,如轮廓信息,细节信息等,然而,我们一般只获取最终的输出结果,至于中间的特征图则很少关注。 前两天师弟突然…