ubuntu安装vm和Linux,安装python环境,docker和部署项目(一篇从零到部署)

news2024/11/6 9:42:55

1、下载Ubuntu

Index of /releasesicon-default.png?t=N7T8https://old-releases.ubuntu.com/releases/

 2、下载VMware

官方正版VMware下载(16 pro):https://www.aliyundrive.com/s/wF66w8kW9ac
下载Linux系统镜像(阿里云盘不限速):https://www.aliyundrive.com/s/UQMBPEovxNg
(系统镜像下载后,把后缀改成iso即可正常使用)
安装:选一下安装地址,一直下一步即可。(可能会要求重启电脑,重启即可)
在这里插入图片描述

3、安装Linux

下载Linux系统镜像(阿里云盘不限速):阿里云盘分享
(系统镜像下载后,把后缀改成iso即可正常使用)

接下来看图操作

一路next安装即可,iso路径选对即可。

  1. 安装时会创建一个用户 frank 123456
  1. 使用sudo passwd命令修改root用户的密码123456
  2. 使用su - root用户 输入123456密码即可登录到root用户

查看当前虚拟机的ip,ifconfig,提示没有安装网络工具,使用apt install net-tools安装即可

  1. 查看ip 192.168.79.129

  1. 使用finalshell连接Ubuntu 提示连接拒绝(如果没有该问题直接跳过该步骤即可)

解决方案:修改ssh_config文件,需要安装vim命令 apt install vim

 

再次连接Ubuntu 成功

4、更换ubuntu镜像源

cat /etc/apt/sources.list  使用该命令查看当前的源地址

ubuntu | 镜像站使用帮助 | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror

选择对应的版本号,将下面的内容复制到sources.list文件全部覆盖即可。

apt-get update  执行该命令更新即可生效。

5、安装python环境

        PPA 全称为 Personal Package Archives(个人软件包档案),是 Ubuntu Launchpad 网站提供的一项服务,当然不仅限于 Launchpad 。它允许个人用户上传软件源代码,通过 Launchpad 进行编译并发布为二进制软件包,作为 apt/新立得源供其他用户下载和更新。在Launchpad网站上的每一个用户和团队都可以拥有一个或多个PPA。

通常 PPA 源里的软件是官方源里没有的,或者是最新版本的软件。相对于通过 Deb 包安装来说,使用 PPA 的好处是,一旦软件有更新,通过 sudo apt-get upgrade 这样命令就可以直接升级到新版本。

直接使用ppa安装python3.10

add-apt-repository ppa:deadsnakes/ppa

使用以下命令刷新缓存:

apt update

安装python3.10

apt install python3.10

设置python的版本

apt-cache rdepends python3.8

检查当前版本

python3 --version

使用 update-alternatives 创建指向 python3 的符号链接

update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.10

并通过以下命令选择使用哪一个作为 python3

update-alternatives --config python3

 

5.1 安装python3虚拟环境

 为何需要安装python的虚拟环境?

1、安装pip3

apt install python3-pip

2、安装虚拟环境

apt install virtualenv

 2.1 、python3 -m venv myenv  在指定路径下创建虚拟环境,这里的myenv根据自己的实际名称修改

2.2、激活虚拟环境

 ​​​使用pip 直接安装requests依赖测试安装成功。

 总结安装虚拟环境的步骤:

1、安装虚拟环境工具,例如venv

2、创建一个新的虚拟环境

3、激活虚拟环境

4、在虚拟环境使用pip安装所需要的安装包

5.2、更换pip的下载源

1、创建pip.conf文件,然后录入对应的镜像源

 使用命令 pip config list 查看上面的配置是否生效

5.3、使用Anaconda3工具

        一句话:python需要下载很多包,Anaconda集成了几乎常用的包,这也是那么多数据分析者推荐Anaconda的原因。Anaconda 是一个用于科学计算的 Python 发行版,支持 Linux, Mac, Windows, 包含了众多流行的科学计算、数据分析的 Python 包。
用途
        快速安装,运行和升级及其依赖项
        在计算机便捷的创建,和保存,加载和切换环境。

