小阿轩yx-案例:jenkins部署Maven和NodeJS项目

小阿轩yx-案例:jenkins部署Maven和NodeJS项目

前言

  • 在 Java 项目开发中,项目的编译、测试、打包等是比较繁琐的,属于重复劳动的工作,浪费人力和时间成本。
  • 以往开发项目时,程序员往往需要花较多的精力在引用 jar 包搭建项目环境上,跨部门甚至跨人员之间的项目结构都有可能不一样。
  • Maven 的仓库管理、依赖管理、继承和聚合等特性为项目的构建提供了一整套完善的解决方案。
  • 将 Maven 集成到 jenkins 环境中,为开发人员的编译、打包、部署,测试等工作,提供了高效率的集成环境。

开发相关概念

什么是 Maven

  • 每一个开发工具(IDE)都有自己不同的项目结构,它们互相之间不通用。
  • 比如我在 eclipse 中创建的目录,无法在 idea 中进行使用,这就造成了很大的不方便。

Maven

  • 提供了一套标准化的项目结构,所有的 IDE 使用 Maven 构建的项目完全一样,所以 IDE 创建的 Maven 项目可以通用。
  • Apache 软件基金会组织维护的一款自动化构建工具,专注服务于 Java 平台的项目构建和依赖管理。
  • 这个单词的本意是:专家,内行。
  • 读音是 [ 'meɪvn ]。
  • Maven 项目对象模型(POM)是可以通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

Maven 的作用

项目构建

  • Maven 自动化 Java 项目的构建过程。
  • 它根据预定的生命周期并执行各个生命周期阶段的任务,实现编译、测试、打包等,并确保构建的一致性和可重复性。

依赖管理

  • Maven 根据 pom.xml 文件的依赖信息自动下载和管理库和框架。
  • 它规范了依赖解析和库搜索过程,避免了版本冲突和传递问题。

项目信息管理

  • Maven 利用 pom.xml 文件描述的项目信息生成报告和文档。
  • 提高了项目的可读性可维护性

插件及扩展

  • Maven 通过插件系统实现高度可扩展性
  • 插件增强项目功能,如代码生成、代码质量检查、测试报告等。

多模块项目支持

  • Maven 支持创建多模块项目,简化大型项目的组织和管理。
  • 多模块项目共享依赖、插件和属性配置,方便项目配置和维护。

持续集成

  • Maven 与各种持续集成工具(如 Jenkins、Travis CI等)相结合,实现项目的自动化构建、测试和部署等,有助于提高项目的质量和交付速度。

什么是构建

  • 就是以我们编写的 Java 代码、框架配置文件、其他资源文件、JSP 页面和图片等静态资源作为 “原材料”,去 “生产” 出一个可以运行的项目的过程。

构建过程的几个主要环节

  • 清理:删除以前的编译结果,为重新编译做好准备。
  • 编译:将 Java 源程序编译为字节码文件。
  • 测试:针对项目中的关键点进行测试,确保项目在迭代开发过程中关键点的正确性
  • 报告:在每一次测试后以标准的格式记录和展示测试结果。
  • 打包:将一个包含诸多文件的工程封装为一个压缩文件用于安装或部署。Java 工程对应 jar 包,Web 工程对应 war 包。
  • 安装:在 Maven 环境下特指将打包的结果— jar 包或 war 包安装到本地仓库中。
  • 部署:将打包的结果部署到远程仓库或将 war 包部署到服务器上运行。

自动化构建

为什么要使用 Maven 这样的构建工具呢?

  • 看一个程序员在某一天的工作
  • 托马斯像往常一样早早的来到了公司,冲好一杯咖啡,打开了自己的邮箱 -- 很不幸,QA 小组发来了一封邮件,报告了他昨天提交的模块的测试结果 -- 有 BUG。
  • “好吧,反正也不是第一 次”,托马斯摇摇头进入 IDE,运行自己的程序,编译、打包、部署到服务器上,然后按照邮件中的操作路径进行测试。
  • “嗯没错,这个地方确实有问题”,托马斯说道。
  • 于是托马斯开始尝试修复这个 BUG,当他差不多有眉目的时候已经到了午饭时间。
  • 下午继续工作。BUG 很快被修正了,接着托马斯对模块重新进行了编译、打包、部署,测试之后确认没有问题了,回复了 QA 小组的邮件。
  • 一天就这样过去了,然而第二天、第三天,基本都是这样度过的。

梳理一下托马斯这一天中的工作内容

从中我们发现,托马斯的很大一部分时间花在了 “编译、打包、部署、测试” 这些程序化的工作上面,而真正需要有人接介入实现的分析问题和编码环节其实只占了很少一部分,如下图

能将这些程序化的工作交给机器自动完成么?

  • 当然是可以的,这就是自动化构建。

这样构建的流程就成了下图所示的过程

  • 此时 Maven 的意义就体现了出来,它可以自动的从构建过程的起点一致执行到终点

Maven 核心 -- pod 文件

  • Maven 能够实现自动化构建是和它的内部原理分不开的,而构建过程离不开一个关键对象,就是 pom 文件。

pom

  • 全称为 project object model,意思为项目对象模型
  • 通过 xml 表示 maven 项目,使用 pom.xml 来实现。
  • pom 文件是 Maven 项目的核心文件之一,包含了 Maven 项目的所有配置信息。

pom 文件

  • 是对项目描述:包括配置文件,开发者需要遵循的规则,组织和项目的 url,项目的依赖性,以及其他所有的项目相关因素。
  • 是 Maven 的重要组成部分,可以帮助开发者管理和构建项目。
  • 使用 Maven 进行项目构建时,需要根据项目的需要配置 pom 文件。
  • Maven 借助于这个文件,就可以自动化构建、测试、打包和发布 Java 项目。

Maven 项目自动化部署流程

电子商城项目简介

  • 作为后端开发人员,不仅需要开发项目,有时候还需要对项目进行部署,这时就少不了和 Linux 和 Docker 打交道。

mall 商城项目简介

  • mall 项目是一套电商系统,包括前台商城系统及后台管理系统,基于SpringBoot+MyBatis 实现采用 Docker 容器化部署。
  • 前台商城系统包含首页门户、商品推荐、商品搜索、商品展示、购物车、订单流程、会员中心、客户服务、帮助中心等模块。
  • 后台管理系统包含商品管理、订单管理、会员管理、促销管理、运营管理、内容管理、统计报表、财务管理、权限管理、设置等模块。

系统架构图

业务架构图

设备清单

主机名IP 地址软件包备注
Jenkins192.168.10.104Jenkins
gitlab192.168.10.105gitlab代码仓库
mall192.168.10.101dockermall 服务器

mall 商城运行环境部署

docker 环境的安装

  • 可以直接使用先有的 docker 环境

将所需的镜像通过 Xftp 上传至服务器(101)

进入镜像目录并导入镜像

[root@localhost ~]# cd images/
[root@localhost images]# bash imp_docker_img.sh

修改主机名

[root@localhost ~]# hostnamectl set-hostname mall
[root@localhost ~]# bash

开启 Docker 的远程管理 API

  • 因为 jenkins 直接在 docker 主机中生成镜像,所以 docker 主机需要开启远程 API,以便能够实现镜像的远程推送
[root@mall ~]# vim /usr/lib/systemd/system/docker.service
##修改以下内容
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock -H tcp://0.0.0.0:2375
  • -H tcp://0.0.0.0:2375

重载并重启 docker 进程

[root@mall ~]# systemctl daemon-reload
[root@mall ~]# systemctl restart docker

MySQL 安装

[root@mall ~]# docker pull mysql:5.7

使用命令启动 MySQL 服务

[root@mall ~]# docker run -p 3306:3306 --name mysql -v /mydata/mysql/log:/var/log/mysql -v /mydata/mysql/data:/var/lib/mysql -v /mydata/mysql/conf:/etc/mysql -e MYSQL_ROOT_PASSWORD=root -d mysql:5.7

参数说明

  • -p 3306:3306:将容器的 3306 端口映射到主机的 3306 端口
  • -v /mydata/mysql/conf:/etc/mysql:将配置文件夹挂在到主机
  • -v /mydata/mysql/log:/var/log/mysql:将日志文件夹挂载到主机
  • -v/mydata/mysql/data:/var/lib/mysql/:将数据文件夹挂载到主机
  • -e MYSQL_ROOT_PASSWORD=root:初始化 root 用户的密码

上传数据库脚本 mall.sql 到当前工作目录

将 mall.sql 文件拷贝到 mysql 容器的 / 目录下

[root@mall ~]# docker cp mall.sql mysql:/

进入运行 MySQL 的 docker 容器

[root@mall ~]# docker exec -it mysql /bin/bash

登录到 msql

root@fe01d531da7a:/# mysql -uroot -proot --default-character-set=utf8

创建 mall 数据库

mysql> create database mall character set utf8;

进入 sql 脚本并导入到数据库

mysql> use mall;
Database changed
mysql> source /mall.sql;

设置授权

  • 创建一个 reader:123456 帐号并修改权限,使得任何 ip 都能访问
mysql> grant all privileges on *.* to 'reader'@'%' identified by '123456';
Query OK, 0 rows affected, 1 warning (0.00 sec)

退出容器

mysql> exit
Bye
root@fe01d531da7a:/# exit
exit

将所需的 elasticsearch 包上传至服务器(101)

修改虚拟内存区域大小,否则会因为过小而无法启动

[root@mall ~]# sysctl -w vm.max_map_count=262144
vm.max_map_count = 262144

启动 Elasticsearch 服务

[root@mall ~]# docker run -p 9200:9200 -p 9300:9300 --name elasticsearch -e "discorvery.type=single-node" -e "cluster.name=elasticsearch" -e "ES_JAVA_OPTS=-Xms512m -Xmx1024m" -v /mydata/elasticsearch/plugins:/usr/share/elasticsearch/plugins -v /mydata/elasticsearch/data:/usr/share/elasticsearch/data -d elasticsearch:7.17.3
  • 内存小的服务器可以通过 ES_JAVA_OPTS 来设置占用内存大小

修改 /mydata/elasticsearch/data 目录的权限

[root@mall ~]# chmod 777 /mydata/elasticsearch/data/
  • /usr/share/elasticsearch/data 目录没有访问权限,只需要修改 /mydata/elasticsearch/data 目录的权限,再重新启动即可。

下载中文分词器 IKAnalyzer(已有理想安装包,此步骤可跳过)

IKAnalyzer

  • 是一个开源的,基于 java 语言开发的轻量级的中文分词工具包

IK

  • 是目前最为流行的中文分词器,它是一个基于 Maven 构建的项目,具有 60万字/秒的高速处理能力;
  • 并且支持用户词典护展定义。

注意下载与 Elasticsearch 对应的版本

下载地址

https://github.com/medcl/elasticsearch-analysis-ik/releases

注意对应好版本要使用 7.17.3 的版本,本案例的 Elasticsearch 版本为 7.17.3,需要的 analysis-ik也是 7.17.3

下载所需的 unzip 压缩包

[root@mall ~]# yum -y install unzip

将其解压到 /mydata/elasticsearch/plugins/analysis-ik/ 目录中

[root@mall ~]# unzip elasticsearch-analysis-ik-7.17.3.zip -d /mydata/elasticsearch/plugins/analysis-ik

查看总用量

[root@mall ~]# ll /mydata/elasticsearch/plugins/analysis-ik/
总用量 1432
-rw-r--r--. 1 root root 263965 1月  18 2022 commons-codec-1.9.jar
-rw-r--r--. 1 root root  61829 1月  18 2022 commons-logging-1.2.jar
drwxr-xr-x. 2 root root   4096 1月  18 2022 config
-rw-r--r--. 1 root root  54931 4月  27 2022 elasticsearch-analysis-ik-7.17.3.jar
-rw-r--r--. 1 root root 736658 1月  18 2022 httpclient-4.5.2.jar
-rw-r--r--. 1 root root 326724 1月  18 2022 httpcore-4.4.4.jar
-rw-r--r--. 1 root root   1807 4月  27 2022 plugin-descriptor.properties
-rw-r--r--. 1 root root    125 4月  27 2022 plugin-security.policy

重启服务

[root@mall ~]# docker restart elasticsearch

Nginx 安装

  • nginx 为 mall 电商平台的管理前端提供的访问入口

下载 Nginx1.22 的 docker 镜像

[root@mall ~]# docker pull nginx:1.22

先运行一次容器(为了拷贝配置文件)

[root@mall ~]# docker run -p 80:80 --name nginx -v /mydata/nginx/html:/usr/share/nginx/html -v /mydata/nginx/logs:/var/log//nginx -d nginx:1.22

设置网站目录权限

[root@mall ~]# chmod -R 755 /mydata/nginx/html/

利用 Jenkins 部署 mall 商城后台程序

为 Jenkins 安装 maven 环境

(如果已经安装过,可以跳过此步)

解压

[root@jenkins ~]# tar zxvf apache-maven-3.8.6-bin.tar.gz

将 maven 移动到指定目录下

[root@jenkins ~]# mv apache-maven-3.8.6-bin.tar.gz /usr/local/maven/

设置 java 和 maven 的环境变量

[root@jenkins ~]# vim /etc/profile
##在文件末尾添加
export JAVA_HOME=/usr/local/java
export CLASSPATH=$JAVA_HOME/lib:$CLASSPATH
export PATH=$JAVA_HOME/bin:$PATH
export MAVEN_HOME=/usr/local/maven
export PATH=$PATH:/$MAVEN_HOME/bin
  • export MAVEN_HOME=/usr/local/maven
  • export PATH=$PATH:/$MAVEN_HOME/bin

让文件立即生效

[root@jenkins ~]# source /etc/profile

查看 maven 版本

[root@jenkins ~]# mvn -version
Apache Maven 3.8.6 (84538c9988a25aec085021c365c560670ad80f63)
Maven home: /usr/local/maven
Java version: 11.0.16.1, vendor: Oracle Corporation, runtime: /usr/local/java
Default locale: zh_CN, platform encoding: UTF-8
OS name: "linux", version: "6.9.7-1.el7.elrepo.x86_64", arch: "amd64", family: "unix"

修改 maven 更新源

[root@jenkins ~]# vim /usr/local/maven/conf/settings.xml
##修改 maven 的仓库
<mirrors>
    <mirror>
      <id>aliyunmaven</id>
      <mirrorOf>*</mirrorOf>
      <name>阿里云公共仓库</name>
      <url>https://maven.aliyun.com/repository/public</url>
    </mirror>
<mirrors>

阿里提供了 maven 更新源,可访问阿里官方网站查看详细信息

https://maven.aliyun.com

  •     <mirror>
  •       <id>aliyunmaven</id>
  •       <mirrorOf>*</mirrorOf>
  •       <name>阿里云公共仓库</name>
  •       <url>https://maven.aliyun.com/repository/public</url>
  •     </mirror>

为 Jenkins 配置 JDK 环境

  • 在 Jenkins 首页中,单击 “Manage Jenkins” → “system Configuration” → “Tools” → “JDK安装”,点击 “新增 JDK”,并取消勾选 “Install automatically”。
  • JDK 别名设置为 “jdk-11”,JAVA HOME 设置为本案例中 JDK 实际安装路径 “/usr/local/java”。

为 Jenkins 配置 Maven 环境

  • 找到 “Maven 安装” 选项,然后单击 “新增 Maven”,取消勾选 “Install automatically”,并设置 Name(名称)为 “maven”、MAVEN HOME 为 “/usr/local/maven”。

  • 以上各项配置完毕后,点击保存按钮,推荐重启下 Jenkins 服务

可以在这里做个快照,方便后续使用

gitlab 中创建项目

gitlab 中导入gitee 中的 mall 项目

在 gitlab 中导入 mall 项目

  • https://gitee.com/kgc-wjq/mall.git

参数如下图

修改代码

  • 直接在 gitlab 中修改项目文件 pom.xml 的代码。
  • 将远程 docker 主机的 ip 地址设置为本案例中的 docker 主机的 IP 地址:192.168.10.101。
  • 修改好后点击提交修改的按钮。

获取 gitlab 仓库 URL

链接

  • http://192.168.10.105/root/mall.git

在 jenkins 中添加 SSH Server

  • “Manage Jenkins” --> “System”,添加 “Publish over SSH”,点击 SSH Servers 的新增按钮,添加一个 SSH 的主机。
  • 参数如下图,并保存设置。

为 Jenkins 添加 SSH remote hosts

  • 本案例中,要通过 Jenkins 在 docker 主机上执行命令,需要将 docker 添加为 Jenkins 的 ssh 远程主机

为 docker 主机添加凭据

添加 SSH remote hosts

  • “Dashboard” --> “Manage Jenkins” --> “System” -- > “SSH remote hosts”

新建 Item

设置项目参数

源码管理设置

  • 源码管理中,选中 “Git”,并在仓库 URL 中填写 mall 项目代码仓库的 URL 地址,在指定分支中将分支填写为 “*/main”。
  • http://192.168.10.105/root/mall.git

设置 maven 构建参数

  • 选择 “Build” 模块,“Goals and options” 填写 “clean package”。

在 Build 下配置 Goals and options,即给 mvn 命令的参数这里可以设置的 maven 参数如下

mvn clean

  • 清理环境,清除 target 文件夹。

mvn compile

  • 编译,将 Java 源文件编译成 class 文件。

mvn test

  • 执行 test 目录下的测试用例。

mvn package

  • 打包,将 Java 工程打成 jar 包。

mvn clean package -Dmaven.test.skip=true

  • 跳过单元测试

添加 “Post steps” -- “Execute shell”

  • 在 “Post steps” 选项中,点击 “Add post-build step” 按钮,添加一个构建后的步 “Executeshell”,这里需要将后台程序的启动脚本目录 mall-sh 上传到 Jenkins 主机的 root 家目录下,然后在下图界面中设置同步脚本:scp -r /root/mall-sh 192.168.10.101:/root。

此命令是在 Jenkins主机上执行的。

添加 “Post steps” -- “Execute shell script on remote host using ssh”

  • 点击 “Add post-build step” 按钮,选择 “Execute shell script on remote host using ssh”,添加要在远程主机执行的脚本。
  • 此插件时利用 ssh 协议在远程主机上执行命令,因此,Jenkins 主机和远程的 docker 主机之间需要有免密连接的环境。

注意这个脚本是放在远程主机上的。

  • 上一步中,我们用 scp 的方法将脚本拷贝到了远程主机。
  • 这个步骤中,就需要在远程主机中执行这些脚本。

设置如下

  • chmod +x /root/mall-sh/*
  • /root/mall-sh/mall-admin.sh
  • /root/mall-sh/mall-search.sh
  • /root/mall-sh/mall-portal.sh

设置免密连接

[root@jenkins ~]# ssh-keygen
[root@jenkins ~]# ssh-copy-id 192.168.10.101
  • 如果 Jenkins 主机已有 ssh 密钥对,可以不必生成,直接执行 ssh-copy-id 即可。

保存并构建

  • 保存设置后点击 “Build Now”。
  • 第一次构建需要较长的时间。
  • 此步骤需要联网,注意网络状态。
  • 如果网络状态不好,会影响拉取 maven 更新源的 jar 包,最终导致构建失败。
  • 构建过程需要利用 java 镜像,需要在 docker 主机中提前拉取好 iava 的镜像。

访问后台程序验证结果

mall-admin 的后台系统 api 接口文档地址

  • http://192.168.10.101:8080/swagger-ui/

mall-search 的搜索系统 api 接口文档地址

  • http://192.1658.10.101:8080/swagger-ui/

mall-portal 的前台 api 接口文档地址

  • http://192.168.10.101:8085/swagger-ui/

使用 Jenkins 一键打包部署 NodeJS 前端应用

什么是 NodeJS

  • Javascript 诞生于 1995 年,几乎是和互联网同时出现;
  • Node.js 诞生于 2009 年,比 Javascript 晚了 15 年左右。

  • 在 Node.js 之前,Javascript 只能运行在浏览器中,作为网页脚本使用,为网页添加些特效,或者和服务器进行通信。
  • 有了 Node.js 以后,Javascript 就可以脱离浏览器像其它编程语言一样直接在计算机上使用,想干什么就干什么,再也不受浏览器的限制了。
  • Node.is 并不是一门新的编程语言,也不是一个 Javascript 的框架,它是一套 JavaScript 运行环境,用来支持 Javascript 代码的执行。
  • 用编程术语来讲,Node.js 是一个 Javascript 运行时(Runtime)。

为 jenkins 安装 NodeJS

(如果已装过,可以跳过此步)

  • 对 NodeJS 项目进行构建的时候,需要 g++的编译环境,不同的项目 Node]s 的版本也不一样,在进行部署的时候要根据项目的依赖版本进行选择。

下载安装所需的相关依赖包

[root@jenkins ~]# yum -y install gcc* automake autoconf libtool make

将所需的 node tar 包上传至服务器(104)

解压

[root@jenkins ~]# tar zxvf node-v14.18.0-linux-x64.tar.gz

移动到指定目录下

[root@jenkins ~]# mv node-v14.18.0-linux-x64 /usr/local/nodejs14

链接文件

[root@jenkins ~]# ln -s /usr/local/nodejs14/bin/* /usr/local/bin/

查看 node 和 npm 的版本

[root@jenkins ~]# node -v
v14.18.0
[root@jenkins ~]# npm -v
6.14.15

gitlab 添加项目

gitlab 中创建项目

在 gitlab 中导入mall-admin-web 项目

  • 项目的 gitee 仓库链接为:https://gitee.com/kgc-wjq/mall-admin-web.git

参数如下

修改代码

  • 修改 config 目录下 “prod.env.js” 文件将 BASE_API 接口地址修改 “http://192.168.10.101:8080”,并提交修改。

拷贝出项目的仓库 URL

  • http://192.168.10.105/root/mall-admin-web.git

构建 NodeJS 项目

构建一个自由风格的软件项目

设置源码管理

  • 选中 “Git”,并将 mall-admin-web 的项目仓库 URL 填写进去,修改分支为 “*/main”

添加一个执行 shell 的构建

  • 在 “Build Steps” 中,点击增加构建步骤按钮,增加一个 “Execute shell”
  • 添加一个执行 shell 的构建,用于将我们的前端代码进行编译打包

脚本代码如下

  • 如果 npm 镜像站无法使用,会导致构建失败,可以替换为其他的镜像服务器

国内 npm 镜像站

  • npm config set registry https://registry.npmmirror.com
  • npm config set registry http://mirrors.cloud.tencent.com/npm/
  • npm config set registry https://mirrors.huaweicloud.com/repository/npm/

增加构建后操作

  • 在 “构建后操作” 中,增加 “Send build artifacts over ssH”,利用该插件在远程 docker 主机上执行命令,此处需要在 docker 主机上为网站目录授权,否则,当把项目推送到 docker 主机后,其网站目录的权限不足,页面会提示 403 的错误。

授权命令为

  • chmod -R 755 /mydata/nginx/html/

如下图

保存设置后开始构建

登录前端验证项目部署结果

  • http://192.168.10.101

默认账号密码

  • admin
  • macro123

APP 端测试

  • APP 端在测试的时候可以使用 HBuilderx,这是一个手机端的模拟器,可以测试 APP 应用程序。

导入 APP 项目

  • 在 windows 中使用 HBuilderx导入 mall-app-web-1.0.0 项目,在 “文件” 菜单中导入本地项目,找到 “mall-app-web-1.0.0” 的项目文件夹,导入即可。

修改 mall-app-web 连接地址

  • 访问在线接口无需搭建后台环境,只需将 mall-app-web-1.0.0/utils/requestutil.js 文件中的config.baseUrl 改为线上地址即可,修改requestutil.js 文件内容

运行移动端网页

  • 在 HBuilder X 中使用 “运行” --> “运行到浏览器” --> “Chrome” 运行项目。
  • 如果是第一次执行,需要下载相关插件。

运行成功后会自动打开下面地址(将浏览器改为手机模式)

  • http://localhost:8060/

如果浏览器没有启动的话,可以直接访问如下地址访问

  • http://localhost:8060/

小阿轩yx-案例:jenkins部署Maven和NodeJS项目

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

MOELoRA —— 多任务医学应用中的参数高效微调方法

人工智能咨询培训老师叶梓 转载标明出处 在医疗场景中&#xff0c;LLMs可以应用于多种不同的任务&#xff0c;如医生推荐、诊断预测、药物推荐、医学实体识别、临床报告生成等。这些任务的输入和输出差异很大&#xff0c;给统一模型的微调带来了挑战。而且LLMs的参数众多&…

CSS3渐变

一、线性渐变 通过background-image: linear-gradient(...)设置线性渐变 语法&#xff1a; linear-gradient(direction,color1,color2, . . ) direction&#xff1a;渐变方向&#xff0c;默认从上到下&#xff0c;可选值&#xff1a; 简单选取&#xff1a; ① to right&…

SpringBoot框架下的教育系统开发全解析

1系统概述 1.1 研究背景 随着计算机技术的发展以及计算机网络的逐渐普及&#xff0c;互联网成为人们查找信息的重要场所&#xff0c;二十一世纪是信息的时代&#xff0c;所以信息的管理显得特别重要。因此&#xff0c;使用计算机来管理微服务在线教育系统的相关信息成为必然。开…

文章资讯职场话题网站源码整站资源自带2000+数据

介绍&#xff1a; 数据有点多&#xff0c;数据资源包比较大&#xff0c;压缩后还有250m左右。值钱的是数据&#xff0c;网站上传后直接可用&#xff0c;爽飞了 环境&#xff1a;NGINX1.18 mysql5.6 php7.2 代码下载

Jetson 开发系列:如何用GPU跑本地大模型?

最近刚入手一台 Jetson Ori Nano 开发板&#xff0c;前两篇把开发前的准备工作做了&#xff1a; 搭建本地环境&#xff1a;Jetson 开发系列&#xff1a;Orin Nano 开箱&#xff01;一款强大的嵌入式&物联网开发板管理音频设备&#xff1a;Jetson 开发系列&#xff1a;Linu…

使用Buildpacks构建Docker镜像

## 使用Buildpacks构建Docker镜像 ![](../assets/运维手册-Buildpacks-Buildpacks.io.png) ### Buildpacks简介 与Dockerfile相比&#xff0c;Buildpacks为构建应用程序提供了更高层次的抽象。具体来说&#xff0c;Buildpacks&#xff1a; * 提供一个平衡的控制&#xff0c;…

大佬,简单解释下“嵌入式软件开发”和“嵌入式硬件开发”的区别

在开始前刚好我有一些资料&#xff0c;是我根据网友给的问题精心整理了一份「嵌入式的资料从专业入门到高级教程」&#xff0c; 点个关注在评论区回复“888”之后私信回复“888”&#xff0c;全部无偿共享给大家&#xff01;&#xff01;&#xff01;首先&#xff0c;嵌入式硬…

【AIGC半月报】AIGC大模型启元:2024.10(上)

【AIGC半月报】AIGC大模型启元&#xff1a;2024.10&#xff08;上&#xff09; (1) YOLO11&#xff08;Ultralytics新作&#xff09; (1) YOLO11&#xff08;Ultralytics新作&#xff09; 2024.10.01 Ultralytics在 YOLO Vision 2024 活动上宣布发布其新的计算机视觉模型 YOLO…

无人机电力巡检:点亮电力巡检新视野!

一、无人机电力巡查的优势 提高巡检效率&#xff1a;无人机可以搭载高清摄像头、红外热像仪等先进设备&#xff0c;实时拍摄和传输图像&#xff0c;帮助巡检人员快速发现潜在问题&#xff0c;如电线破损、绝缘子污损、设备过热等&#xff0c;从而大大缩短了巡检周期。 降低人…

Vue+NestJS项目实操(图书管理后台)

一、项目搭建 前端基于vben进行二次开发 在Github下载vben框架&#xff0c;搜索vben即可 下载地址&#xff1a;https://github.com/vbenjs/vue-vben-admin 下载完成后&#xff0c;进行安装依赖&#xff0c;使用命令&#xff1a; // 下载依赖 pnpm install// 运行项目 pnpm …

开源的云平台有哪些?

开源云平台为用户提供了构建、管理和运行云基础设施及应用的能力&#xff0c;同时允许社区参与开发和改进。以下是一些知名的开源云平台&#xff1a; 1. OpenStack 简介&#xff1a;OpenStack&#xff1a;一个广泛使用的开源云平台&#xff0c;它由多个组件组成&#xff0c;提…

HTML+CSS - 表单交互(一)

1. 前言 ​​​​​​​ Web 表单是用于和用户交互的强大工具——其常用于收集用户数据和控制用户界面。 web 表单是用户和 web 站点或应用程序之间交互的主要内容之一。它们允许用户输入数据&#xff0c;大多数情况下会将数据发送到 web 服务器进行处理和存储 2. form标签 …

Redis篇(Redis原理 - RESP协议)

目录 一、简介 二、Redis通信协议 基于Socket自定义Redis的客户端 三、Redis内存回收 1. 过期key处理 1.1. 惰性删除 1.2. 周期删除 1.3. 知识小结 2. 内存淘汰策略 一、简介 Redis是一个CS架构的软件&#xff0c;通信一般分两步&#xff08;不包括pipeline和PubSub&a…

AI不可尽信

看到某项目有类似这样的一段代码 leaves : make([]int, 10) leaves leaves[:0]没理解这样的连续两行,有何作用? 初始化一个长度和容量都为10的切片,接着把切片长度设置为0 即如下demo: (在线地址) package mainimport "fmt"func main() {leaves : make([]int, 1…

M3u8视频由手机拷贝到电脑之后,通过potplayer播放报错找不到文件地址怎么解决?

该文章前面三节主要介绍M3u8视频是什么&#xff0c;视频播放错误(找不到地址)的解决方法在后面 M3U8是一种多媒体播放列表文件格式&#xff0c;主要用于流媒体播放。 一、文件格式特点 1. 文本文件&#xff1a;M3U8是一个采用 UTF-8 编码的文本文件&#xff0c;这意味着它可…

【STM32开发之寄存器版】(三)-详解NVIC中断

一、前言 STM32F103ZET6具备强大的中断控制能力&#xff0c;其嵌套向量中断控制器(NVIC)和处理器核的接口紧密相连&#xff0c;可以实现低延迟的中断处理和高效地处理晚到的中断。NVIC主要具备以下特性&#xff1a; 68个可屏蔽中断通道(不包含16个Cortex™-M3的中断线)&#xf…

经典文献阅读之--WiROS(用于机器人的WiFi感知工具箱)

0. 简介 近期的许多研究探索了使用基于WiFi的感知技术来改善SLAM&#xff08;同时定位与地图构建&#xff09;、机器人操控或探索。此外&#xff0c;WiFi的广泛可用性使其成为最具优势的射频信号。但WiFi传感器缺乏一个准确、易处理、多功能的工具箱&#xff0c;这限制了它们与…

VUE2常见问题以及解决方案汇总(不断更新中)

解决vue项目中 el-table 的 row-click 事件与行内点击事件冲突&#xff0c;点击事件不生效&#xff08;表格行点击事件和行内元素点击事件冲突&#xff09;需要阻止事件冒泡 问题描述 1.点击列的编辑按钮&#xff0c;会触发按钮本身事件&#xff0c;同时会触发行点击事件 2.点…

SaaS 应用如何助长网络犯罪

过去十年&#xff0c;软件即服务 (SaaS)的采用呈爆炸式增长&#xff0c;彻底改变了我们的工作方式。 从电子邮件平台到通信和协作应用程序&#xff0c;再到文件存储和共享服务&#xff0c;这些工具有望为我们的日常工作生活带来更大的灵活性和效率&#xff0c;尤其是在当今的远…

Linux环境基础开发工具使用(2)

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 Linux环境基础开发工具使用(2) 收录于专栏[Linux学习] 本专栏旨在分享学习Linux的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 1. Li…