SpringCloudAlibaba实战-nacos集群部署

写在前面:在学习阶段,我们想快速学习SpringCloudAlibaba功能,但总是花费大量时间跟着视频或博客做组件配置。由于版本的更迭,我们学习时的组件版本很可能和作者的不一致,又或者是各自环境不一,只能一坑又一坑的踩。因此,本篇博客针对这一痛点,进行nacos集群部署记录。

        关于nacos的理论知识,以及单机版部署网上前人之述足矣。关于集群实战方面,我看了一些视频和博客,一般分为:

  • window搭建(学习不建议)
  • linux搭建(环境准备繁琐)
  • docker单容器部署(集群模式启动\停止,修改配置繁琐)
  • docker-compose部署(企业常用)

        但关于docker-compose部署方式,一般都是单机单台版的,因此我想完善一下集群部署这块,并拓展一下docker-compose的使用方法,因为企业中部署经常需要用到。废话不多说,实战就开干!

一、环境准备

1. 虚拟机

  • 软件VmWare
  • 系统Centos7.6
  • 内存分配:8G

        关于虚拟机怎么配置,我推荐下面这篇博客,就不多介绍了。

VMware安装Centos7系统(命令行模式)_vm安装完centos镜像后怎么进入命令环境-CSDN博客文章浏览阅读6.2k次,点赞4次,收藏31次。一、准备软件、系统镜像二、创建新虚拟机三、安装CentOS7系统四、配置固定IP便于远程管理_vm安装完centos镜像后怎么进入命令环境https://blog.csdn.net/renfeigui0/article/details/102499358

2.安装docker

        使用docker-compose,首先需要下载docker和docker-compose。关于docker的下载,完全可以参考我的另一篇博客:

Study-02-Docker安装icon-default.png?t=N7T8http://t.csdnimg.cn/zrrdO当时跟着视频敲得博客,前面有些啰嗦。直接看从下面这部分开始复制粘贴即可:

ps:我上面的方法默认安装的最新版,当然撰写本博客时间,用的也是当前最新版。

3. 安装docker-compose

  • 命令安装
sudo curl -L "https://github.com/docker/compose/releases/latest/download/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

ps:这种方法我没成功过,因为网不好,再者翻墙,容易连接超时。这里有个很恶心的地方,国内也有相关的源,下载速度很快,确实可以下,但是下下来不能用,这就很离谱,试了几个博客的都是这。

  • 手动安装(推荐)

访问网址:

https://github.com/docker/compose/releasesicon-default.png?t=N7T8https://github.com/docker/compose/releases这里以docker-compose v2.21.0为例

(1)点击Assets,下载 docker-compose-linux-x86_64 

(2)上传文件

        将docker-compose-linux-x86_64 上传至下面目录下(一般这个目录都有,没有的话自己创建)。关于怎么上传,Xshell和finalShell这些图形化工具都有。

ps:为什么选择这个目录,因为下载后默认就是这个目录。

cd /usr/local/bin

        上传到该目录下后,重命名为 docker-compose。

mv docker-compose-linux-x86_64 docker-compose

        接下来就是赋予权限。

sudo chmod +x /usr/local/bin/docker-compose

安装完成后,进行验证:

docker-compose --version

二、集群部署

        使用docker-compose部署,首先梳理nacos集群需要什么:

  • mysql 8.0 镜像(本版要求5.7+)
  • nacos1.4.0 镜像 (版本根据项目来)
  • 部署使用:一个msyql容器、三个nacos容器。

1. 创建目录

sudo mkdir -p /usr/local/software/nacos

2. 构建docker-compose

(1)命令介绍

Compose 模板文件 - Docker — 从入门到实践icon-default.png?t=N7T8https://yeasy.gitbook.io/docker_practice/compose/compose_file(2)构建梳理

        nacos需要配置mysql,所以mysql需要先运行。mysql 运行需要先初始化脚本,创建nacos数据库和相关表。

(3)创建mysql初始化文件

  • 在nacos目录下创建init_mysql目录,然后创建init_nacos_mysql.sql文件。
