珠海门户网站建设哪家专业/重庆seo整站优化系统
目录
一、本地私有仓库
1. 下载registry镜像
2. 在daemon.json文件中添加私有镜像仓库地址
编辑
3. 运行registry容器
4. Docker容器的重启策略如下
5. 为镜像打标签
6. 上传到私有仓库
7. 列出私有仓库的所有镜像
8. 列出私有仓库的centos镜像有哪些tag
9. 先删除原有的centos镜像,再测试私有仓库下载 ’
二、Harbor
1. Harbor简介
2. Harbor的特性
3. Harbor的构成
4. Harbor部署
4.1 服务器设置
4.2 部署Docker-Compose服务
4.3 部署Harbor
4.3.1 下载或上传Harbor安装程序
4.3.2 修改harbor安装的配置文件
4.4 harbor.cfg配置文件中的两类参数
4.4.1 所需参数
4.4.2 可选参数
4.5 启动harbor
4.6 查看harbor启动镜像
4.7 创建一个新项目
4.7.1 登录Harbor
4.7.2 下载镜像进行测试
4.7.3 将镜像打标签
4.7.4 上传镜像到Harbor
4.7.5 web查看project状态
4.8 在其他客户端上传镜像
4.8.1 在Docker客户端配置操作
4.8.2 重启Docker,再次登录
4.8.3 再次登录Harbor
4.8.4 下载镜像进行测试
4.8.5 上传镜像进行测试
5. 维护管理Harbor
5.1 通过Harbor Web创建项目
5.2 创建 Harbor 用户
5.2.1 创建用户并分配权限
5.2.2 添加项目成员
5.2.3 在客户端上使用普通账户操作镜像
编辑 5.3 修改harbor.cfg配置文件、
5.4 移除Harbor服务容器同时保留镜像数据/数据库,并进行迁移
5.5 如需重新部署,需要移除Harbor服务器全部数据
一、本地私有仓库
1. 下载registry镜像
[root@docker ~]# docker pull registry
[root@docker ~]# docker images
2. 在daemon.json文件中添加私有镜像仓库地址
[root@docker ~]# vim /etc/docker/daemon.json {"registry-mirrors": ["https://n1x922iy.mirror.aliyuncs.com"],"insecure-registries": ["192.168.80.115:5000"]
}[root@docker ~]# systemctl restart docker.service
3. 运行registry容器
[root@docker ~]# docker run -itd -v /data/registry:/var/lib/registry -p 5000:5000 --restart=always --name registry registry:latest
[root@docker ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
ea1409afd421 registry:latest "/entrypoint.sh /etc…" 5 seconds ago Up 4 seconds 0.0.0.0:5000->5000/tcp, :::5000->5000/tcp registry
-itd:在容器中打开一个伪终端进行交互操作,并在后台运行
-v:把宿主机的/data/registry目录(这个目录是registry容器中存放镜像文件的目录),来实现数据的持久化
-p:映射端口,访问宿主机的5000端口就访问到registry容器的服务了
--restart=always:这是重启的策略,在容器退出时总是重启容器
--name registry:创建容器命名为registry registry:latest:这个是刚才pull下来的镜像
4. Docker容器的重启策略如下
no:默认策略。在容器退出时不重启容器
no-failure:在容器非正常退出时(退出状态非0),才会重启容器
no-failure:3:在容器非正常退出时重启容器,最多重启3次
always:在容器退出时总是重启容器
unless-stopped:在容器退出时总是重启容器,但是不考虑在Docker守护进程启动时就已经停止了的容器
5. 为镜像打标签
[root@docker ~]# docker tag centos:7 192.168.80.115:5000/centos:test1
[root@docker ~]# docker images
6. 上传到私有仓库
[root@docker ~]# docker push 192.168.80.115:5000/centos:test1
7. 列出私有仓库的所有镜像
[root@docker ~]# curl http://192.168.80.115:5000/v2/_catalog
8. 列出私有仓库的centos镜像有哪些tag
[root@docker ~]# curl http://192.168.80.115:5000/v2/centos/tags/list
9. 先删除原有的centos镜像,再测试私有仓库下载 ’
[root@docker ~]# docker rmi -f 192.168.80.115.5000/centos:test1 centos:7 [root@docker ~]# docker images[root@docker ~]# docker pull 192.168.80.115:5000/centos:test1[root@docker ~]# docker images
二、Harbor
1. Harbor简介
Harbor 是 VMware 公司开源的企业级 Docker Registry 项目,其目标是帮助用户迅速搭建一个企业级的 Docker Registry 服务。 Harbor以 Docker 公司开源的 Registry 为基础,提供了图形管理 UI 、基于角色的访问控制(Role Based AccessControl) 、AD/LDAP 集成、以及审计日志(Auditlogging) 等企业用户需求的功能,同时还原生支持中文。 Harbor 的每个组件都是以 Docker 容器的形式构建的,使用 docker-compose 来对它进行部署。用于部署 Harbor 的 docker-compose 模板位于 harbor/docker-compose.yml。
2. Harbor的特性
(1)基于角色控制:用户和仓库都是基于项目进行组织的,而用户在项目中可以拥有不同的权限。
(2)基于镜像的复制策略:镜像可以在多个Harbor实例之间进行复制(同步)。
(3)支持 LDAP/AD:Harbor 可以集成企业内部已有的 AD/LDAP(类似数据库的一张表),用于对已经存在的用户认证和管理。
(4)镜像删除和垃圾回收:镜像可以被删除,也可以回收镜像占用的空间。
(5)图形化用户界面:用户可以通过浏览器来浏览,搜索镜像仓库以及对项目进行管理。
(6)审计管理:所有针对镜像仓库的操作都可以被记录追溯,用于审计管理。
(7)支持 RESTful API:RESTful API 提供给管理员对于 Harbor 更多的操控, 使得与其它管理软件集成变得更容易。
(8)Harbor和docker registry的关系:Harbor实质上是对docker registry做了封装,扩展了自己的业务模板。
3. Harbor的构成
Harbor 在架构上主要有 Proxy、Registry、Core services、Database(Harbor-db)、Log collector(Harbor-log)、Job services 六个组件。
Harbor组件 | 说明 |
---|---|
Proxy | Harbor 的 Registry、UI、Token 服务等组件,都处在 nginx 反向代理后边。该代理将来自浏览器、docker clients 的请求转发到后端不同的服务上。 |
Registry | 负责储存 Docker 镜像,并处理 Docker push/pull 命令。由于要对用户进行访问控制,即不同用户对 Docker 镜像 有不同的读写权限,Registry 会指向一个 Token 服务,强制用户的每次 Docker pull/push 请求都要携带一个合法的 Token, Registry 会通过公钥对 Token 进行解密验证。 |
Core services | Harbor的核心功能,主要提供以下3个服务: 1)UI(harbor-ui): 提供图形化界面,帮助用户管理 Registry 上的镜像(image), 并对用户进行授权。 2)WebHook:为了及时获取Registry 上image 状态变化的情况,在Registry 上配置 Webhook,把状态变化传递给 UI 模块。 3)Token 服务:负责根据用户权限给每个 Docker push/pull 命令签发 Token。Docker 客户端向 Registry 服务发起的请求, 如果不包含 Token,会被重定向到 Token 服务,获得 Token 后再重新向 Registry 进行请求。 |
Database(harbor-db) | 为core services提供数据库服务,负责储存用户权限、审计日志、Docker 镜像分组信息等数据。 |
Job services | 主要用于镜像复制,本地镜像可以被同步到远程 Harbor 实例上。 |
Log collector(harbor-log) | 负责收集其他组件的日志到一个地方。 |
Harbor 的每个组件都是以 Docker 容器的形式构建的,因此,使用 Docker Compose 来对它进行部署。 总共分为7个容器运行,通过在docker-compose.yml所在目录中执行 docker-compose ps 命令来查看, 名称分别为:nginx、harbor-jobservice、harbor-ui、harbor-db、harbor-adminserver、registry、harbor-log。 其中 harbor-adminserver 主要是作为一个后端的配置数据管理,并没有太多的其他功能。harbor-ui 所要操作的所有数据都通过 harbor-adminserver 这样一个数据配置管理中心来完成。
4. Harbor部署
4.1 服务器设置
服务器 | IP地址 | 主要软件 |
---|---|---|
Harbor服务器 | 192.168.122.10 | docker-ce、docker-compose、harbor-offline-v1.2.2 |
client服务器 | 192.168.122.11 | docker-ce |
4.2 部署Docker-Compose服务
下载或者上传Docker-Compose
[root@docker ~]# curl -L https://github.com/docker/compose/releases/download/1.21.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
[root@docker ~]# chmod +x /usr/local/bin/docker-compose
[root@docker ~]# docker-compose -v
docker-compose version 1.21.1, build 5a3f1a3
4.3 部署Harbor
4.3.1 下载或上传Harbor安装程序
[root@docker ~]# cd /opt
[root@docker opt]# rz -E
rz waiting to receive.
#传入harbor安装包harbor-offline-installer-v1.2.2.tgz
[root@docker opt]# tar zxvf harbor-offline-installer-v1.2.2.tgz -C /usr/local/
4.3.2 修改harbor安装的配置文件
[root@docker opt]# vim /usr/local/harbor/harbor.cfg #5行,修改,设置为Harbor服务器的IP地址或者域名
hostname = 192.168.80.115
#59行,指定管理员的初始密码,默认的用户名/密码是admin/Harbor12345
harbor_admin_password = Harbor12345
4.4 harbor.cfg配置文件中的两类参数
关于harbor.cfg配置文件中有两类参数:所需参数和可选参数
4.4.1 所需参数
这些参数需要在配置文件harbor.cfg中设置。如果用户更新它们并运行install.sh 脚本重新安装harbor,参数将生效。具体参数如下:
● hostname:用于访问用户界面和 register 服务。它应该是目标机器的 IP 地址或完全限定的域名(FQDN),例如 192.168.80.10 或 hub.kgc.cn。不要使用 localhost 或 127.0.0.1 为主机名。
ui_url_protocol:(http 或 https,默认为 http)用于访问 UI 和令牌/通知服务的协议。如果公证是启用状态,则此参数必须为 https。
● max_job_workers:镜像复制作业线程。
● db_password:用于db_auth 的MySQL数据库root 用户的密码。
● customize_crt:该属性可设置为打开或关闭,默认打开。打开此属性时,准备脚本创建私钥和根证书,用于生成/验证注册表令牌。当由外部来源提供密钥和根证书时,将此属性设置为 off。
● ssl_cert:SSL 证书的路径,仅当协议设置为 https 时才应用。
● secretkey_path:用于在复制策略中加密或解密远程 register 密码的密钥路径。
4.4.2 可选参数
这些参数对于更新是可选的,即用户可以将其保留为默认值,并在启动 Harbor 后在 Web UI 上进行更新。如果进入 Harbor.cfg,只会在第一次启动 Harbor 时生效,随后对这些参数的更新,Harbor.cfg 将被忽略。
注意:如果选择通过 UI 设置这些参数,请确保在启动 Harbor 后立即执行此操作。具体来说,必须在注册或在 Harbor 中创建任何新用户之前设置所需的 auth_mode。当系统中有用户时(除了默认的 admin 用户), auth_mode 不能被修改。 具体参数如下:
Email:Harbor 需要该参数才能向用户发送“密码重置”电子邮件,并且只有在需要该功能时才启用。请注意,在默认情况下 SSL 连接时没有启用。如果 SMTP 服务器需要 SSL,但不支持 STARTTLS,那么应该通过设置启用 SSL email_ssl = TRUE。
● harbour_admin_password:管理员的初始密码,只在 Harbour 第一次启动时生效。之后, 此设置将被忽略,并且应在 UI 中设置管理员的密码。请注意,默认的用户名/密码是admin/Harbor12345。
● auth_mode:使用的认证类型,默认情况下,它是 db_auth,即凭据存储在数据库中。对于LDAP身份验证,请将其设置为 ldap_auth。
● self_registration:启用/禁用用户注册功能。禁用时,新用户只能由 Admin 用户创建,只有管理员用户可以在 Harbour 中创建新用户。注意:当 auth_mode 设置为 ldap_auth 时,自注册功能将始终处于禁用状态,并且该标志被忽略。
● Token_expiration:由令牌服务创建的令牌的到期时间(分钟),默认为 30 分钟。
● project_creation_restriction:用于控制哪些用户有权创建项目的标志。默认情况下,每个人都可以创建一个项目。如果将其值设置为“adminonly”,那么只有 admin 可以创建项目。
● verify_remote_cert:打开或关闭,默认打开。此标志决定了当Harbor与远程 register 实例通信时是否验证 SSL/TLS 证书。 将此属性设置为 off 将绕过 SSL/TLS 验证,这在远程实例具有自签名或不可信证书时经常使用。
另外,默认情况下,Harbour 将镜像存储在本地文件系统上。在生产环境中,可以考虑 使用其他存储后端而不是本地文件系统,如 S3、Openstack Swif、Ceph 等对象存储。但需要更新 common/templates/registry/config.yml 4.6 查看harbor启动镜像 文件。
4.5 启动harbor
[root@docker opt]# cd /usr/local/harbor/
[root@docker harbor]# ./install.sh
[root@docker harbor]# docker images
[root@docker harbor]# docker ps -a
注:启动harbor前需删除registry镜像/容器,否则无法生成新的registry镜像。
4.6 查看harbor启动镜像
[root@docker harbor]# docker-compose ps
4.7 创建一个新项目
(1)浏览器访问:http://192.168.80.115/登录harbor web ui界面,默认的管理员用户名和密码是admin/Harbor12345
(2)输入用户名和密码登录界面后可以创建一个新项目。点击“+项目”按钮
(3)填写项目名称为“test_project”,点击“确定”按钮,创建新项目
(4)此时可使用 Docker 命令在本地通过 127.0.0.1 来登录和推送镜像。默认情况下,Registry 服务器在端口 80 上侦听。
4.7.1 登录Harbor
[root@docker harbor]# docker login -u admin -p Harbor12345 http://127.0.0.1
4.7.2 下载镜像进行测试
[root@docker harbor]# docker pull nginx
[root@docker harbor]# docker images
4.7.3 将镜像打标签
[root@docker harbor]# docker tag nginx:latest 127.0.0.1/test_project/nginx:v1
[root@docker harbor]# docker images
4.7.4 上传镜像到Harbor
[root@docker harbor]# docker push 127.0.0.1/test_project/nginx:v1
4.7.5 web查看project状态
4.8 在其他客户端上传镜像
以上操作都是在Harbor服务器本地操作。如果其他客户端登录到Harbor,就会报如下错误。出现这问题的原因为Docker Registry交互默认使用的是HTTPS,但是搭建私有镜像默认使用的是HTTP服务,所以与私有镜像交互时出现以下错误。
4.8.1 在Docker客户端配置操作
解决办法是在Docker server启动的时候,增加启动参数,默认使用HTTP访问。 方法一:修改/usr/lib/systemd/system/docker.service
[root@localhost ~]# vim /usr/lib/systemd/system/docker.service#13行修改
ExecStart=/usr/bin/dockerd -H fd:// --insecure-registry 192.168.80.115 --containerd=/run/containerd/containerd.sock
#或修改为ExecStart=/usr/bin/dockerd --insecure-registry 192.168.80.115
方法二:修改/etc/docker/daemon.json
[root@localhost ~]# vim /etc/docker/daemon.json{"registry-mirrors": ["https://3c7tpzyf.mirror.aliyuncs.com"],"insecure-registries": ["192.168.80.115"]
}
4.8.2 重启Docker,再次登录
[root@localhost ~]# systemctl daemon-reload
[root@localhost ~]# systemctl restart docker
4.8.3 再次登录Harbor
[root@localhost ~]# docker login -u admin -p Harbor12345 http://192.168.80.115
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /root/.docker/config.json.
#将自动保存凭据到/root/.docker/config.json,下次登录时可直接使用凭据登录 Harbor
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-storeLogin Succeeded
4.8.4 下载镜像进行测试
[root@localhost ~]# docker pull 192.168.80.115/test_project/nginx:v1[root@localhost ~]# docker images
4.8.5 上传镜像进行测试
[root@localhost ~]# docker pull cirros
docker tag cirros:latest 192.168.80.115/test_project/cirros:v1
[root@localhost ~]# docker tag cirros:latest 192.168.80.115/test_project/cirros:v1
[root@localhost ~]# docker images
[root@localhost ~]# docker push 192.168.80.115/test_project/cirros:v1
5. 维护管理Harbor
5.1 通过Harbor Web创建项目
在 Harbor 仓库中,任何镜像在被 push 到 regsitry 之前都必须有一个自己所属的项目。 单击“+项目”,填写项目名称,项目级别若设置为"私有",则不勾选。如果设置为公共仓库,则所有人对此项目下的镜像拥有读权限,命令行中不需要执行"Docker login"即可下载镜像,镜像操作与 Docker Hub 一致。
5.2 创建 Harbor 用户
5.2.1 创建用户并分配权限
在 Web 管理界面中单击系统管理 -> 用户管理 -> +用户, 填写用户名为“test”,邮箱为“123@test.com”,全名为“test”,密码为“Test12345”(需大小写英文,数字以及至少8位字符),注释为“test”(可省略)。 附:用户创建成功后,单击左侧“...”按钮可将上述创建的用户设置为管理员角色或进行删除操作,本例不作任何设置。
5.2.2 添加项目成员
单击项目 -> test_project -> 成员 -> + 成员,填写上述创建的用户 test 并分配角色为“开发人员”。
附:此时单击左侧“...”按钮仍然可对成员角色进行变更或者删除操作
5.2.3 在客户端上使用普通账户操作镜像
删除全部本地镜像
[root@localhost ~]# docker rmi -f $(docker images -q)
[root@localhost ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
退出当前用户,然后使用上述创建的账户test登录
[root@localhost ~]# docker logout 192.168.80.115
Removing login credentials for 192.168.80.115
[root@localhost ~]# docker login -u test -p Test12345 http://192.168.122.10
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /root/.docker/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-storeLogin Succeeded
下载harbor仓库镜像
[root@localhost ~]# docker pull 192.168.80.115/test_project/cirros:v1
[root@localhost ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
192.168.122.10/test_project/cirros v1 f9cae1daf5f6 7 months ago 12.6MB
上传镜像至harbor仓库
[root@localhost ~]# docker tag 192.168.80.115/test_project/cirros:v1 [root@localhost ~]# docker images[root@localhost ~]# docker push 192.168.80.115/test_project/cirros:v2
5.3 修改harbor.cfg配置文件、
要更改 Harbour的配置文件中的可选参数时,需先停止现有的 Harbour实例并更新 Harbor.cfg;然后运行 prepare 脚本来填充配置;最后重新创建并启动 Harbour 的实例。 使用 docker-compose 管理 Harbor 时,必须在与 docker-compose.yml 相同的目录中运行。
[root@docker ~]# cd /usr/local/harbor
[root@docker harbor]# docker-compose down -v[root@docker harbor]# vim harbor.cfg #只能修改可选参数
[root@docker harbor]# ./prepare [root@docker harbor]# docker-compose up -d
如果有以下报错,需要开启防火墙 firewalld 服务解决
Creating network "harbor_harbor" with the default driver
ERROR: Failed to Setup IP tables: Unable to enable SKIP DNAT rule: (iptables failed: iptables --wait -t nat -I DOCKER -i br-b53c314f45e8 -j RETURN: iptables: No chain/target/match by that name.(exit status 1))systemctl restart firewalld.service
docker-compose up -d
5.4 移除Harbor服务容器同时保留镜像数据/数据库,并进行迁移
在Harbor服务器上操作
(1)移除Harbor服务容器
[root@docker harbor]# cd /usr/local/harbor
[root@docker harbor]# docker-compose down -v
(2)把项目中的镜像数据进行打包 持久数据,如镜像,数据库等在宿主机的/data/目录下,日志在宿主机的/var/log/Harbor/目录下
[root@docker harbor]# ls /data/registry/docker/registry/v2/repositories/test_project
cirros nginx
[root@docker harbor]# cd /data/registry/docker/registry/v2/repositories/test_project
[root@docker test_project]# tar zcvf test-registry.tar.gz ./*
5.5 如需重新部署,需要移除Harbor服务器全部数据
[root@docker harbor]# cd /usr/local/harbor
[root@docker harbor]# docker-compose down -v
Stopping nginx ... done
Stopping harbor-jobservice ... done
Stopping harbor-ui ... done
Stopping registry ... done
Stopping harbor-db ... done
Stopping harbor-adminserver ... done
Stopping harbor-log ... done
Removing nginx ... done
Removing harbor-jobservice ... done
Removing harbor-ui ... done
Removing registry ... done
Removing harbor-db ... done
Removing harbor-adminserver ... done
Removing harbor-log ... done
Removing network harbor_harbor
[root@docker harbor]# rm -rf /data/database
[root@docker harbor]# rm -rf /data/registry
相关文章:

Docker私有仓库与Harbor部署使用
目录 一、本地私有仓库 1. 下载registry镜像 2. 在daemon.json文件中添加私有镜像仓库地址 编辑 3. 运行registry容器 4. Docker容器的重启策略如下 5. 为镜像打标签 6. 上传到私有仓库 7. 列出私有仓库的所有镜像 8. 列出私有仓库的centos镜像有哪些tag 9. 先删…...

Linux的iptables防火墙基础介绍
iptables 防火墙 应用层软件----管理 内核级netfilter 硬件-------内核----网络—netfilter/kvm----- app iptables iptables—控制netfilter 过滤:<smac/sip/dip/sport/dport/状态> TCP/IP 应用层 传输层 sport dport 状态 <三次握手/四次断开> 网…...

deepspeed+transformers模型微调
一、目录 代码讲解 二、实现。 1、代码讲解,trainer 实现。 transformers通过trainer 集成deepspeed功能,所以中需要进行文件配置,即可实现deepspeed的训练。 微调代码: 参数定义—>数据处理---->模型创建/评估方式----&…...

无人机摄影测量数据处理、三维建模及在土方量计算中的应用
专题一、无人机摄影测量技术应用现状及其发展 1、无人机摄影测量技术概述 2、摄影测量系统的发展 3、无人机摄影测量技术应用分析 专题二、基本原理和关键技术讲解 1、摄影测量基础知识 1)航空摄影 2)航摄像片的方位元素 3)共…...