如果你需要的包要求不同版本的Python,你无需切换到不同的环境,因为conda同样是一个环境管理器。仅需要几条命令,你可以创建一个完全独立的环境来运行不同的Python版本,同时继续在你常规的环境中使用你常用的Python版本。——conda官方网站

python和包以及anaconda的概念关系

基于自己对于这些概念术语之间的关系打一个小比方:

关于python与包 包 =“工具”;

下载包 = “买工具”;

写程序 = “用工具做东西”(程序import导入)

关于anaconda

环境 = “好比一栋楼,在楼里面分配一间屋给各种‘包’放,每间房里面的‘包’互不影响”
激活环境 = “告诉电脑,我现在要用这个屋子里面的‘包’来做东西了所以要进这间屋子”
移除环境 = “现在这个屋子里面我原来要用的东西现在不需要了把它赶出去节省电脑空间”
Conda创建环境相当于创建一个虚拟的空间将这些包都装在这个位置,我不需要了可以直接打包放入垃圾箱,同时也可以针对不同程序的运行环境选择不同的conda虚拟环境进行运行。

5.3.1、Anaconda下载和安装

官网下载:https://www.anaconda.com/products/individualicon-default.png?t=N7T8https://www.anaconda.com/products/individual1、推荐使用清华镜像网站下载: 

https://mirrors.tuna.tsinghua.edu.cn/anaconda/archive/
选择你想要下载的Linux版本。
以Anaconda3-2020.07-Linux-x86_64为例子:

2、将下载的文件放到/root/ 文件夹下,然后进入文件夹执行命令:

 bash Anaconda3-2020.07-Linux-x86_64.sh

3、一路next,出现yes时输入yes,然后enter确认安装路径即可。 

4、添加环境变量:

5、查看该文件,在末尾增加

export PATH="/root/anaconda3/bin:$PATH"

/root/anaconda3/bin 就是上面安装的anaconda的路径

6、然后执行 source ~/.bashrc

7、通过命令conda --version查看当前conda的版本,安装成功!

5.3.2、anaconda使用教程

1、创建新的虚拟环境。

 conda create -n my_env_conda python=3.10

my_env_conda 环境名称 

3.10是python的版本

conda create --name myenvTest

激活conda:conda activate myenvTest

然后使用命令:conda info --envs 查看所有的conda 

 使用命令:conda install requests  安装自己需要的依赖

使用Anaconda Navigator(可选):Anaconda还提供了一个图形化界面工具Anaconda Navigator,用于管理环境、安装软件包和启动应用程序。你可以在终端中运行以下命令启动Anaconda Navigator:

 anaconda-navigator

 

 

 创建应用选择刚刚创建的env1虚拟环境中的python

 

 点击应用则保存成功。

点击运行则看到是使用的我们配置的虚拟环境了。

6、安装pycharm

1、下载pycharm的Linux版本

https://www.jetbrains.com/pycharm/download/download-thanks.html?platform=linux&code=PCC

或者直接在Windows下载然后上传到对应的Linux的文件夹中。

解压文件: tar -xzf pycharm-community-2023.3.2.tar.gz

将文件解压然后移动到指定的文件夹下,/opt/pycharm

2、启动pycharm,找到对应的文件夹下:直接 sh pycharm.sh 打开py编译器

你好,python!

7、安装docker

1、安装

在 Ubuntu 上安装 Docker 非常直接。我们将会启用 Docker 软件源,导入 GPG key,并且安装软件包。首先,更新软件包索引,并且安装必要的依赖软件,来添加一个新的 HTTPS 软件源:

apt update

apt install apt-transport-https ca-certificates curl gnupg-agent software-properties-common

curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -

将 Docker APT 软件源添加到系统报错了:(这一步好像不用管,不影响后续的安装docker可以忽略) 

add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"

apt-get install python-apt

由于缺少上面的依赖,则需要安装此依赖

按照此操作还是会报错。

cp apt_pkg.cpython-38-x86_64-linux-gnu.so apt_pkg.so

然后再执行:add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" 报错就变了~~

2、安装docker

apt update

apt install docker-ce docker-ce-cli containerd.io      安装最新的版本

想要安装指定版本,首先列出 Docker 软件源中所有可用的版本:

apt update