mkdir init_mysql
vim init_nacos_mysql.sql

  • 进入nacos官网,拷贝nacos_db中的内容至init_nacos_mysql.sql中

网址:

https://github.com/alibaba/nacos/blob/develop/config/src/main/resources/META-INF/nacos-db.sqlicon-default.png?t=N7T8https://github.com/alibaba/nacos/blob/develop/config/src/main/resources/META-INF/nacos-db.sql

由于官网sql不包括创建数据库内容,所以在创建表结构上面需要加入创建数据库语句:

/******************************************/
/*   数据库 = nacos   */
/*   字符集 = utf8mb4   */
/*   排序规则 = utf8mb4_general_ci   */
/******************************************/CREATE DATABASE IF NOT EXISTS nacos DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
USE nacos;

  • wq保存退出即可

(4)创建文件

  • 在上面创建的nacos目录下,执行:
vim docker-compose.yml
  • 输入 i 进入编辑模式,然后将下面内容复制进去,第三节我对文件会进行详解

ps:复制时,不要忘记使用 i 进入编辑模式!然后就是如果你误操作了的话,在Esc命令模式下,依次输入:gg  d  G 可以快速清空文档。

这里我们使用了端口:8846、8847、8848三个端口作为服务端口。

version: '3'
services:mysql:image: mysql:8.0.20container_name: mysqlenvironment:- MYSQL_ROOT_PASSWORD=123456volumes:- /usr/local/software/nacos/init_mysql:/docker-entrypoint-initdb.d- /usr/local/software/nacos/mysql_data:/var/lib/mysqlports:- "3306:3306"networks:- nacos_networknacos1:image: nacos/nacos-server:1.4.0container_name: nacos1hostname: nacos1environment:- PREFER_HOST_MODE=hostname- MODE=cluster- NACOS_APPLICATION_PORT=8846- NACOS_SERVERS=nacos1:8846 nacos2:8847 nacos3:8848- SPRING_DATASOURCE_PLATFORM=mysql- MYSQL_SERVICE_HOST=mysql- MYSQL_SERVICE_PORT=3306- MYSQL_SERVICE_USER=root- MYSQL_SERVICE_PASSWORD=123456- MYSQL_SERVICE_DB_NAME=nacosports:- "8846:8846"depends_on:- mysqlnetworks:- nacos_networkhealthcheck:test: ["CMD", "curl", "-f", "http://localhost:8846/nacos/v1/console/health/readiness"]interval: 30stimeout: 10sretries: 3nacos2:image: nacos/nacos-server:1.4.0container_name: nacos2hostname: nacos2environment:- PREFER_HOST_MODE=hostname- MODE=cluster- NACOS_APPLICATION_PORT=8847- NACOS_SERVERS=nacos1:8846 nacos2:8847 nacos3:8848- SPRING_DATASOURCE_PLATFORM=mysql- MYSQL_SERVICE_HOST=mysql- MYSQL_SERVICE_PORT=3306- MYSQL_SERVICE_USER=root- MYSQL_SERVICE_PASSWORD=123456- MYSQL_SERVICE_DB_NAME=nacosports:- "8847:8847"depends_on:- mysqlnetworks:- nacos_networkhealthcheck:test: ["CMD", "curl", "-f", "http://localhost:8847/nacos/v1/console/health/readiness"]interval: 30stimeout: 10sretries: 3nacos3:image: nacos/nacos-server:1.4.0container_name: nacos3hostname: nacos3environment:- PREFER_HOST_MODE=hostname- MODE=cluster- NACOS_APPLICATION_PORT=8848- NACOS_SERVERS=nacos1:8846 nacos2:8847 nacos3:8848- SPRING_DATASOURCE_PLATFORM=mysql- MYSQL_SERVICE_HOST=mysql- MYSQL_SERVICE_PORT=3306- MYSQL_SERVICE_USER=root- MYSQL_SERVICE_PASSWORD=123456- MYSQL_SERVICE_DB_NAME=nacosports:- "8848:8848"depends_on:- mysqlnetworks:- nacos_networkhealthcheck:test: ["CMD", "curl", "-f", "http://localhost:8848/nacos/v1/console/health/readiness"]interval: 30stimeout: 10sretries: 3networks:nacos_network:driver: bridge
  • 保存后退出