《ESP8266通信指南》15-MQTT连接、订阅MQTT主题并打印消息(基于Lua|适合新手|非常简单)
往期 《ESP8266通信指南》14-连接WIFI(基于Lua)-CSDN博客 《ESP8266通信指南》13-Lua 简单入门(打印数据)-CSDN博客 《ESP8266通信指南》12-Lua 固件烧录-CSDN博客 《ESP8266通信指南》11-Lua开发环境配置-CSDN博客 《ESP826…...

LeetCode:两数之和
文章收录于LeetCode专栏 LeetCode地址 两数之和 给定一个整数数组nums和一个整数目标值target,请你在该数组中找出和为目标值的那两个整数,并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是数组中同一个元素在答案里不能重复出现。…...

CSDN我的创作纪念日128天||不忘初心|努力上进|勇往直前
机缘 Hello,大家好,我是景天,其实很早之前我就加入到了CSND的大军,彼时我还是个刚毕业的小白白,时常过来CSND汲取养料,就这样,慢慢的来提升自己,强大自己。工作锻炼了我,…...

MySQL数据库中的浮点类型和高精度类型有什么区别?为什么不推荐使用浮点类型?
在软件开发中,作为后端,无可避免的需要熟练使用 MySQL 数据库进行数据存储和读取。对于信息系统而言,数据库的的地位不言而喻。那作为软件开发工程师,在使用 MySQL 过程中,又有哪些需要注意的呢?我们从实际…...

