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

k8s+helm部署tongweb7云容器版(by lqw)

安装准备

1.联系销售获取安装包和授权(例如:tongweb-cloud-7.0.C.6_P3.tar.gz)。
2.已安装docker和k8s集群,参考:
k8s集群搭建
3.有对应的docker私库,没有的可以参考:
harbor搭建
4.docker已经拉取对应的一些基础镜像,例如jdk(版本不低于1.8)。
5.安装helm,可参考Helm安装

测试和打包镜像

拿到安装包后,先解压并放入授权测试,测试可以正常运行并输出日志(需安装并配置jdk环境变量)。

在这里插入图片描述
然后看看logs目录下是否有日志滚动,如下为正常显示:

cd /opt/tongweb-cloud-7.0.C.6/tongweb/kernel/bin
./startservernohup.sh

在这里插入图片描述

停止tongweb(可以直接ps -ef |grep tongweb然后kill掉进程id,或者执行stopserver.sh这个脚本)。
把dockerfile-example复制过来,改名为Dockerfile:

在这里插入图片描述

在这里插入图片描述

cd到Dockerfile所在的目录,执行下面指令(tongweb:v70c6可根据需要修改):

docker build -t tongweb:v70c6 -f Dockerfile .

之后看看docker images里是否有对应镜像,测试是否能跑通

#tongweb:v70c6是指镜像名和版本
docker run -itd --name my_tongweb -p 8099:8080 -v /opt/tongweb-cloud-
7.0.C.6/tongweb:/opt/Tongweb tongweb:v70c6

查看日志没问题的话,打包和push到私库(192.168.10.126:80是本地安装好的harbor的私库地址)

docker tag tongweb:v70c6 192.168.10.126:80/tongweb7/tongweb:v70c6
docker push 192.168.10.126:80/tongweb7/tongweb:v70c6

查看私库是否已经有对应的镜像,例如可视化页面,或者指令:

在这里插入图片描述