(5)启动

在nacos目录下,输入命令:

docker-compose up -d

(6)检查

健康状态返回为healthy,说明集群部署成功:

传统客户端方法:

        访问网址,查看集群启动情况(记得开放客户端对应端口的防火墙):

sudo firewall-cmd --permanent --add-port=8848/tcp sudo firewall-cmd --reload

http://ip:8848/nacos/

如果想要远程访问数据库:记得防火墙开放3306端口。

至此,使用nacos集群部署完毕,下面是docker-compose启动和停止相关命令:

Tip: 要在docker-compose.yml同级目录下执行

  •  首次创建命令(后台执行)

docker-compose up -d

  • 启动命令

docker-compose start

  • 重启命令

docker-compose restart

  • 停止/删除命令
  1. docker-compose down

    这个命令不仅停止项目中定义的所有容器,还会删除它们。除了容器之外,与容器关联的网络、网络接口和默认的网络栈也会被删除。但请注意,除非你特别指定,否则挂载的卷(volumes)不会被删除。

  2. docker-compose down --volumesdocker-compose down -v

    这个命令会做docker-compose down相同的所有事情,并且还会删除所有在docker-compose.yml文件中定义的卷(volumes)。这是一种彻底清理项目的方式,因为它会移除所有数据。

  3. docker-compose stop

    这个命令只会停止容器,不会删除任何东西。所有的数据、网络设置和卷都会保留,以便后续可以通过docker-compose start再次启动。

        当然对于集群快速部署,上面已经完成了,但是对于docker-compose构建,估计还是有很多明白的地方,下面我将在第三节分享自己的心得。

三、docker-compose详解

        关于docker-compose基础知识,我在第二节的构建docker-compose中附的有网址,可以前去学习。下面我对本文编写的部署nacos文件进行详解。

1. 文件分析

version: '3'

        在docker-compose.yml文件中,version: "3"标志表示该文件使用的是Docker Compose的第3版语法。Docker Compose的不同版本提供了不同的特性和选项。版本3是为Docker 1.13及更高版本设计的,提供了一系列针对生产环境优化的新功能和改进。

networks:nacos_network:driver: bridge
  • networks: 定义了所有自定义网络的配置。
  • nacos_network: 这是自定义网络的名称。

  • driver: bridge: 指定使用桥接(bridge)驱动程序。桥接网络是Docker网络的一种类型,它使容器可以访问外部网络,同时还能让不同的容器互相通信。

        当使用docker-compose up启动服务时,Docker Compose会自动创建这个自定义网络,并且你在这个Compose文件里定义的所有服务都会连接到这个网络,从而能够在该网络内互相通信。