C++ 抽象与封装
一 抽象 抽象实例:时钟 数据抽象: 具有表面当前时间的时、分、秒 行为抽象: 具有设置时间和显示时间两个最基本的功能。 抽象实例:人 数据抽象:姓名、年龄、性别等。 行为抽象: 生物属性:吃…...

antV X6的简要使用教程
🧑🎓 个人主页:《爱蹦跶的大A阿》 🔥当前正在更新专栏:《VUE》 、《JavaScript保姆级教程》、《krpano》、《krpano中文文档》 ✨ 前言 在我们的日常开发工作中,我们经常需要构建复杂的交互式图…...

【LLM 论文】Step-Back Prompting:先解决更高层次的问题来提高 LLM 推理能力
论文:Take a Step Back: Evoking Reasoning via Abstraction in Large Language Models ⭐⭐⭐⭐ Google DeepMind, ICLR 2024, arXiv:2310.06117 论文速读 该论文受到的启发是:人类再解决一个包含很多细节的具体问题时,先站在更高的层次上解…...

Java——接口的补充
目录 一:接口的注意事项 1. 接口中不能有方法块; 2. 接口没有构造方法: 3.接口是可以多继承的; 4. 多个接口抽象方法重复 5. 类的父类方法与接口方法重复 二:类与接口 1. 继承与实现 2. 多个父接口的抽象…...