[root@master .docker]# curl -u 'admin:harbor12345' -X GET
'http://192.168.10.126/api/v2.0/projects/tongweb7/repositories/tongweb/artifacts
'
[{"accessories":null,"addition_links":{"build_history":
{"absolute":false,"href":"/api/v2.0/projects/tongweb7/repositories/tongweb/artif
acts/sha256:6cfc4c6c6c14d1111d496b830285d13c4ca24f6fab1c10dd95bce9f17260ec67/add
itions/build_history"}},"digest":"sha256:6cfc4c6c6c14d1111d496b830285d13c4ca24f6
fab1c10dd95bce9f17260ec67","extra_attrs":
{"architecture":"amd64","author":"","config":{"ArgsEscaped":true,"Entrypoint":
["/opt/TongWeb/kernel/bin/startserver.sh"],"Env":
["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/lib/jvm
/java-1.8-openjdk/jre/bin:/usr/lib/jvm/java-1.8-openjdk/bin","LANG=C.UTF-
8","JAVA_HOME=/usr/lib/jvm/java-1.8-
openjdk","JAVA_VERSION=8u212","JAVA_ALPINE_VERSION=8.212.04-
r0","TZ=Asia/Shanghai"],"ExposedPorts":{"8088/tcp":{}}},"created":"2025-04-
10T11:12:32.784615336+08:00","os":"linux"},"icon":"sha256:0048162a053eef4d4ce3fe
7518615bef084403614f8bca43b40ae2e762e11e06","id":2,"labels":null,"manifest_media
_type":"application/vnd.docker.distribution.manifest.v2+json","media_type":"appl
ication/vnd.docker.container.image.v1+json","project_id":4,"pull_time":"2025-04-
10T03:25:46.345Z","push_time":"2025-04-
10T03:20:42.567Z","references":null,"repository_id":2,"size":139075466,"tags":
[{"artifact_id":2,"id":2,"immutable":false,"name":"v70c6","pull_time":"0001-01-
01T00:00:00.000Z","push_time":"2025-04-
10T03:20:42.607Z","repository_id":2}],"type":"IMAGE"}]
[root@master .docker]#

导出tongweb镜像以防万一,然后删掉docker里的tongwbe镜像,试试看能不能重新拉取下来:

docker save -o tongwebcloud_7.0.c.6.tar tongweb:v70c6
docker rmi -f 192.168.10.126:80/tongweb7/tongweb:v70c6
docker pull tongweb:v70c6

在这里插入图片描述

helm安装

下载地址

#解压安装包
tar -zxvf helm-v3.15.2-linux-amd64.tar
mv linux-amd64/helm /usr/local/bin/helm
helm version

在这里插入图片描述

到解压好的tongweb7的目录下,在对应路径找到chart.yaml(最好是自己单独复制一个helm目录出来去执行,这里只是为了演示方便)

在这里插入图片描述

在这里插入图片描述

修改helm目录下的values.yaml

在这里插入图片描述
在这里插入图片描述
将最新的tongweb.xml放入到helm的configs目录下
在这里插入图片描述

cd到helm目录的上一级目录,执行以下指令(其中default是k8s的命令空间,tongweb是指release_name,如果需要用其他的命令空间,可以使用指令:kubectl create namespace 自行创建)。

helm install --namespace default tongweb helm/

在这里插入图片描述
提示信息解读:

helm/:
如截图所示,这个路径指向 /opt/tongweb-cloud-7.0.C.6/tongweb/extends/templates/helm,
而该路径包含了一个 Helm chart 目录。
目录包含重要文件如 Chart.yaml 和 values.yaml,以及 templates/ 目录。
Chart.yaml 存储了 chart 的元信息,如名称、版本等。
values.yaml 用于定义 chart 的默认配置值。
templates/ 目录里面通常存储了 Kubernetes 资源的 YAML 模板。
命令结果:
Helm 成功将名为 tongweb 的 release 安装到了 default 命名空间中。
STATUS: deployed 表示资源已成功部署。
NOTES: 部分提供了一些使用提示,比如如何获取应用的 URL。这通常是 chart 定义者提供的信息,用于
帮助用户更好地使用部署后的应用。

使用kubectl get pods查看状态

在这里插入图片描述
如果状态如上图所示,可以使用指令

#tongweb-7849bf9554-gzf46为Name显示的信息
kubectl describe pod tongweb-7849bf9554-gzf46

在这里插入图片描述

这种情况下,修改仓库配置完毕后,卸载重装,卸载指令如下:

#其中tongweb为安装指令里的release-name
[root@master templates]# helm uninstall tongweb
release "tongweb" uninstalled
[root@master templates]# kubectl get pods
No resources found in default namespace.
[root@master templates]# helm list
NAME NAMESPACE REVISION UPDATED STATUS CHART APP VERSION
[root@master templates]#

重新安装和检查

[root@master templates]# kubectl get pods |grep tongweb
tongweb-bbff654f-v4h2r 1/1 Running 0 2m29s
[root@master templates]# kubectl describe pod tongweb-bbff654f-v4h2r
Name: tongweb-bbff654f-v4h2r
Namespace: default
Priority: 0
Node: node2/192.168.10.128
Start Time: Thu, 10 Apr 2025 15:20:50 +0800
Labels: app.kubernetes.io/instance=tongweb
app.kubernetes.io/name=tongweb
pod-template-hash=bbff654f
Annotations: sidecar.istio.io/inject: false
Status: Running
IP: 10.244.2.10
IPs:
IP: 10.244.2.10
Controlled By: ReplicaSet/tongweb-bbff654f
Containers:
tongweb:
Container ID:
docker://9a93d33bc315273dce919dede39c33ee5129509d2b2591d5b85e3d2cc80a95f6
Image: 192.168.10.126:80/tongweb7/tongweb:v70c6
Image ID: dockerpullable://192.168.10.126:80/tongweb7/tongweb@sha256:6cfc4c6c6c14d1111d496b83028
5d13c4ca24f6fab1c10dd95bce9f17260ec67
Ports: 8088/TCP, 8443/TCP
Host Ports: 0/TCP, 0/TCP
State: Running
Started: Thu, 10 Apr 2025 15:20:52 +0800
Ready: True
Restart Count: 0
Environment:
ENV_TYPE: cloud
POD_NAME: tongweb-bbff654f-v4h2r (v1:metadata.name)
MEM_REQUEST: 0 (requests.memory)
MEM_LIMIT: node allocatable (limits.memory)
Mounts:
/opt/TongWeb/kernel/autodeploy from autodeploy-volume (rw)
/opt/TongWeb/kernel/conf/tongweb.xml from tongweb-volume
(rw,path="tongweb.xml")
/opt/TongWeb/kernel/logs from log-volume (rw)
/var/run/secrets/kubernetes.io/serviceaccount from default-token-jj8c9
(ro)
Conditions:
Type Status
Initialized True
Ready True
ContainersReady True
PodScheduled True
Volumes:
log-volume:
Type: HostPath (bare host directory volume)
Path: /home/work/logs
HostPathType: DirectoryOrCreate
autodeploy-volume:
Type: EmptyDir (a temporary directory that shares a pod's lifetime)
Medium:
SizeLimit: <unset>
tongweb-volume:
Type: ConfigMap (a volume populated by a ConfigMap)
Name: tongweb
Optional: false
登录dashboard,可以看到有相关信息:
values.yaml文件配置说明
default-token-jj8c9:
Type: Secret (a volume populated by a Secret)
SecretName: default-token-jj8c9
Optional: false
QoS Class: BestEffort
Node-Selectors: <none>
Tolerations: node.kubernetes.io/not-ready:NoExecute op=Exists for 300s
node.kubernetes.io/unreachable:NoExecute op=Exists for 300s
Events:
Type Reason Age From Message
---- ------ ---- ---- -------
Normal Scheduled 2m40s default-scheduler Successfully assigned
default/tongweb-bbff654f-v4h2r to node2
Normal Pulling 2m39s kubelet Pulling image
"192.168.10.126:80/tongweb7/tongweb:v70c6"
Normal Pulled 2m39s kubelet Successfully pulled image
"192.168.10.126:80/tongweb7/tongweb:v70c6" in 83.379623ms
Normal Created 2m39s kubelet Created container tongweb
Normal Started 2m38s kubelet Started container tongweb

登录dashboard,可以看到有相关信息:
在这里插入图片描述

values.yaml文件配置说明

Plain Text
Default values for tongweb.
# This is a YAML-formatted file.
# Declare variables to be passed into your templates.
replicaCount: 1
#镜像地址和拉取策略
image:
repository: tongweb
tag: latest
pullPolicy: Always
#secret配置
imagePullSecrets: []
nameOverride: "tongweb"
fullnameOverride: ""
#配置tongweb运行所需的环境变量
env:
#环境类型为云上
- name: ENV_TYPE
value: "cloud"
- name: POD_NAME
valueFrom:
fieldRef:
fieldPath: metadata.name
- name: MEM_REQUEST
valueFrom:
resourceFieldRef:
resource: requests.memory
- name: MEM_LIMIT
valueFrom:
resourceFieldRef:
resource: limits.memory
#tongweb端口暴露配置
ports:
#tongweb http端口配置
- port-http: 8088
# tongweb https端口配置
- port-https: 8443
#tongweb挂载文件配置当前值支持hostpath,nfs,emptyDir,configmap挂载方式配置
#参数说明:
#name:表示挂载名称
#mountPath表示k8s容器中需要挂载的目录或者文件
#subPath 表示k8s容器中需要挂载的子目录或者文件
#下面介绍每一种挂载方式配置:
#hostpath挂载
#hostpah挂载参数说明
#hostPath:宿主机挂载目录
#hostpath挂载示例
#- name: log-volume
# mountPath: /opt/TongWeb/kernel/logs
# hostPath: /home/work/logs
#
#nfs挂载
#nfs挂载参数说明
#nfsPath:表示nfs服务器上面的挂载目录
#nfsServer:表示nfs服务器的ip地址
#nfs挂载示例
#- name: log-volume
# mountPath: /opt/TongWeb/kernel/logs
# nfsPath: /home/work/logs
# nfsServer: 127.0.0.1
#
#emptyDir挂载
#emptyDir挂载参数说明
#emptyDir:采用空目录挂载
#emptyDir挂载示例
#- name: log-volume
# mountPath: /opt/TongWeb/kernel/logs
# emptyDir: {}
#
#configMap挂载
#configMap参数说明
#configMapName: configMap名称
#configMap挂载示例
#- name: tongweb-volume
# mountPath: /opt/TongWeb/kernel/conf/tongweb.xml
# subPath: tongweb.xml
# configMapName: tongweb
#pvc挂载配置
#- name: autodeploy-volume
# mountPath: /opt/TongWeb/kernel/autodeploy
# pvc: autodeploy-pvc
mounts:
- name: log-volume
mountPath: /opt/TongWeb/kernel/logs
hostPath: /home/work/logs
- name: autodeploy-volume
mountPath: /opt/TongWeb/kernel/autodeploy
emptyDir: {}
- name: tongweb-volume
mountPath: /opt/TongWeb/kernel/conf/tongweb.xml
subPath: tongweb.xml
configMapName: tongweb
#pvc配置
#persistence:
# enabled: 开关
# pvc:
# - name: pvc名称
# accessMode: 访问模式
# size: 请求资源大小
# storageClass: storageClass名称
# annotations: 注解
persistence:
enabled: false
pvc:
- name: log-pvc
accessMode: ReadWriteOnce
size: 500Mi
storageClass: nfs-client
annotations: {}
- name: autodeploy-pvc
accessMode: ReadWriteOnce
size: 500Mi
storageClass: nfs-client2
annotations: {}
# initContainer容器配置,主要是支持应用的部署和文件的上传,利用initcontainer可以部署应用和上
传jar包
# initContainer参数说明
# enabled: initcontainer开关
# containers:容器配置
# - image: 镜像地址
# name: 容器名称
# packagePath: 镜像中文件的路径,建议都放置到同一个路径下面。采用同一个路径可以把所有的文件
都复制下来。
# mounts: 需要挂载到容器中的哪个挂载配置
# mountName: 挂载名称,对应上面的mounts的name配置
initContainers:
enabled: false
containers:
- image: testwar
name: application
packagePath: /opt/app/.
mounts:
- mountName: autodeploy-volume
#为了方面用户修改或替换tongweb.xml等配置文件,无需重新制作镜像,或者单独的创建每一个
configMap。tongweb helmchart提供一次性的创建所有的configMap,需要把配置文件放到根目录的
configs目录下,通过helm install就可创建所有的configmap
#configMapfile:
#- key: configMap中的key
# value: 配置文件的路径
# configMapName: configMap的名称
#configMapfile配置示例
#configMapfile:
#- key: "tongweb.xml"
# value: "configs/tongweb.xml"
# configMapName: tongweb
configMapfile:
- key: "tongweb.xml"
value: "configs/tongweb.xml"
configMapName: tongweb
serviceAccount:
# Specifies whether a service account should be created
create: false
# Annotations to add to the service account
annotations: {}
# The name of the service account to use.
# If not set and create is true, a name is generated using the fullname
template
name: ""
podAnnotations: {}
podSecurityContext: {}
# fsGroup: 2000
securityContext: {}
# capabilities:
# drop:
# - ALL
# readOnlyRootFilesystem: true
# runAsNonRoot: true
# runAsUser: 1000
# service访问配置
# type: 外部访问方式
# portParam:
# - name: port名称
# port: 内部访问端口配置
# targetPort: 目标端口配置
#当type类型为NodePort时可以固定nodePort
# nodePort: 外部访问端口
service:
type: NodePort
portParam:
- name: port-http
port: 9060
targetPort: 8088
# nodePort: 30021
ingress:
enabled: false
annotations: {}
# kubernetes.io/ingress.class: nginx
# kubernetes.io/tls-acme: "true"
hosts:
- host: chart-example.local
paths: []
tls: []
# - secretName: chart-example-tls
# hosts:
# - chart-example.local
resources: {}
# We usually recommend not to specify default resources and to leave this as a
conscious
# choice for the user. This also increases chances charts run on environments
with little
# resources, such as Minikube. If you do want to specify resources, uncomment
the following
# lines, adjust them as necessary, and remove the curly braces after
'resources:'.
# limits:
# cpu: 100m
# memory: 128Mi
# requests:
# cpu: 100m
# memory: 128Mi
autoscaling:
enabled: false
minReplicas: 1
maxReplicas: 100
targetCPUUtilizationPercentage: 80
# targetMemoryUtilizationPercentage: 80
nodeSelector: {}
tolerations: []
affinity: {}

相关文章:

k8s+helm部署tongweb7云容器版(by lqw)

安装准备 1.联系销售获取安装包和授权&#xff08;例如&#xff1a;tongweb-cloud-7.0.C.6_P3.tar.gz&#xff09;。 2.已安装docker和k8s集群&#xff0c;参考&#xff1a; k8s集群搭建 3.有对应的docker私库&#xff0c;没有的可以参考&#xff1a; harbor搭建 4.docker已经…...

关于DApp、DeFi、IDO私募及去中心化应用开发的综合解析

一、DApp&#xff08;去中心化应用&#xff09;技术开发 1. 技术架构与开发流程 分层架构 &#xff1a; 前端层 &#xff1a;使用React/Vue.js构建用户界面&#xff0c;通过Web3.js或Ethers.js与区块链交互。 智能合约层 &#xff1a;以太坊系常用Solidity&#xff0c;Solana…...

招贤纳士|Walrus 亚太地区招聘高级开发者关系工程师

职位介绍&#xff1a; 开发者关系团队&#xff08;Developer Relations&#xff09;通过线上线下方式与开发者社区互动&#xff0c;提供专业支持和指导&#xff0c;帮助他们在 Sui 和 Walrus 上构建下一代 Web3 应用。团队通过与社区对话&#xff0c;了解开发者的痛点&#xf…...

Qt实现文件传输客户端(图文详解+代码详细注释)

Qt实现文件传输客户端 1、 客户端UI界面设计2、客户端2.1 添加网络模块和头文件2.2 创建Tcp对象2.3 连接按钮2.3.1 连接按钮连接信号与槽2.3.2 连接按钮实现 2.4 读取文件2.4.1 连接读取文件的信号与槽2.4.2 读取文件槽函数实现2.5 进度条2.5.1 设置进度条初始值2.5.2 初始化进…...

STL详解 - list的模拟实现

目录 1. list 的基本结构 1.1 构造函数 2. 迭代器的实现 2.1 构造函数 2.2 自增和自减操作符 2.3 比较操作符 2.4 解引用和箭头操作符 3. list 容器的实现 3.1 构造函数 3.2 拷贝构造 3.3 赋值运算符重载 3.4 析构函数 3.5 迭代器相关函数 3.6 插入和删除函数 3.…...

ROS 2 的bag

ROS 1 和 ROS 2 的bag包互转方法 1. 安装rosbags工具&#xff1a; 使用pip安装最新版本的rosbags库&#xff08;确保版本大于等于0.9.15&#xff09; pip install rosbags --upgrade 2. db3文件bag包互转&#xff1a;使用rosbags-convert命令进行转换 rosbags-convert --sr…...

微软承认Win11出现极端错误,只能强制关机或重装系统

最近&#xff0c;不少使用 Windows 11 的用户反映&#xff0c;在系统更新后&#xff0c;“Windows Hello”突然失效&#xff0c;原本便捷的人脸识别和PIN登录功能统统无法使用。更糟的是&#xff0c;有人在重置系统后直接被挡在系统门外&#xff0c;这让人不禁发问&#xff1a;…...

bininote: 使用AI将视频转换了Markdown笔记

GitHub&#xff1a;https://github.com/JefferyHcool/BiliNote 更多AI开源软件&#xff1a;发现分享好用的AI工具、AI开源软件、AI模型、AI变现 - 小众AI BiliNote 是一个开源的 AI 视频笔记助手&#xff0c;支持通过哔哩哔哩、YouTube 等视频链接&#xff0c;自动提取内容并生…...

Python自动化办公

第五篇&#xff1a;Python自动化办公&#xff1a;10行代码搞定重复性工作 适合读者&#xff1a;职场人士、数据分析师 | 阅读时长&#xff1a;12分钟 引言 每天重复处理Excel、PDF或邮件&#xff1f;Python可以帮你自动化这些枯燥任务&#xff0c;节省90%的时间。本文通过实际…...

使用 tcpdump 工具,捕获并分析

一、 文章概述 使用 tcpdump 工具&#xff0c;捕获并分析了与 SM-DP&#xff08;Subscription Management Data Preparation&#xff09; 服务器之间进行 TLS&#xff08;Transport Layer Security&#xff09; 握手的过程的数据包&#xff0c;并对其进行了详细解读。 二、 主…...

【LInux网络】socket 编程 - 从ip端口到接口详解

&#x1f4e2;博客主页&#xff1a;https://blog.csdn.net/2301_779549673 &#x1f4e2;博客仓库&#xff1a;https://gitee.com/JohnKingW/linux_test/tree/master/lesson &#x1f4e2;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01; &…...

MCP:构建大型语言模型与外部系统无缝交互的标准协议架构

目录 引言MCP概述 2.1 MCP的定义2.2 MCP的起源与发展MCP的核心设计原理 3.1 上下文传递与交互3.2 数据安全与隐私保护3.3 统一通信协议MCP架构设计详解 4.1 模块化设计4.2 组件解析 4.2.1 Client Agent4.2.2 Context Manager4.2.3 API Adapter4.2.4 Security Layer4.3 设计原则…...

50常用控件_QPushButton

目录 QPushButton添加图标 QPushButton添加快捷键 代码示例: 按钮的重复触发 使用 QPushButton 表示一个按钮.这也是当前我们最熟悉的一个控件了 OPushButton 继承自 QAbstractButton .这个类是一个抽象类是其他按钮的父类 抽象类 这个类包含了 纯虚函数无法创建出实例(对象…...

Java的ForkJoinPool:深入理解并发编程的利器

在现代软件开发中&#xff0c;多核处理器的普及使得并发编程成为提升应用性能的关键。Java作为一门广泛使用的编程语言&#xff0c;提供了丰富的并发工具&#xff0c;其中ForkJoinPool是Java 7引入的一个强大组件&#xff0c;专为处理可递归分解的任务设计。它通过分治算法和工…...

结合 Python 与 MySQL 构建你的 GenBI Agent_基于 MCP Server

写在前面 商业智能(BI)正在经历一场由大型语言模型(LLM)驱动的深刻变革。传统的 BI 工具通常需要用户学习复杂的界面或查询语言,而生成式商业智能 (Generative BI, GenBI) 则旨在让用户通过自然语言与数据交互,提出问题,并获得由 AI 生成的数据洞察、可视化建议甚至完整…...

道路运输安全员企业负责人考试内容与范围

道路运输企业主要负责人&#xff08;安全员&#xff09;考证要求 的详细说明&#xff0c;适用于企业法定代表人、分管安全负责人等需取得的 《道路运输企业主要负责人和安全生产管理人员安全考核合格证明》&#xff08;交通运输部要求&#xff09;。 考试内容与范围 1. 法律法…...

一体化安全管控平台:消防“一张图”与APP统一管理的创新模式

在科技飞速发展的当下&#xff0c;智慧消防已成为消防救援行业不可阻挡的发展趋势。随着城市化进程的加速&#xff0c;城市规模不断扩大&#xff0c;建筑结构愈发复杂&#xff0c;传统的消防管理模式逐渐暴露出诸多弊端&#xff0c;难以满足现代社会对消防安全的高标准要求。 智…...

利用pnpm patch给第三方库打补丁

如果在使用第三方库的时候, 发现bug, 但是等不了官方补丁, 可以使用pnpm patch给第三方库打补丁来解决, 类似 git diff, 操作如下: 在package.json所在目录的命令行执行 pnpm patch jiaminghi/data-view执行完这个命令后会生成临时文件夹供你编辑, 然后开始编辑这个临时文件夹…...

Spark-SQL(三)

一. 数据加载与保存 1. 数据加载: spark.read.load 是加载数据的通用方法。 spark.read.format("…")[.option("…")].load("…") 1&#xff09;format("…")&#xff1a;指定加载的数据类型。 2&#xff09;load("…"…...

centosu7 二进制安装mysql5.7

一、准备工作 1. 卸载原有MariaDB&#xff08;如有&#xff09; sudo yum remove -y mariadb-libs sudo rm -rf /var/lib/mysql 2. 安装依赖 sudo yum install -y libaio numactl openssl-devel 3. 创建MySQL用户和目录 sudo groupadd mysql sudo useradd -r -g mysql -s…...

生物信息与自动化控制1 - 传感器数据采集与PID 算法的应用

1. 生物过程自动化控制 在生物制药、发酵工程等生物过程中&#xff0c;可以利用生物信息学技术分析生物反应的机理和代谢网络&#xff0c;然后通过自动化控制系统对生物过程进行实时监测和优化控制&#xff0c;以提高生物产品的产量和质量。例如&#xff0c;在发酵过程中&…...

npm包管理工具理解

一、当前维护者&#xff1a;GitHub&#xff08;微软旗下&#xff09; 2018 年&#xff0c;npm 公司被 GitHub 收购&#xff1b; 2020 年&#xff0c;GitHub 被微软收购。 因此&#xff0c;目前 npm 公共仓库由 GitHub 团队负责运维&#xff0c;微软提供底层基础设施支持&#…...

Uniapp 使用Android studio进行离线打包

一.需求 开发Uniapp项目时&#xff0c;使用HBuilderX进行云打包&#xff0c;会经常遇到两个方面的问题&#xff0c;当天的打包的次数受到了限制和打包的时间会比较长&#xff0c;因此&#xff0c;对于离线打包其需求还是比较常见的&#xff0c;这篇文章记录一下对Uniapp的项目…...

mcp和API区别

MCP&#xff08;Model Context Protocol&#xff0c;模型上下文协议&#xff09;与传统API&#xff08;Application Programming Interface&#xff0c;应用程序编程接口&#xff09;在技术架构、集成方式和应用场景等方面存在显著差异&#xff0c;以下是主要区别的总结&#x…...

ASP.NET 中 Cache 的常规使用方法

在 ASP.NET 中&#xff0c;Cache 类提供了一种在服务器内存中存储数据的方法&#xff0c;可以显著提高应用程序性能。以下是 Cache 的常规使用方法&#xff1a; 1. 基本缓存操作 添加缓存项 // 最简单的添加方式 Cache["key"] "value";// 使用 Insert …...

TextIn ParseX文档解析参数使用指南(第一期)

TextIn ParseX通用文档解析作为一款适配多样化场景的PDF解析工具&#xff0c;在基础识别能力以上&#xff0c;还提供了便捷、完善的参数配置功能&#xff0c;便于用户根据自身需求调整&#xff0c;获得所需输出结果。在TextIn技术社群&#xff0c;我们的产品团队也经常接到关于…...

[图论]生成树 引言

生成树 引言 生成树&#xff1a;一个连通图的生成树是该图的一个极小连通子图。生成树中含有图中全部(设 V V V个)顶点及构成一棵树的 V − 1 V-1 V−1条边&#xff0c;且生成树中不应有环。最小生成树(MST)&#xff1a;图的所有生成树中&#xff0c;边权之和最小的生成树。显…...

生信小白学Rust-02

基本类型 Rust 每个值都有其确切的数据类型&#xff0c;总的来说可以分为两类&#xff1a;基本类型和复合类型。 基本类型意味着它们往往是一个最小化原子类型&#xff0c;无法解构为其它类型&#xff08;一般意义上来说&#xff09;&#xff0c;由以下组成&#xff1a; 数值…...

Docker Compose 中配置 Host 网络模式

在 Docker Compose 中配置 Host 网络模式时&#xff0c;需通过 network_mode 参数直接指定容器使用宿主机的网络栈。以下是具体配置方法及注意事项&#xff1a; 1. 基础配置示例 在 docker-compose.yml 文件中&#xff0c;为需要启用 Host 模式的服务添加 network_mode: "…...

SQL Server 2022 安装常见问题及解决方法

一、系统要求不满足​ 1. 硬件配置不足​ SQL Server 2022 对硬件有一定要求&#xff0c;若内存、磁盘空间不足&#xff0c;安装可能失败。例如&#xff0c;32 位系统至少需要 1GB 内存&#xff0c;64 位系统至少 2GB&#xff0c;且安装过程需预留足够磁盘空间。​ 解决方法&a…...

解决 AWS RDS MySQL mysqldump 导入sql SET @@GLOBAL 权限不足问题

在使用 mysqldump 导出数据库时&#xff0c;导出的 SQL 文件通常会包含一些 SET 语句&#xff0c;例如 SET MYSQLDUMP, SET SESSION, SET GLOBAL 等&#xff0c;这些语句用于设置会话或全局变量以确保数据一致性和兼容性。然而&#xff0c;在 AWS RDS MySQL 环境中&#xff0c;…...

加油站小程序实战教程11会员注册

目录 1 创建API2 搭建页面布局3 绑定事件总结 上一篇我们介绍了我的页面&#xff0c;显示未开通界面的搭建。当用户点击开通会员时&#xff0c;我们给出弹窗提示用户进行手机号授权&#xff0c;得到手机号之后我们调用API来完成会员的注册。本篇我们介绍一下会员注册的流程。 1…...

基于stm32的手机无线充电研究

标题:基于stm32的手机无线充电研究 内容:1.摘要 随着智能手机的普及&#xff0c;无线充电技术成为了研究热点。本研究的目的是设计并实现基于STM32的手机无线充电系统。采用电磁感应原理&#xff0c;以STM32微控制器为核心控制单元&#xff0c;设计了发射端和接收端电路。通过…...

如何快速隔离被攻击的服务器以防止横向渗透

当发现服务器被攻击时&#xff0c;迅速隔离是防止攻击者横向移动的关键措施。以下是快速隔离服务器的系统化方法&#xff1a; 一、立即网络隔离措施 1. 物理隔离&#xff08;最彻底&#xff09; 直接拔掉服务器的网线&#xff08;对物理服务器&#xff09; 关闭服务器电源&a…...

Ngrok 内网穿透实现Django+Vue部署

目录 Ngrok 配置 注册/登录 Ngrok账号 官网ngrok | API Gateway, Kubernetes Networking Secure Tunnels 直接cmd运行 使用随机生成网址&#xff1a;ngrok http 端口号 使用固定域名生成网址&#xff1a;ngrok http --domain你的固定域名 端口号 Django 配置 1.Youre a…...

信息学奥赛一本通 1508:Easy SSSP

【题目链接】 ybt 1508&#xff1a;Easy SSSP 【题目考点】 1. SPFA算法 判断负环 【解题思路】 使用SPFA统计整个图中是否有负环&#xff0c;初始需要将所有顶点都入队。 可以假想存在一个超级源点&#xff0c;第0号顶点。第0号顶点到第1到第n号顶点都有权值为0的边。 &a…...

兔子桌面官方下载-兔子桌面TV版-安卓电视版官方免费下载新版

想要体验兔子桌面 TV 版带来的诸多便利&#xff0c;下载安装非常简单。以下为你详细介绍官方免费下载新版的步骤&#xff1a; 安卓电视盒子下载方法 确保电视盒子已连接网络&#xff0c;打开盒子自带的浏览器&#xff0c;访问兔子桌面官方网站。 在官网找到 TV 版下载入口&am…...

国标GB28181视频平台EasyCVR视频汇聚系统,打造别墅居民区智能监控体系

一、现状背景 随着国家经济的快速增长&#xff0c;生活水平逐渐提高&#xff0c;私人别墅在城市、乡镇和农村的普及率也在逐年增加。然而&#xff0c;由于别墅区业主经济条件较好&#xff0c;各类不法事件也日益增多&#xff0c;主要集中在以下几个方面&#xff1a; 1&#x…...

天元证券|奶粉行业结构性回暖 乳企竞速全龄化、国际化

在过去几年中&#xff0c;中国婴配粉市场经历了量价齐增&#xff0c;量减价增&#xff0c;量减价减的三个周期。历经多年行业深度洗牌与竞争格局重塑&#xff0c;2024年中国婴配粉市场回暖态势愈发清晰可辨。 日前&#xff0c;包括中国飞鹤、澳优、健合集团在内的多家奶粉股披露…...

JVM:对象的实例化、直接内存

一、对象的实例化 对象实例化步骤&#xff1a; 首先加载对象所属类的相关信息&#xff0c;若该类存在父类&#xff0c;那么要将父类的信息也加载进来&#xff0c;依此类推接着在堆中为对象分配内存&#xff0c;有两种分配方法&#xff1a;当堆内存空间较为规整时&#xff0c;…...

Qwen2.5-Omni 7B 模型部署:镜像下载、环境安装及 demo 启动指南

本文采用docker方式启动 参考&#xff1a;https://github.com/QwenLM/Qwen2.5-Omni 下载模型 modelscope download --model Qwen/Qwen2.5-Omni-7B --local_dir /usr/local/ai/models/Qwen2.5-Omni-7B 下载docker镜像&#xff08;耗时较长&#xff0c;耐心等待&#xff09; d…...

【DeepSeek答】如何成为一名科技领域陪同口译,阶段性学习目标是什么

问&#xff1a;请问我怎样能成为一名陪同口译&#xff1f;需要学习哪些方面&#xff1f;如何阶段性达成目标&#xff1f;我每天晚上可以抽出一个小时学习&#xff0c;周六日全天学习。请帮我具体规划出阶段性的学习路线&#xff0c;并且给出学习教材 DeepSeek答&#xff1a; 根…...

AN(G|C)LE as an OpenCL Compute Driver

AN{G|C}LE as an OpenCL Compute Driver References Vulkanised 2024 https://vulkan.org/events/vulkanised-2024 References [1] Yongqiang Cheng, https://yongqiang.blog.csdn.net/...

在云服务器的 Linux 系统中安装 Python 的步骤(以常见发行版 Ubuntu/CentOS 为例)

一、Ubuntu/Debian 系统安装 Python 1. 更新系统包列表 sudo apt update && sudo apt upgrade -y2. 安装编译依赖 sudo apt install -y build-essential zlib1g-dev libncurses5-dev libgdbm-dev libnss3-dev libssl-dev libreadline-dev libffi-dev libsqlite3-dev…...

spark-SQL核心编程课后总结

通用加载与保存方式 加载数据&#xff1a;Spark-SQL的 spark.read.load 是通用加载方法&#xff0c;借助 format 指定数据格式&#xff0c;如 csv 、 jdbc 、 json 等&#xff1b; load 用于指定数据路径&#xff1b; option 在 jdbc 格式时传入数据库连接参数。此外&#xff0…...

stm32c011f4烧写程序 could not stop Cortex-M device

stm32c011f4烧写程序 could not stop Cortex-M device 一、问题描述二、问题分析三、解决方案说明&#xff1a;新的问题解决办法 四、其他可能原因分析可能的原因及解决方案&#xff08;一&#xff09;硬件连接问题1、复位引脚&#xff08;NRST&#xff09;状态异常2、 JTAG/SW…...

【Web API系列】Web Shared Storage API之WorkletSharedStorage深度解析与实践指南

前言 在现代Web开发领域&#xff0c;数据存储与隐私保护的矛盾始终存在。传统存储方案如LocalStorage和Cookies面临着日益严格的安全限制&#xff0c;而跨域数据共享的需求却在持续增长。正是在这样的背景下&#xff0c;Web Shared Storage API应运而生&#xff0c;其核心组件…...

nvm切换node版本后,解决npm找不到的问题

解决方法如下 命令行查看node版本 node -v找到node版本所对应的npm版本 点击进入node版本 npm对应版本下载 点击进入npm版本 下载Windows 压缩包 下载完成后&#xff0c;解压&#xff0c;文件改名为npm 复制到你nvm对应版本的node_modules 下面 将下载的npm /bin 目录…...

【路由交换方向IE认证】BGP选路原则之Local Preference属性

文章目录 一、路由器BGP路由的处理过程控制平面和转发平面选路工具 二、BGP的选路顺序选路的前提选路顺序 三、Local Preference属性选路原则Local Preference选路方法Local Preference选路时的方向、方式设置直接更改Local Preference值使用route-map更改Local Preference值 四…...

MTK-Android12 13 屏蔽掉Viewing full screen

去掉ROOM 开机第一次提示全屏弹框 文章目录 需求参考资料修改文件实现方案 解决思路grep 源码查找信息grep 查找 grep -rn "Viewing full screen" 找string 字段grep 查找 grep -rn immersive_cling_title 布局grep 查找 grep -rn layout.immersive_mode_cling 对应的…...