为什么要使用Dokcer网络?

  1. 隔离性: 不同的网络提供不同的隔离层,这样不同的应用或服务之间不会相互影响。这有助于增强安全性。

  2. 简化配置: 使用Docker网络可以自动进行DNS解析,容器可以通过服务名称而不是IP地址进行通信,这大大简化了配置。

  3. 易于扩展: 当应用需要更多服务或组件时,可以很容易地将它们加入到现有的Docker网络中,而不需要对现有系统进行大量修改。

  mysql:image: mysql:8.0.20container_name: mysqlenvironment:- MYSQL_ROOT_PASSWORD=123456volumes:- /usr/local/software/nacos/init_mysql:/docker-entrypoint-initdb.d- /usr/local/software/nacos/mysql_data:/var/lib/mysqlports:- "3306:3306"networks:- nacos_network
  • mysql:自定义服务名,可以用这个名称在Docker Compose内部引用这个服务。
  • image: 指定使用哪个Docker镜像来创建容器,这里是MySQL的8.0.20版本。
  • container_name: 定义容器的名称为mysql。
  • environment: 定义环境变量。
    • MYSQL_ROOT_PASSWORD=123456: 设置MySQL root用户的密码为123456。
  • volumes: 映射宿主机和容器内的文件或目录。
    • /usr/local/software/nacos/init_mysql:/docker-entrypoint-initdb.d: 将宿主机的/usr/local/software/nacos/init_mysql目录映射到容器的/docker-entrypoint-initdb.d目录。用于初始化数据库。
    • /usr/local/software/nacos/mysql_data:/var/lib/mysql: 将宿主机的/usr/local/software/nacos/mysql_data目录映射到容器的/var/lib/mysql目录,用于保存MySQL的数据。
  • ports: 端口映射。
    • "3306:3306": 将容器的3306端口映射到宿主机的3306端口。
  • networks: 网络设置。
    • nacos_network: 这个容器将连接到名为nacos_network的自定义网络。
  nacos1:image: nacos/nacos-server:1.4.0container_name: nacos1hostname: nacos1environment:- PREFER_HOST_MODE=hostname- MODE=cluster- NACOS_APPLICATION_PORT=8846- NACOS_SERVERS=nacos1:8846 nacos2:8847 nacos3:8848- SPRING_DATASOURCE_PLATFORM=mysql- MYSQL_SERVICE_HOST=mysql- MYSQL_SERVICE_PORT=3306- MYSQL_SERVICE_USER=root- MYSQL_SERVICE_PASSWORD=123456- MYSQL_SERVICE_DB_NAME=nacosports:- "8846:8846"depends_on:- mysqlnetworks:- nacos_networkhealthcheck:test: ["CMD", "curl", "-f", "http://localhost:8846/nacos/v1/console/health/readiness"]interval: 30stimeout: 10sretries: 3
  • nacos1: 服务名称,定义nacos1,nacos2,nacos3服务就可以在内部调用了。

  • image: 指定使用哪个Docker镜像来创建容器,这里是Nacos Server的1.4.0版本。

  • container_name: 定义容器的名称为nacos1

  • hostname: 设置容器内部的主机名为nacos1,不写的话默认为容器id。

  • environment: 定义环境变量。

    • PREFER_HOST_MODE=hostname:Nacos首选的主机模式设置为主机名,上面我们自定义为了nacos1。
    • MODE=cluster:Nacos运行在集群模式下。
    • NACOS_APPLICATION_PORT=8846:Nacos应用的端口。
    • NACOS_SERVERS=nacos1:8846 nacos2:8847 nacos3:8848:集群中其他Nacos服务器的地址和端口。(这里也可以写ip地址,但记得加"",例如:“192.168.64.1:8846 192.168.64.1:8847 192.168.64.1:8848”)
    • SPRING_DATASOURCE_PLATFORM=mysql:使用MySQL作为数据源。
    • MYSQL_SERVICE_HOST=mysql:MySQL服务的主机名。
    • MYSQL_SERVICE_PORT=3306:MySQL服务的端口。
    • MYSQL_SERVICE_USER=root:MySQL的用户。
    • MYSQL_SERVICE_PASSWORD=123456:MySQL用户的密码。
    • MYSQL_SERVICE_DB_NAME=nacos:使用的MySQL数据库名称。
  • ports: 端口映射。

    • "8846:8846": 将容器的8846端口映射到宿主机的8846端口。
  • depends_on: 依赖服务。

    • mysql: nacos1服务依赖于mysql服务,mysql启动后才执行nacos1。还有一种
  • networks: 网络设置。

    • nacos_network: 这个容器将连接到名为nacos_network的自定义网络。
  • healthcheck: 健康检查设置。

    • test: 执行的健康检查命令,nacos有健康检查命令。
    • interval: 检查间隔。
    • timeout: 超时时间。
    • retries: 重试次数。

其他集群配置和nacos1配置一致,只需要更改端口号和服务名就可以实现增加集群节点。

2. 其他问题

如何修改Nacos配置?

        直接在environment中修改nacos参数即可,但是修改docker-compose后需要重新构建。但是需要重新启动服务。