word转pdf的java实现(documents4j)
一、多余的话 java实现word转pdf可用的jar包不多,很多都是收费的。最近发现com.documents4j挺好用的,它支持在本机转换,也支持远程服务转换。但它依赖于微软的office。电脑需要安装office才能转换。鉴于没在linux中使用office,本…...

基于K8S构建Jenkins持续集成平台
文章目录 安装和配置NFSNFS简介NFS安装 在Kubernetes安装Jenkins-Master创建NFS client provisioner安装Jenkins-Master Jenkins与Kubernetes整合实现Jenkins与Kubernetes整合构建Jenkins-Slave自定义镜像 JenkinsKubernetesDocker完成微服务持续集成拉取代码,构建镜…...

PHPStudy 访问网页 403 Forbidden禁止访问
涉及靶场 upload-labd sqli-labs pikachu dvwa 以及所有部署在phpstudy中的靶场 注意:一定要安装解压软件 很多同学解压靶场代码以后访问报错的原因是:电脑上没有解压软件。 这个时候压缩包看起来就是黄色公文包的样子,右键只有“全部提取…...

热爱电子值得做的电子制作实验
加我zkhengyang,进嵌入式音频系统研究开发交流答疑群(课题组) AM/FM收音机散件制作,磁带随声听散件,黑白电视机散件制作,功放散件制作,闪光灯散件制作,声控灯散件,等等,可提高动手能…...