apt list -a docker-ce

5:25.0.0-1~ubuntu.20.04~focal 

apt install docker-ce=<VERSION> docker-ce-cli=<VERSION> containerd.io  指定版本安装

3、一旦安装完成,Docker 服务将会自动启动。你可以输入下面的命令,验证它:

systemctl status docker

 docker -v 查看安装的docker的版本

当一个新的 Docker 发布时,你可以使用标准的sudo apt update && sudo apt upgrade流程来升级 Docker 软件包。

如果你想阻止 Docker 自动更新,锁住它的版本:

apt-mark hold docker-ce

4、使用命令验证docker是否安装成功:docker container run hello-world

如果本地没有该镜像,这个命令将会下载测试镜像,在容器中运行它,打印出 “Hello from Docker”,并且退出。

5、卸载docker

在卸载 Docker 之前,你最好 移除所有的容器,镜像,卷和网络。

运行下面的命令停止所有正在运行的容器,并且移除所有的 docker 对象:

docker container stop $(docker container ls -aq)
docker system prune -a --volumes

现在你可以使用apt像卸载其他软件包一样来卸载 Docker:

apt purge docker-ce
apt autoremove

6、设置阿里云加速

阿里云登录 - 欢迎登录阿里云,安全稳定的云计算服务平台

1、登录阿里云,然后查看加速地址

2、按照文档操作,执行命令:

sudo mkdir -p /etc/docker

sudo tee /etc/docker/daemon.json <<-'EOF'

{

        "registry-mirrors": ["https://86nahrjt666.mirror.aliyuncs.com"]

}

EOF

sudo systemctl daemon-reload

sudo systemctl restart docker

3、然后查看文件

4、Docker启动命令

systemctl start docker

5、关闭docker

systemctl stop docker

7、镜像和容器

1、docker常见命令

命令

说明

文档地址

docker pull

拉取镜像

docker pull

docker push

推送镜像到DockerRegistry

docker push

docker images

查看本地镜像

docker images

docker rmi

删除本地镜像

docker rmi

docker run

创建并运行容器(不能重复创建)

docker run

docker stop

停止指定容器

docker stop

docker start

启动指定容器

docker start

docker restart

重新启动容器

docker restart

docker rm

删除指定容器

docs.docker.com

docker ps

查看容器

docker ps

docker logs

查看容器运行日志

docker logs

docker exec

进入容器

docker exec

docker save

保存镜像到本地压缩文件

docker save

docker load

加载本地压缩文件到镜像

docker load

docker inspect

查看容器详细信息

docker inspect

用一副图来表示这些命令的关系:

        镜像:

        docker image 本质上是一个 read-only 只读文件, 这个文件包含了文件系统、源码、库文件、依赖、工具等一些运行 application 所必须的文件。

​         可以把docker image 理解成一个模板, 可以通过这个模板实例化出来很多容器。

        ​image 里面是一层层文件系统 Union FS。联合文件系统,可以将几层目录挂载到一起,形成一个虚拟文件系统。 每一层文件系统我们叫做一层 layer,联合文件系统可以对每一层文件系统设置三种权限,只读(readonly)、读写(readwrite)和写出(whiteout-able),但是 docker镜像中每一层文件系统都是只读的。 构建镜像的时候,从一个最基本的操作系统开始,每个构建的操作都相当于做一层的修改,增加了一层文件系统。

        容器:

         容器是镜像的运行实体。镜像是静态的只读文件,而容器带有运行时需要的可写文件层,并且容器中的进程属于运行状态。即容器运行着真正的应用进程。容器有初建、运行、停止、暂停和删除五种状态 。

​         容器的本质是主机上运行的一个进程,但是容器有自己独立的命名空间隔离和资源限制。也就是说,在容器内部,无法看到主机上的进程、环境变量、网络等信息,这是容器与直接运行在主机上进程的本质区别。

​         容器是基于镜像创建的可运行实例,并且单独存在,一个镜像可以创建出多个容器。运行容器化环境时,实际上是在容器内部创建该文件系统的读写副本。 这将添加一个容器层,该层允许修改镜像的整个副本 。

2、创建容器