重新启动服务: 有两种主要方法可以重新启动服务以应用更改。

  • 全部重新启动: 使用docker-compose down将现有的服务容器、网络、卷和图像全部停止并删除,然后使用docker-compose up重新启动。

  • 部分重新启动: 如果你只是修改了一个服务,你也可以仅重新启动该服务。使用docker-compose up -d <service_name>来重新启动特定的服务。这样做通常更快,因为它不会影响到其他正在运行的服务。例如:只修改了nacos1服务,则执行:docker-compose up -d nacos1。

内存配置过大问题?

        nacos会设置默认JVM参数,如果感觉比较大,可以自定义参数,在environment中增加下面的参数配置即可。最后根据情况选择重启服务方式。

	  - JVM_XMS=1g- JVM_XMX=1g- JVM_XMN=512m

出错了,如何查看日志?

docker logs -f 容器id

nacos状态不是healthy?

        第一次构建,有时候会出现某个服务启动失败的情况,有可能是因为数据库容器没有及时启动,可以执行docker-compose restart命令重启试试。还有启动时间较长会处于Starting状态,耐心等待即可,如若不行,请使用上面的查看日志命令,具体定位原因。有可能会有疑惑,为什么docker-compose中使用了depends_on还会出现加载顺序失败的问题,下面进行补充:

  1. 启动顺序: 使用depends_on会控制容器的启动顺序,但它不会等待依赖的服务“完全就绪”后再启动。例如,数据库可能需要一些时间初始化,但depends_on不会等数据库初始化完成。

  2. 停止顺序: depends_on也影响容器的停止顺序。依赖服务将先于依赖它的服务停止

  3. 健康检查: 如果你需要等待依赖服务完全启动(例如,数据库初始化完成),可以在docker-compose.yml中为依赖服务添加一个healthcheck字段。

  4. 并非强制性: 即使没有使用depends_on,所有服务仍然可以手动按任何顺序启动和停止。depends_on只是自动化这个过程。

四、对比普通docker构建

1. 构建mysql

拉取镜像:

docker pull mysql:8.0.20

启动镜像:

docker run -p 3306:3306 --name mysql -e MYSQL_ROOT_PASSWORD=123456  -d mysql:8.0.20

2. 构建nacos集群

docker run -d \
-e PREFER_HOST_MODE=hostname \
-e MODE=cluster \
-e NACOS_APPLICATION_PORT=8846 \
-e NACOS_SERVERS="192.168.64.142:8846 192.168.64.142:8847 192.168.64.142:8848" \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_SERVICE_HOST=192.168.64.142 \
-e MYSQL_SERVICE_PORT=3306 \
-e MYSQL_SERVICE_USER=root \
-e MYSQL_SERVICE_PASSWORD=123456 \
-e MYSQL_SERVICE_DB_NAME=nacos \
-e NACOS_SERVER_IP=192.168.64.142 \
-p 8846:8846 \
--name my-nacos1 \
nacos/nacos-server:1.4.0docker run -d \
-e PREFER_HOST_MODE=hostname \
-e MODE=cluster \
-e NACOS_APPLICATION_PORT=8847 \
-e NACOS_SERVERS="192.168.64.142:8846 192.168.64.142:8847 192.168.64.142:8848" \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_SERVICE_HOST=192.168.64.142 \
-e MYSQL_SERVICE_PORT=3306 \
-e MYSQL_SERVICE_USER=root \
-e MYSQL_SERVICE_PASSWORD=123456 \
-e MYSQL_SERVICE_DB_NAME=nacos \
-e NACOS_SERVER_IP=192.168.64.142 \
-p 8847:8847 \
--name my-nacos2 \
nacos/nacos-server:1.4.0docker run -d \
-e PREFER_HOST_MODE=hostname \
-e MODE=cluster \
-e NACOS_APPLICATION_PORT=8848 \
-e NACOS_SERVERS="192.168.64.142:8846 192.168.64.142:8847 192.168.64.142:8848" \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_SERVICE_HOST=192.168.64.142 \
-e MYSQL_SERVICE_PORT=3306 \
-e MYSQL_SERVICE_USER=root \
-e MYSQL_SERVICE_PASSWORD=123456 \
-e MYSQL_SERVICE_DB_NAME=nacos \
-e NACOS_SERVER_IP=192.168.64.142 \
-p 8848:8848 \
--name my-nacos3 \
nacos/nacos-server:1.4.0