.class文件启动过程以及文件内容结构讲解
当你直接启动一个.class文件时,实际上是在操作系统中调用Java虚拟机(JVM),并将该.class文件传递给JVM以执行。现在让我们来解释一下.class文件的启动过程以及文件内容结构: 启动过程:操作系统通过指定的命…...

解锁楼宇自动化新维度西门子Insight+BACnet IP I/O控制器
数字城市的楼宇自动化已不再是一个遥不可及的概念,而是成为了现代建筑的标配。特别是在大型商业综合体、高端写字楼和公共设施中,高效的楼宇管理系统是确保环境舒适度与能源效率的关键。当提及楼宇自动化领域的佼佼者,西门子Insight楼宇自动化…...

2024.05.10作业
TCP服务器 头文件 #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QTcpServer> #include <QTcpSocket> #include <QList> #include <QMessageBox> #include <QDebug>QT_BEGIN_NAMESPACE namespace Ui { class Widget; …...

基于POSIX标准库的读者-写者问题的简单实现
文章目录 实验要求分析保证读写、写写互斥保证多个读者同时进行读操作读者优先实例代码分析写者优先读写公平法示例代码分析实验要求 创建一个控制台进程,此进程包含n个线程。用这n个线程来表示n个读者或写者。每个线程按相应测试数据文件的要求进行读写操作。用信号量机制分别…...