docker run -d --name mysql -p 3306:3306 -e TZ=Asia/Shanghai -e MYSQL_ROOT_PASSWORD=123 msql

Docker run:创建并运行一个容器,-d是容器在后台运行

--name mysql:给容器起个名字,必须唯一

-p 3306:3306:设置端口映射,前面是宿主机端口,后面是容器的端口

-e KEY=VALUE::设置环境变了

mysql:指定运行的镜像名称

3、拉取nginx镜像和创建nginx容器

docker pull nginx 拉取镜像

docker save -o nginx.tar nginx:latest 保存到本地

docker rmi nginx:latest 删除nginx镜像

使用 docker load -i nginx.tar 将上面删除的nginx重新加载回来。 

创建并运行nginx:docker run -d --name nginx -p 80:80 nginx

1、直接访问虚拟机的ip则进入到了nginx的index界面

2、进入容器终端

docker exec -it nginx bash

docker rm mysql2(容器名) 

3、如果命令太长可以给命令起别名

8、docker数据卷

容器是隔离环境,容器内程序的文件、配置、运行时产生的容器都在容器内部,我们要读写容器内的文件非常不方便。大家思考几个问题:

  • 如果要升级MySQL版本,需要销毁旧容器,那么数据岂不是跟着被销毁了?

  • MySQL、Nginx容器运行后,如果我要修改其中的某些配置该怎么办?

  • 我想要让Nginx代理我的静态资源怎么办?

因此,容器提供程序的运行环境,但是程序运行产生的数据、程序运行依赖的配置都应该与容器解耦。 

1、数据卷(volume)是一个虚拟目录,是容器内目录宿主机目录之间映射的桥梁。

通过数据卷实现宿主机和容器文件的双向绑定。

2、数据卷的常用命令

3、举例:nginx容器部署静态资源

以Nginx为例,我们知道Nginx中有两个关键的目录:

  • html:放置一些静态资源

  • conf:放置配置文件

如果我们要让Nginx代理我们的静态资源,最好是放到html目录;如果我们要修改Nginx的配置,最好是找到conf下的nginx.conf文件。

但遗憾的是,容器运行的Nginx所有的文件都在容器内部。所以我们必须利用数据卷将两个目录与宿主机目录关联,方便我们操作。如图:

在上图中:

  • 我们创建了两个数据卷:confhtml

  • Nginx容器内部的conf目录和html目录分别与两个数据卷关联。

  • 而数据卷conf和html分别指向了宿主机的/var/lib/docker/volumes/conf/_data目录和/var/lib/docker/volumes/html/_data目录

这样以来,容器内的confhtml目录就 与宿主机的confhtml目录关联起来,我们称为挂载。此时,我们操作宿主机的/var/lib/docker/volumes/html/_data就是在操作容器内的/usr/share/nginx/html/_data目录。只要我们将静态资源放入宿主机对应目录,就可以被Nginx代理了。

小提示

/var/lib/docker/volumes这个目录就是默认的存放所有容器数据卷的目录,其下再根据数据卷名称创建新目录,格式为/数据卷名/_data

为什么不让容器目录直接指向宿主机目录呢

  • 因为直接指向宿主机目录就与宿主机强耦合了,如果切换了环境,宿主机目录就可能发生改变了。由于容器一旦创建,目录挂载就无法修改,这样容器就无法正常工作了。

  • 但是容器指向数据卷,一个逻辑名称,而数据卷再指向宿主机目录,就不存在强耦合。如果宿主机目录发生改变,只要改变数据卷与宿主机目录之间的映射关系即可。

4、实操截图说明

1、先删除以前的nginx容器,然后在创建容器,直接指定数据卷挂载

2、查看数据卷 docker volume ls

 3、查看对应的数据卷详情 docker volume inspect html

 4、查看 cd /var/lib/docker/volumes/html/_data 目录

使用命令 docker exec -it nginx bash 进入容器内部查看内容 

使用MobaXterm_Personal_23.6工具将静态图片上传到Linux系统里面,直接访问路径成功

http://192.168.79.129/abc.png

由此可见,该目录展示的内容就是容器nginx里面的内容。 

 5、直接修改宿主机里面的文件内容,index.html

修改前:

修改后:

cd /var/lib/docker/volumes/html/_data
vim index.html  修改文件,esc/:wq 保存退出

6、mysql链接远程(6-7很像,建议直接看7)

拉取的镜像是mysql:8.0.20 

1、创建 docker_insert_mysql8.0.20.sh 。注意里面挂载的前面的路径已实际为准
#!/bin/sh
docker run \
-p 3307:3306 \
--name mysql8 \
--privileged=true \
--restart unless-stopped \
-v /docker/mysql8.0.20/mysql:/etc/mysql \
-v /docker/mysql8.0.20/logs:/logs \
-v /docker/mysql8.0.20/data:/var/lib/mysql \
-v /etc/localtime:/etc/localtime \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql:8.0.20

2、cd /docker/mysql8.0.20/mysql/ 到该目录,直接 sh docker_insert_mysql8.0.20.sh

 

链接成功。 

7、mysql挂载数据卷(6-7很像,建议直接看7)

1、先删除容器mysql8 : docker rm -f mysql8

 2、进入root目录,将mysql文件夹里面内容准备好

2.1、conf文件夹:hm.cnf
[client]
default_character_set=utf8mb4
[mysql]
default_character_set=utf8mb4
[mysqld]
character_set_server=utf8mb4
collation_server=utf8mb4_unicode_ci
init_connect='SET NAMES utf8mb4'
2.2、 init文件夹:hmall.sq
2.3、data目录是下面步骤生成的
3、创建并运行新mysql容器,挂载本地目录
docker run -d \
  --name mysql \
  -p 3306:3306 \
  -e TZ=Asia/Shanghai \
  -e MYSQL_ROOT_PASSWORD=123 \
  -v ./mysql/data:/var/lib/mysql \
  -v ./mysql/conf:/etc/mysql/conf.d \
  -v ./mysql/init:/docker-entrypoint-initdb.d \
  mysql
3.1、查看root目录,可以发现~/mysql/data目录已经自动创建好了
3.2、查看MySQL容器内数据 docker exec -it mysql mysql -uroot -p123

3.3、还是使用外部机器连接该数据库

 

 8、总结

 9、镜像结构

10、dockerfile

1、定义

        由于制作镜像的过程中,需要逐层处理和打包,比较复杂,所以Docker就提供了自动打包镜像的功能。我们只需要将打包的过程,每一层要做的事情用固定的语法写下来,交给Docker去执行即可。

而这种记录镜像结构的文件就称为Dockerfile,其对应的语法可以参考官方文档:

Dockerfile reference | Docker Docs

2、dockerfile常用命令

指令

说明

示例

FROM

指定基础镜像

FROM centos:6

ENV

设置环境变量,可在后面指令使用

ENV key value

COPY

拷贝本地文件到镜像的指定目录

COPY ./xx.jar /tmp/app.jar

RUN

执行Linux的shell命令,一般是安装过程的命令

RUN yum install gcc

EXPOSE

指定容器运行时监听的端口,是给镜像使用者看的

EXPOSE 8080

ENTRYPOINT

镜像中应用的启动命令,容器运行时调用

ENTRYPOINT java -jar xx.jar

3、制作镜像实例

3.1、准备文件到 /root/docker-hello-demo/

dockerfile:

# 基础镜像
FROM openjdk:11.0-jre-buster
# 设定时区
ENV TZ=Asia/Shanghai
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
# 拷贝jar包
COPY docker-demo.jar /app.jar
# 入口
ENTRYPOINT ["java", "-jar", "/app.jar"]

 jar下载地址

3.2、进入该目录,制作镜像 docker build -t docker-demo .