开放防火墙端口:

sudo firewall-cmd --permanent --add-port=8846/tcp sudo firewall-cmd --permanent --add-port=8847/tcp sudo firewall-cmd --permanent --add-port=8848/tcp sudo firewall-cmd --reload

测试访问:

http://192.168.64.142:8846/nacos
http://192.168.64.142:8847/nacos
http://192.168.64.142:8848/nacos

3. 优缺点对比

Docker Compose构建的优点:

  1. 简单性和一致性: 通过一个docker-compose.yml文件,你可以定义整个应用环境的所有服务、网络和卷,这样可以确保每次部署都是一致的。

  2. 自动化: 一条docker-compose up命令就可以启动你在docker-compose.yml中定义的所有服务和依赖。

  3. 便于本地开发: 对于多服务应用,使用Docker Compose可以轻易地在本地机器上模拟生产环境。

  4. 依赖管理: 通过depends_on字段,可以轻松管理服务间的依赖关系。

  5. 可读性和文档化: docker-compose.yml文件也作为一种文档,可以让其他开发者或系统管理员快速了解应用的结构和服务。

  6. 网络配置: 简化了容器间网络连接的设置,自动配置了一个默认的网络环境。

  7. 缩放和负载均衡: 使用docker-compose可以方便地扩展服务的实例数量。

Docker Compose构建的缺点:

  1. 复杂性: 对于单一应用或只有一个服务的简单项目,使用Docker Compose可能显得过于复杂。

  2. 学习曲线: 相较于Docker单命令,需要时间学习docker-compose.yml文件的语法和选项。

  3. 不适用于生产: Docker Compose主要是为了简化开发和测试环境的配置,而不是用于生产环境。对于生产环境,更推荐使用如Kubernetes这样的容器编排工具。

  4. 资源消耗: 如果你在本地机器上运行多个容器,可能会消耗大量的资源。

Docker单台运行的优点:

  1. 简单快捷: 对于简单应用或单个服务,使用基础的Docker命令更为直接和快速。

  2. 更少的抽象: 没有额外的抽象层,有时候这样更容易理解和调试。

  3. 适用于生产: Docker容器可以在生产环境中单独运行,或者被集成到其他容器编排解决方案中。

Docker单台运行的缺点:

  1. 手动管理: 每个容器和服务都需要手动启动、停止和连接。

  2. 难以管理依赖: 如果有多个相互依赖的服务,手动管理它们会变得复杂和容易出错。

  3. 不易于复制: 没有一个统一的配置文件,迁移到另一台机器或共享给其他开发者会更困难。

  4. 缺乏自动化和一致性: 由于没有自动化脚本和定义好的配置,可能会导致环境不一致的问题。

        本文详细介绍了docker-compose在单台服务器上构建集群,虽然真实开发中并不会这样做,而是使用的真实的服务器,搭建集群。但是通过本次搭建的过程,可以知道docker-compose的基本应用。如果道友有足够的时间,部署项目时不妨改造试试,假设你的微服务项目有:study_front,study_backend1,study_backend2,mysql等等。使用docker-compose部署构建可以很方便的管理和维护,迁移到别处也不会因为环境问题而头疼。

        至此,一个使用docker-compose搭建nacos集群完毕,恭喜道友在学习之路上更进一步。这学习大道茫茫,然而你我都是这条路上的苦行僧,在此留下心得,祝你我都能修的圆满。咱们下一个路口(BUG)见!

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

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

相关文章

kubernets挑战实验一(| pvc | pod | services | rolebinding | context)