重生我是嵌入式大能之串口调试UART
什么是串口 串口是一种在数据通讯中广泛使用的通讯接口,通常我们叫做UART (通用异步收发传输器Universal Asynchronous Receiver/Transmitter),其具有数据传输速度稳定、可靠性高、适用范围广等优点。在嵌入式系统中,串口常用于与外部设备进…...

【智能优化算法】蜜獾优化算法(Honey Badger Algorithm,HBA)
蜜獾优化算法(Honey Badger Algorithm,HBA)是期刊“MATHEMATICS AND COMPUTERS IN SIMULATION”(IF 3.6)的2022年智能优化算法 01.引言 蜜獾优化算法(Honey Badger Algorithm,HBA)受蜜獾智能觅食行为的启发,从数学上发展出一种求解优化问题的…...

【算法与数据结构】数组
文章目录 前言数组数组的定义数组的基本操作增加元素删除元素修改元素查找元素 C STL 中的数组arrayvector Python3 中的列表访问更改元素值遍历列表检查列表中是否存在某元素增加元素删除元素拷贝列表总结 Python3 列表的常用操作 参考资料写在最后 前言 本系列专注更新基本数…...

【数据结构】队列详解(Queue)
文章目录 有关队列的概念队列的结点设计及初始化队列的销毁判空和计数入队操作出队操作 有关队列的概念 队列:只允许在一端进行插入数据操作,在另一端进行删除数据操作的特殊线性表,队列具有先进先出FIFO(First In First Out)入队列:进行插入操作的一端…...