命令说明:

  • docker build : 就是构建一个docker镜像

  • -t docker-demo:1.0-t参数是指定镜像的名称(repositorytag

  • . : 最后的点是指构建时Dockerfile所在路径,由于我们进入了demo目录,所以指定的是.代表当前目录,也可以直接指定Dockerfile目录

 3.3、查看镜像 docker images

3.4、运行镜像 docker run -d --name dd -p 8080:8080 docker-demo

docker logs -f dd 查看容器日志

http://192.168.79.129:8080/hello/count  访问地址成功!

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

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

相关文章

利用AI制作桌游卡牌的个人实践

一、引言&#xff1a; ChatGPT ChatGPT是由OpenAI开发的一款基于GPT&#xff08;生成式预训练变换器&#xff09;架构的人工智能语言模型。GPT-4&#xff0c;是ChatGPT中使用的最新版本&#xff0c;具有以下特点&#xff1a; 1. **语言理解与生成能力**&#xff1a;ChatGPT擅…

Linux 一键部署grafana

grafana 前言 Grafana 是一款开源的数据可视化和监控仪表盘工具。它提供了丰富的数据查询、可视化和报警功能,可用于实时监控、数据分析和故障排除等领域。 通过 Grafana,您可以连接到各种不同的数据源,包括时序数据库(如 Prometheus、InfluxDB)和关系型数据库(如 MySQ…

【数据结构初阶】——顺序表

本文由睡觉待开机原创&#xff0c;转载请注明出处。 本内容在csdn网站首发 欢迎各位点赞—评论—收藏 如果存在不足之处请评论留言&#xff0c;共同进步&#xff01; 这里写目录标题 1.数据结构2.顺序表线性表顺序表的结构 3.动态顺序表的实现 1.数据结构 数据结构的概念&…

YOLOv8改进 | Conv篇 | 2024.1月最新成果可变形卷积DCNv4(全网独家首发,附详细教程)

一、本文介绍 本文给大家带来的改进机制是2024-1月的最新成果DCNv4,其是DCNv3的升级版本,效果可以说是在目前的卷积中名列前茅了,同时该卷积具有轻量化的效果!一个DCNv4参数量下降越15Wparameters左右,。它主要通过两个方面对前一版本DCNv3进行改进:首先,它移除了空间聚…

【数据结构与算法】1.数据结构绪论

&#x1f4da;博客主页&#xff1a;爱敲代码的小杨. ✨专栏&#xff1a;《Java SE语法》 ❤️感谢大家点赞&#x1f44d;&#x1f3fb;收藏⭐评论✍&#x1f3fb;&#xff0c;您的三连就是我持续更新的动力❤️ &#x1f64f;小杨水平有限&#xff0c;欢迎各位大佬指点&…

Spring Authorization Server入门 (二十) 实现二维码扫码登录

实现原理 打开网页&#xff0c;发起授权申请/未登录被重定向到登录页面选择二维码登录&#xff0c;页面从后端请求二维码页面渲染二维码图片&#xff0c;并轮询请求&#xff0c;获取二维码的状态事先登录过APP的手机扫描二维码&#xff0c;然后APP请求服务器端的API接口&#…

Mybatis 动态SQL条件查询(注释和XML方式都有)

需求 : 根据用户的输入情况进行条件查询 新建了一个 userInfo2Mapper 接口,然后写下如下代码,声明 selectByCondition 这个方法 package com.example.mybatisdemo.mapper; import com.example.mybatisdemo.model.UserInfo; import org.apache.ibatis.annotations.*; import j…

Unity New Input System 及其系统结构和源码浅析【Unity学习笔记·第十二】

转载请注明出处&#xff1a;&#x1f517;https://blog.csdn.net/weixin_44013533/article/details/132534422 作者&#xff1a;CSDN|Ringleader| 主要参考&#xff1a; 官方文档&#xff1a;Unity官方Input System手册与API官方测试用例&#xff1a;Unity-Technologies/InputS…

2024/1/21周报

文章目录 摘要Abstract文献阅读题目问题与创新方法RNN网络LSTM网络目标变量与外部变量的相关性 实验数据集评估准则参数设置实验结果 深度学习GRU网络结构介绍前向传播过程反向传播过程简单的GRU代码实现 总结 摘要 本周阅读了一篇基于LSTM的深度学习模型用于长期旅游需求预测…

大数据开发之Kafka(概述、快速入门、生产者)

第 1 章&#xff1a;Kafka概述 1.1 定义 Kafka是一个分布式的基于发布/订阅模式的消息队列&#xff0c;主要应用于大数据实时处理领域。 发布/订阅&#xff1a;消息的发布者不会将消息直接发送给特定的订阅者&#xff0c;而是将发布的消息分为不同的类别&#xff0c;订阅者只…

性能测试、分析、优化

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 关注公众号&#xff1a;互联网杂货铺&#xff0c;回复1 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;薪资嘎嘎涨 前言 理论来源于实践又服务于实践&#xff0c;在笔者…

【算法与数据结构】518、LeetCode零钱兑换 II

文章目录 一、题目二、解法三、完整代码 所有的LeetCode题解索引&#xff0c;可以看这篇文章——【算法和数据结构】LeetCode题解。 一、题目 二、解法 思路分析&#xff1a;本题的硬币是无数的&#xff0c;因此本题可以抽象成一个完全背包问题。完全背包和01背包的不同之处在于…

LoadRunner从零开始之接触LoadRunner

LoadRunner 是Mercury Interactive 公司开发的一款成熟的性能测试工具&#xff0c;LoadRuner 作为性能测试的实现者&#xff0c;涉及了性能测试流程、性能测试技术和软件 体系架构等众多方面的知识点&#xff0c;可以说&#xff0c;学习LoadRuner 是理解和学习性能测试 的非常好…

常用设计模式(工厂方法,抽象工厂,责任链,装饰器模式)

前言 有关设计模式的其他常用模式请参考 单例模式的实现 常见的设计模式(模板与方法&#xff0c;观察者模式&#xff0c;策略模式) 工程方法 定义 定义一个用于创建对象的接口&#xff0c;让子类决定实例化哪一个类。Factory Method使得一个类的实例化延迟到子类。 ——《设…

Spring Boot 优雅实现统一数据返回格式+统一异常处理+统一日志处理

在我们的项目开发中&#xff0c;我们都会对数据返回格式进行统一的处理&#xff0c;这样可以方便前端人员取数据&#xff0c;当然除了正常流程的数据返回格式需要统一以外&#xff0c;我们也需要对异常的情况进行统一的处理&#xff0c;以及项目必备的日志。 1. 统一返回格式 …

【小沐学GIS】基于C++绘制三维太阳系SolarSystem(OpenGL、glfw、glut)

&#x1f37a;三维数字地球系列相关文章如下&#x1f37a;&#xff1a;1【小沐学GIS】基于C绘制三维数字地球Earth&#xff08;OpenGL、glfw、glut&#xff09;第一期2【小沐学GIS】基于C绘制三维数字地球Earth&#xff08;OpenGL、glfw、glut&#xff09;第二期3【小沐学GIS】…

深度学习基础之数据操作

深度学习中最常用的数据是张量&#xff0c;对张量进行操作是进行深度学习的基础。以下是对张量进行的一些操作&#xff1a; 首先我们需要先导入相关的张量库torch。 元素构造&#xff08;初始化&#xff09; 使用arange创造一个行向量&#xff0c;也就是0轴&#xff08;0维&a…

LabVIEW 2023下载安装教程,附安装包和工具,免费使用,无套路获取

前言 LabVIEW是一种程序开发环境&#xff0c;提供一种图形化编程方法&#xff0c;可可视化应用程序的各个方面&#xff0c;包括硬件配置、测量数据和调试&#xff0c;同时可以通过FPGA数学和分析选板中的NI浮点库链接访问浮点运算功能库&#xff0c;LabVIEW软件是NI设计平台的…

西圣H1头戴式耳机发布,不止音质惊艳,更有舒适听音体验

近日&#xff0c;深耕智能声学领域多年的 xisem西圣品牌‏‏发布——‏西圣H1头戴式主动降噪蓝牙耳机正式迎来首销。从各个方面来看&#xff0c;这款头戴式耳机展现出了极具颠覆性的创新&#xff0c;不仅在音质和降噪性能上表现出色&#xff0c;更重要的是采用了更加轻巧的佩戴…

使用记事本修复DBC文件问题V3.0

要麻了&#xff0c;竟然写到3.0了。 有个信号解析不出来&#xff0c;同一条报文的其他信号可以正确解析&#xff0c;打开DBC检查&#xff0c;位置长度都是正确的&#xff0c;死活解析不出来。 打开记事本 发现他居然在信号后面加了个回车&#xff0c;就产生了上面这种诡异的情…