参考&#xff1a; https://kubernetes.io/zh-cn/docs/tasks/access-application-cluster/configure-access-multiple-clusters/ Deploy the given architecture diagram for implementing a Jekyll SSG. 1、创建pvc使用,以下条件限制 Storage Request: 1Gi Access modes: Re…

【WSL 2】Windows10 安装 WSL 2,并配合 Windows Terminal 和 VSCode 使用

【WSL 2】Windows10 安装 WSL 2&#xff0c;并配合 Windows Terminal 和 VSCode 使用 1 安装 Windows Terminal2 安装 WSL 23 在 Windows 文件资源管理器中打开 WSL 项目4 在 VSCode 中使用 WSL 24.1 必要准备4.2 从 VSCode 中 Connect WSL4.3 从 Linux 中打开 VSCode 1 安装 W…

✔ ★【备战实习(面经+项目+算法)】 10.29学习

✔ ★【备战实习&#xff08;面经项目算法&#xff09;】 坚持完成每天必做如何找到好工作1. 科学的学习方法&#xff08;专注&#xff01;效率&#xff01;记忆&#xff01;心流&#xff01;&#xff09;2. 每天认真完成必做项&#xff0c;踏实学习技术 认真完成每天必做&…

企业微信接入芋道SpringBoot项目

背景&#xff1a;使用芋道框架编写了一个数据看板功能需要嵌入到企业微信中&#xff0c;方便各级人员实时观看 接入企业微信的话肯定不能像平常pc端一样先登录再根据权限看页面&#xff0c;不然的话不如直接手机浏览器打开登录账号来得更为方便&#xff0c;所以迎面而来面临两…

在CentOS上用yum方式安装MySQL8过程记录

此文参考官方文档一步一步记录安装到正常运行全过程 安装环境&#xff1a;centos7 mysql版本&#xff1a;8.0.35 安装过程主要参考下面两边文章&#xff1a; 1.官方文档 https://dev.mysql.com/doc/refman/8.0/en/linux-installation-yum-repo.html 2.linux yum安装mysql8 安…

css写个三角形

点击三角形&#xff0c;展开或者收起内容 <template><div><div class"zhankai" click"btn()">展开 <span :class"{sanjiao:true,rotate:flag}"></span></div><!-- 展示或者收起 --><el-collapse-…

Go 开发IDE全览:GoLand VS VSCode全面解析

一、引言 在软件开发的世界里&#xff0c;开发环境的选择与配置是成功项目的基础之一。特别是在Go&#xff08;又名Golang&#xff09;这样一个逐渐获得主流认同、在微服务和云计算领域有着广泛应用的编程语言中&#xff0c;选择合适的开发工具就显得尤为重要。虽然Go语言自身…

博通BCM575系列 RDMA 网卡驱动 bnxt_re 分析(一)

简介 整个BCM系列驱动分成以太网部分(bnxt_en.ko)和RDMA部分(bnxt_re.ko), 两个模块之间通过内核的auxiliary_bus进行管理.我们主要分析下bnxt_re驱动. 代码结构 这个驱动的核心是 qplib_fp.c, 这个文件主要包含了驱动的数据路径, 包括Post Send, Post Recv, Poll CQ流程的实…

Android NDK开发详解之Application.mk探秘

Android NDK开发详解之Application.mk探秘 概览变量APP_ASFLAGSAPP_ASMFLAGSAPP_BUILD_SCRIPTAPP_CFLAGSAPP_CLANG_TIDYAPP_CLANG_TIDY_FLAGSAPP_CONLYFLAGSAPP_CPPFLAGSAPP_CXXFLAGSAPP_DEBUGAPP_LDFLAGSAPP_MANIFESTAPP_MODULESAPP_OPTIMAPP_PLATFORMAPP_PROJECT_PATHAPP_STL…

Amaon CloudFront助力出海业务访问优化

企业的展示网站需要面向多个国家的客户时&#xff0c;由于地理位置的原因。往往会出现一个痛点&#xff0c;网络延迟太高&#xff0c;以至于图片、视频播放时会非常卡顿。客户的访问体验非常差&#xff0c;直接影响到企业收益。此篇文章九河云综合分析Amaon CloudFront&#xf…