Baumer工业相机堡盟工业相机如何通过NEOAPISDK获取相机的Statistics图像传输统计信息(C#)
Baumer工业相机堡盟工业相机如何通过NEOAPISDK获取相机的Statistics图像传输统计信息(C#) Baumer工业相机Baumer工业相机NEOAPI SDK和相机Statistics图像传输统计信息的技术背景Baumer工业相机通过NEOAPISDK获取相机的Statistics图像传输统计信息技术1.引…...

FreeRTOS标准库例程代码
1.设备STM32F103C8T6 2.工程模板 单片机: 部分单片机的程序例程 - Gitee.comhttps://gitee.com/lovefoolnotme/singlechip/tree/master/STM32_FREERTOS/1.%E5%B7%A5%E7%A8%8B%E6%A8%A1%E6%9D%BF 3.代码 1-FreeRTOS移植模板 #include "system.h" #include "…...

wandb: - 0.000 MB of 0.011 MB uploaded持续出现的解决方案
大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的…...

分布式模式让业务更高效、更安全、更稳定
🌈 个人主页:danci_ 🔥 系列专栏:《设计模式》 💪🏻 制定明确可量化的目标,坚持默默的做事。 🚀 转载自热榜文章🔥:探索设计模式的魅力:分布式模…...

5.11学习记录
20长安杯部分 检材 1 的操作系统版本 CentOS Linux 7.6.1810 (Core) 检材 1 中,操作系统的内核版本是 3.10.0-957.el7.x86_64 检材 1 中磁盘包含一个 LVM 逻辑卷,该 LVM 开始的逻辑区块地址(LBA)是 2099200 物理卷ÿ…...

Java类加载器介绍
在Java中,类加载器是一种动态加载类的机制,它负责在运行时查找、加载和链接类文件。当Java应用程序需要创建某个类的对象时,类加载器会在运行时查找该类对应的.class文件,并将其加载到Java虚拟机中。Java类加载器通常分为三层&…...