matplotlib论文图片配色

还在为配图的颜色而烦恼嘛&#xff0c;还在为matplotlib的经典颜色而困惑嘛&#xff0c;看完下面的文章&#xff0c;教你如何选择图片颜色 上图左边是matplotlib默认的颜色系统&#xff0c;而右边就是使用matplotlib自带的颜色系统实现的。如何实现&#xff0c;请继续往下浏览 …

当面试问你接口测试时,不要再说不会了

很多人会谈论接口测试。到底什么是接口测试&#xff1f;如何进行接口测试&#xff1f;这篇文章会帮到你。 前端和后端 在谈论接口测试之前&#xff0c;让我们先明确前端和后端这两个概念。 前端是我们在网页或移动应用程序中看到的页面&#xff0c;它由 HTML 和 CSS 编写而成…

五分钟理解Java跨平台原理(适合小白)

JVM通俗的理解 Java语言的一个非常重要的特点就是与平台的无关性。而使用Java虚拟机&#xff0c;即JVM&#xff08;Java Virtual Machine&#xff09;是实现这一特点的关键。JVM是一种用于计算设备的规范&#xff0c;它是一个虚构出来的计算机&#xff0c;是通过在实际的计算机…

大厂面试题-什么是JVM

JVM全称是Java虚拟机&#xff0c;在聊什么是JVM之前&#xff0c;我们不妨看⼀下这张图。 从这张图中可以看出JVM所处的位置&#xff0c;同时也能看出它两个作用&#xff1a; 1、运⾏并管理Java源码⽂件所⽣成的Class⽂件&#xff0c; 2、在不同的操作系统上安装不同的JVM&#…

瑞萨RH850-P1X ECM和英飞凌TC3xx SMU对比

1.1 基本结构 P1X ECM(Error Control Module)收集从不同的错误源和监控电路发来的错误信号&#xff0c;并通过error pin(ERROROUTZ)对外输出、产生中断并发出ECM reset信号。 P1x-C系列根据产品型号不同&#xff0c;ECM个数也不相同&#xff0c;如下&#xff1a; 对应寄存器基地…

Typora 最新激活方法

Markdown是一种可以使用普通文本编辑器编写的标记语言&#xff0c;通过简单的标记语法&#xff0c;它可以使普通文本内容具有一定的格式&#xff0c;其目标是实现易读易写。而Typora则是一个非常不错的Markdown编辑器&#xff0c;它的界面非常的简洁直观&#xff0c;并且功能各…

css画一条虚线,用到background-image:linear-gradient线性渐变的属性

CSS实现虚线的方法_css 虚线_saltlike的博客-CSDN博客 渐变属性(background-image)全解析_background-image linear_大聪明码农徐的博客-CSDN博客 Background:linear-gradient()详解_background: linear-gradient_小白白中之白的博客-CSDN博客 注意&#xff1a; 必须要写高…

Gateway服务网关

本篇资料&#xff1a;https://gitee.com/Allengan/cloud-demo.githttps://gitee.com/Allengan/cloud-demo.git 目录 1.为什么需要网关 2.gateway快速入门 1&#xff09;创建gateway服务&#xff0c;引入依赖 2&#xff09;编写启动类 3&#xff09;编写基础配置和路由规则…

Spring更加简单的读取和存储对象

前言&#xff1a;在上篇文章中&#xff0c;小编写了一个Spring的创建和使用的相关博客&#xff1a;Spring的创建和使用-CSDN博客&#xff0c;但是&#xff0c;操作/思路比较麻烦&#xff0c;那么本文主要带领大家走进&#xff1a;Spring更加简单的读取和存储对象&#xff01; 本…

1300*C. Social Distance(贪心构造)

Problem - 1367C - Codeforces 解析&#xff1a; 统计出所有连续0序列&#xff0c;并且记录其左右两侧有没有1&#xff0c;然后对于四种情况分别判断即可。 #include<bits/stdc.h> using namespace std; int t,n,k; signed main(){scanf("%d",&t);while(…