基于虚拟机ubuntu的linux和shell脚本的学习,以及SSH远程登陆实战

简介

特点

是一款操作系统,跟windows,macos一样,有下面的特点

简单和高效,一切皆文件,所有配置都通过修改文件解决,不需要繁琐的权限和设置

权限高,把所有细节都交给用户,可完全自定义

安全,所有程序只有自己执行才会启动

分类

1、debian系主要有Debian,Ubuntu,Mint等;

2、redhat系主要有RedHat,Fedora,CentOs等,

3、其它有Slackware,Gentoo,Arch linux,LFS,SUSE等。

4、如果开发用,推荐redhat系,业内公司的服务器多用centos,考虑到平时使用,那么就选择fedora,可以选择最新的发行版。

5、如果简单用加开发,可以选择debian系,推ubuntu,mint。

6、如果是技术狂型,那么就推荐Gentoo,Arch linux,LFS,Slackware等

下面教程以ubuntu为例

安装

在阿里云或清华镜像网站下载到iso,学习时最好使用desktop版

在vmware直接创建典型,跟着操作

安装时最好选英文,一定要记住设置的密码,如000000,防止时间太久忘记,忘记了也可以去搜索对应解决方法

shell&terminal

shell是一种应用程序,帮助用户和操作系统交互

terminal是一个交互界面,用于获取输入,交给shell执行,将输出展示在终端

而应用程序按是否有图形化界面分两种:

CLI(Command Line Interface)和GUI(Graphical User Interface)

即命令行和图形界面

Shell是一类程序,有CLI形式(如sh,bash,zsh;cmd,powershell等),也可以有GUI形式的(如Windows资源管理器explorer.exe等)

文件系统

目录结构

linux哲学 : 一切皆文件

执行ls / 查看根目录得到下面结果

ls.png

按树状目录

directiry.jpg

目录按找功能大致分为

通用数据

/bin Binaries,系统的二进制文件,存放着常用的命令,二进制文件由操作系统直接执行
/lib Library,存放动态链接库,类似windows中的dll
/var variable,习惯将那些经常被修改的目录放在这个目录下。包括各种日志文件。
/srv server, 该目录存放一些服务启动之后需要提取的数据
/usr unix shared resources,共享资源,大部分程序和文件都存在这里面,常用如下
/usr/src  /usr/bin /usr/sbin 分别是源码,普通用户的二进制文件,超级用户的二进制文件
/opt optional,可选目录,默认为空
/tmp temporary,存放一些临时文件
/lost+found,当系统非法关机后,这里就存放了一些文件

用户数据

/home 普通用户
/root 超级用户

操作系统

/boot linux启动时的一些连接文件以及镜像文件
/dev device,存放Linux 的外部设备,在Linux中访问设备的方式和访问文件的方式是相同的
/etc 存放所有的系统管理所需要的配置文件和子目录
/media 系统自动识别一些设备,例如U盘,光驱等等.系统会把识别的设备挂载到这个目录下
/proc Processes,是一种伪文件系统,存储的是当前内核运行状态,它是系统内存的映射,并不在硬盘上
/run run是一个临时文件系统,存储系统启动以来的信息.当系统重启时,这个目录下的文件会被删掉或清除
/mnt mount,系统提供该目录是为了让用户临时挂载别的文件系统
/selinux Redhat/CentOS特有的安全功能规则的目录

文件操作

所有指令可以通过man command的形式查看用法(man:manual,命令的手册页面)

目录

目录分类

绝对目录: 从/开始,目录的全名

相对目录: 从当前开始.表示当前目录,..表示父级目录

特殊目录: ~表示当前用户目录

打印

pwd (print working directory),即打印当前目录

ls (list directory contents).列出目录内容

可选参数
-a 显示所有文件及目录(“.”开头的隐藏文件也会列出),-A可以不列出`.和..`
-l 除文件名称外,亦将文件型态、权限、拥有者、文件大小等资讯详细列出
-t 将文件依建立时间之先后次序列出
-F 在列出的文件名称后加一符号;例如可执行档则加 "*", 目录则加 "/"
-R 若目录下有文件,则以下之文件亦皆依序列出

多个参数可以连写,如ls -al /
切换
cd [destination] 可以用tab补全目录
管理

创建目录 mkdir [-p] directory_name 如果创建多级目录,可用-p自动创建缺失的父目录

删除目录 rmdir [-p] directory_name ,只能删除空目录,要删除文件要用rm命令

文件

创建
touch file_name 
复制和移动
cp [options] source destination
options
    -i 在覆盖已有文件之前询问是否覆盖
    -r 若给出的源文件是一个目录文件,将复制该目录下所有的子目录和文件
    
mv [options] source destination
options
    -i 执行覆盖前询问
    -n 不执行覆盖
    -u 当源文件比目标文件修改时间更晚或目标不存在时,才执行移动
删除
rm [options] [file or directory]
options
    -i 删除前询问
    -r 递归地删除所有子目录和文件
    -f 强制删除,不给出任何提示
    -v 显示详细的删除过程
shell没有回收站,rm -rf谨慎使用
显示
cat [options] file...
options
    -n 加上行号
    -s 将连续两行以上的空白行替换为一行
如果file不止一个文件,则会将它们连接起来
过滤显示
grep [options] [想要匹配的正则表达式] [文件或目录...]
options
    -A [n] 除了显示匹配的那一行之外,还显示该行之后的n行(after)
    -B [n] 除了显示匹配的那一行之外,还显示该行之前的n行(before)
    -C [n] 除了显示匹配的那一行之外,还显示该行之前和之后的n行(contest)
    -c 计算总匹配的行数
    -r 查找目录而非文件时,必须加上这一参数,否则会报错
    -e 使用正则表达式进行匹配,默认也是这样
    -E 使用拓展的正则表达式进行匹配
    -i 忽略字符大小写的差别
    -l 列出含有匹配成功内容的文件名
    -n 在显示匹配的行之前,标示出该行的行号
    -v 显示不包含匹配表达式的所有行,相当于反向选择

正则表达式用单引号括起来

vim

三种模式

命令模式(command),进入时的默认模式,按下esc进入

输入模式(insert),按下i进入

底线命令模式(last line): 按下:进入,常用q和wq(退出和保存并退出)

命令模式

  • h i j k 左下上右移动光标
  • i – 切换到输入模式,在光标当前位置开始输入文本。
  • : – 切换到底线命令模式,以在最底一行输入命令。
  • x – 删除当前光标所在处的字符。
  • o:在当前行的下方插入一个新行,并进入插入模式。
  • O – 在当前行的上方插入一个新行,并进入插入模式。
  • dd – 删除当前行。
  • yy – 复制当前行。
  • p(小写) – 粘贴剪贴板内容到光标下方。
  • P(大写)-- 粘贴剪贴板内容到光标上方。
  • u – 撤销上一次操作。
  • Ctrl + r – 重做上一次撤销的操作。
  • :w – 保存文件。
  • :q – 退出 Vim 编辑器。

用户管理

用GID(group)和UID(user)来区分, 组用来表示拥有相同权限的一类用户,通过root用户来管理

root

su,switch user

sudo superuserdo

切换到root模式就不需要每次都sudo了,方法如下

  1. 设置root密码 sudo passwd root
  2. 切换用户 su root

普通用户

下面都需要切换到root用户才能执行

新建

sudo useradd [options] username
options
    -m 创建用户的主目录
    -d 指定用户的主目录(如果不使用默认的话)
    -g 指定用户登录组的GID或组名
    -p 指定默认密码
    -s 指定用户登录的shell

删除

sudo userdel [options] username
options
	-r 同时删除用户主目录

修改

sudo usermod [options] username

跟新建一样,如下,将eesast的默认shell从sh修改成了bash

usermod -s /bin/bash eesast

查看

可以通过查看/etc/passwd文件来查看当前系统中的全部用户和属性

cat /etc/passwd

每行用户信息都以 “:” 作为分隔符,划分为7个字段,每个字段所表示的含义如下:用户名:密码(被隐藏):UID:GID:备注(在创建用户时或修改用户时添加):主目录:默认Shell

eesast:x:1001:1001::/home/eesast:/bin/bash

密码

passwd [options] 修改自己的密码,需要知道自己的现有密码
sudo passwd [options] username 修改别人的密码,需要超级用户权限

用户组

一个组中可以有多个用户,一个用户也可以在多个组中

跟用户操作一样

新建用户组: groupadd
修改用户组: groupmod
删除用户组: groupdel
切换用户组: newgrp
查看用户所属的组: groups username

用户权限

即用户组对该目录下的文件具有什么条件

查看

ll (约等于 ls -al)ls -l

得到若干条

drwxr-xr-x 3 root root 4096 May 18 2022 ../

第一段的 drwxr-xr-x 表示文件类型及权限:

第一位表示类型 d:目录 -:文件 l:链接

后面每三位为一组,分别表示属主权限,属组权限,其他用户权限

r,w,x代表拥有read,write,excuate权限,-代表没有

第二段代表有3个硬链接指向该文件对应的节点

第三段表示文件属主为root,第四端表示文件属组为root

第五段表示文件大小为4096,第六段表示修改日期和文件名

修改

修改文件权限

chmod : change mode,修改文件的权限,语法如下

chmod [–R] [u/g/o/a][+/-/=][r/w/x] [file]
	-R 表示递归修改
	 u:user | g:group | o:owner | a:all
	 + 增加 - 减少 = 设定
	 r:读 | w:写 | x:执行

例子如下

为所有用户赋予1.txt的执行权限
chmod a+x 1.txt
为属主赋予读、写、执行权限,删除属组和其他用户的执行权限
chmod u=rwx,g-x,o-x 1.txt

因为选项有限,所以可以用位来表示,即用数字表示权限

上面每个选项都有3个独立的选项,都可以用三位来表示

例如,为所有用户赋予所有权限,用编码方法表示为:

chmod 777 1.txt

修改文件属主/组

chown : change owner

chgrp : change group

sudo chown [–R] [owner] [file]
sudo chown [-R] [owner]:[group] [file]

系统管理

磁盘管理

常用三个命令

  • df (disk free):列出文件系统的整体磁盘使用量
  • du (disk used):列出文件或目录的磁盘空间使用量
  • fdisk :用于磁盘分区

查看使用量

df

df [options] [file or directory path]
options
    -h 以人们较易阅读的 GB, MB, KB 等格式自行显示
    -a 列出所有的文件系统
    -T 显示文件系统格式
df命令会把file or directory path所在的文件系统的磁盘用量展示出来

du

du [options] [file or directory path]
options
    -h 以人们较易读的容量格式 (G/M) 显示
    -a 列出所有的文件与目录容量,因为不指定文件时默认仅统计目录的容量
    -s 列出总量,而不列出每个目录占用容量
du命令会把file or directory path自身占用的磁盘空间大小展示出来,不指定时默认为当前目录

分区

sudo fdisk [option] [device name]
option -l 可以把整个系统内能够搜寻到的装置的分区均列出来

格式化

mkfs [option] [device name]
option: -t [filesystem] 将指定的磁盘格式化为指定文件系统格式

磁盘挂载与卸载

mount [device name] [directory] # 将文件系统挂载到某个目录下
umount [device name or directory] # 将某个文件系统或者某个目录挂载的文件系统卸载

系统管理

查看CPU使用

会出现实时更新的列表

top

查看进程

ps : process status

ps [options]
options 
    -a 列出所有的进程(包括其他用户的)
    -u 显示较详细的信息
    -x 也显示没有控制终端的进程

终止进程

kill指令用于向进程发送信号,最终如何响应由该进程决定。一般用作“杀死”一个进程,但无法“杀死”系
统进程和守护进程。

kill -l # 列出全部可以发送的信号名称和编号

kill [options] [PID]
options 
    -s [要发送的信号名称或编号] # 如不指定该项参数,默认发SIGTERM(15),一般可终止进程
    -u [用户名] 向指定用户的所有进程发送信号

软件管理

在不同的linux发行版中,有不同的包管理工具,常见下面两个

debian系列的apt (Advanced Package Tool)

redhat系列的yum(Yellowdog Updater, Modified)

拿apt举例

安装

sudo apt install [package name...] # 可以一次性安装多个软件包

卸载

sudo apt remove [package name] # 卸载软件包
sudo apt autoremove # 清理不再使用的依赖和库文件

更新

sudo apt update # 列出所有可更新的软件清单
sudo apt upgrade # 升级全部可升级的软件包
sudo apt upgrade [package name...] # 指定升级软件包
sudo apt full-upgrade # 升级全部可升级的软件包,并且在升级前将旧的包先卸载

查询

apt list --installed # 列出所有已安装的软件包
apt list --all-versions # 列出所有已安装的软件包的版本信息
sudo apt show [package name] # 显示指定软件包的具体信息
sudo apt search [keyword] # 查找可供安装的软件包

shell

查找文件

find [path] [options]
path是要查找的目录路径,可以是多个,未指定则默认为当前目录
options
    -name [name] 按文件名查找,支持通配符,-iname会忽略大小写
    -type [type] 按文件类型查找,f(普通文件),d(目录)-path [p] 路径符合 p 的文件
    -amin [-n] 在过去 n 分钟内被读取过的文件
    -size [+nM] 大小大于 n M的文件

重定向

输入

command < file #将指定的文件内容作为命令的输入
command << string #从标准输入设备(键盘)中读入,直到遇到string才停止

输出

command  > file 将命令执行的标准输出结果(stdout)重定向输出到指定的文件中,会覆盖文件
command 2> file 同上,错误输出结果(stderr)重定向到此
command &> file 将二者同时重定向
command 2>&1 	>&表示将前面的输出2重定向到后面的文件描述符1中,这里 2>&1,即stderr重定向到stdout

command >>file 同理,会追加文件

管道

用|,将多个命令连接到一起,将前一个命令的输出作为后一个命令的输入

例如

ls -l | grep "txt"

清空

终端输出太多了,清空一下

clear

shell脚本

在shell中运行的脚本程序,用分号和换行来分割不同命令

变量

变量名和等号之间不能有空格

单独

a=1 	#定义
unset a	#删除
a=2		#修改,通过覆盖定义实现
echo $a	#显示

数组

array=(value0 value1 value2 value3)
echo ${array[0]}
echo ${array[@]} #遍历

控制

分支

if condition1 then
command1
elif condition2 then
command2
else
commandN
fi

循环

for var in item1 item2 ... itemN
do
command1
command2
...
commandN
done
for (( i = 1; i <= 10; i++ )) # 需要使用双括号,变量定义可以有空格
while condition
do
command
done

函数

function test(){
    echo "参数1: ${1} !" # 通过${n}来获取传入函数的第n个参数
    echo "参数10: ${10} !" # 双引号括起来的字符串中可以引用变量
    n=$((${1}+${10}))
    return $n # 如果不加return,则返回值为最后一条命令的结果
}

test 1 2 3 4 5 6 7 8 9 10 # 调用函数时依序传递参数
echo $? # 可以通过变量$?来获取函数的返回值或者上一条命令的结果

运行

./test.sh # 注意不能写成test.sh,否则会去环境变量中查找

shell环境变量

环境变量是存储有关 shell 的工作环境的数据,以便程序或 shell 中运行的脚能够访问到它们

系统会创建好一些环境变量,我们在安装新程序等操作时也要留意是否需要设置环境变量,否则会出现“command not found”的错误

查看

env # 查看全部全局变量
printenv HOME # 查看个别全局变量(HOME)
echo $HOME # 查看个别全局变量(HOME)

常用环境变量

  • HOME :当前用户的主目录
  • PATH : shell 查找命令的目录列表,由冒号分隔
  • PWD :当前工作目录

设置

临时设置

variable="test"
export variable # 导出环境变量
unset variable # 删除环境变量

长期设置

export PATH=/usr/local/src/mongodb/bin:$PATH

SSH

secure shell,远程登陆会话常用的安全协议,数据进行压缩,加密chuan’shu

实战

确认虚拟机ip地址

接下来演示主机windows连接到虚拟机ubuntu上的

首先是用ifconfig确认虚拟机的ip地址,需要安装net-tools

然后输出的ens33下的inet就是虚拟机的内网ip地址了

配置虚拟机SSH

  • 安装openssh-client:sudo apt install openssh-client
  • 安装openssh-server:sudo apt install openssh-server
  • 启动ssh-server:sudo /etc/init.d/ssh start
  • 确认ssh-server工作正常:netstat -tpl
    如果你看到了有ssh的字样,就说明ssh正在运行

主机连接虚拟机

打开cmd输入

ssh username@192.168.x.x

得到

The authenticity of host '192.168.x.x (192.168.x.x)' can't be established.
ED25519 key fingerprint is SHA256:4MTn1ZNTkGQoN8ZEERWfqdhoTV0yuLnLhknyDtXGHfY.
This key is not known by any other names
Are you sure you want to continue connecting (yes/no/[fingerprint])? 

然后输入yes即可连接

漫画解释

看完前面linux的各种知识,可以来看看来自turnoff的漫画,来巩固一下

结构

LinuxStructure.jpg

解释

LinuxExplain.jpg

POSIX

特点

简介 : POSIX即Portable Operating System Interface for UNIX”,由IEEE提出的一组标准,用于定义UNIX操作系统的接口。

产生原因 : 不同的操作系统,会提供不同的接口函数来实现系统调用,导致跨平台的难度增大

功能全面 : 而POSIX的标准涵盖了各种操作系统功能,包括文件系统、进程控制、系统调用等。

多平台,多语言 : 虽然POSIX最初是为UNIX设计的,但许多其他操作系统,包括Linux、macOS等,也采纳了POSIX标准或其变体。POSIX支持多种语言,但时由UNIX定义的,所以C语言是其正统血脉

功能

  1. 文件系统操作: 包括文件和目录的创建、删除、读取、写入、定位和权限管理等。
  2. 进程控制: 包括进程的创建、终止、等待、信号处理以及进程间通信等。
  3. 用户和组管理: 包括用户和组的创建、删除、以及权限管理等。
  4. 系统调用: 提供了直接访问操作系统核心功能的接口,例如内存分配、文件 I/O、进程管理等。
  5. 信号处理: 允许程序捕捉和处理来自操作系统的信号,以便响应异步事件。
  6. 线程控制: 包括线程的创建、同步、销毁等。
  7. 网络操作: 包括套接字编程、网络通信等。
  8. 时间和定时器: 包括获取系统时间、定时器的设置等。
  9. 共享内存: 允许多个进程共享一块内存区域。
  10. 互斥锁和条件变量: 用于多线程编程中的同步和互斥。

日常使用

连接网络

有的时候ubuntu安装后却没有网络,可能是因为电脑网络没有共享

虚拟机会虚拟几个专用网络连接来模拟不同的网络,我们只要把主机网络与这些虚拟专用网络共享就好

需要两步: 设置虚拟机的专用网络,设置电脑的共享

虚拟机->属性->网络适配器->自定义->VMnet8->确定

电脑->找到网络适配器设置->打开电脑连接的网络的属性->共享->勾选允许其他用户通过此计算机的internet连接来连接->选择家庭网络连接VMnet8->确定

这个时候打开firefox搜索应该就可以了

安装中文输入法

直接浏览器搜搜狗输入法,有教程,跟着教程走就行了

ctrl+space切换输入法

共享剪切板

只需要安装VMtools即可解决

首先,把所有硬盘链接方式改成使用物理驱动器

  1. 连接 : 然后启动虚拟机,工具栏->虚拟机->安装VMtools->然后会自动挂载安装文件的,看文件夹会多一个VMwate tools
  2. 右键单击类似于 VMwareTools.x.x.x-xxxx.tar.gz 复制到桌面后再提取到桌面,然后执行下面命令
su root
cd  Desktop/vmware-tools-distrib
./vmware-install.pl #第一个yes后全部默认
reboot

如果安装后无法共享剪切板

apt-get update
sudo apt-get install open-vm-tools-desktop

替换镜像源

默认的源在国内访问不到或者速度极慢,所以我们替换成清华源或阿里源

注意替换需要根据找到对应自己版本的源,即更换sources.txt的内容

首先浏览器搜索ubuntu 清华源 清华镜像 然后根据自己的版本,选择对应的源复制

然后就是如下方更换源,先备份,再修改

cd /etc/apt/
cp sources.list sources.list_bak
vi sources.list

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

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

相关文章

出海合规云安全,AWS Landing Zone解决方案建立安全着陆区

在出海的大环境中&#xff0c;企业数字化转型的趋势之一就是上云。然而&#xff0c;上云也带来了新的挑战&#xff0c;特别是对企业的 IT 建设和管理提出了更高的要求。为了构建一个安全合规的云上信息系统环境&#xff0c;满足企业中不同用户的快速增长、资源访问可控、成本可…

Selenium在vue框架下求生存

vue框架下面&#xff0c;没有id、没有name&#xff0c;vue帮开发做了很多脏活累活&#xff0c;却委屈了写页面自动化测试的人&#xff08;当然&#xff0c;也给爬信息的也带来了一定的难处&#xff09;。这里只能靠总结&#xff0c;用一些歪门邪道&#xff1a; 一、跟开发商量…

三台CentOS7.6虚拟机搭建Hadoop完全分布式集群(二)

这个是笔者大学时期的大数据课程使用三台CentOS7.6虚拟机搭建完全分布式集群的案例&#xff0c;已成功搭建完全分布式集群&#xff0c;并测试跑实例。 6.安装JDK 以下操作现在master上操作&#xff0c;然后远程复制到slave01、slave02即可。 6.1 将压缩包发送到master节点机…

【连接池】-从源码到适配(下),使用dynamic-datasource导致连接池没生效(升级版本)

写在前面 书接上文&#xff0c;连接池没生效&#xff0c;启用了一个什么默认的连接池。具体是什么&#xff0c;一起来看看源码吧。 目录 写在前面一、问题描述二、本地调试三、升级dynamic-datasource四、新的问题&#xff08;一&#xff09;数据源初始化问题&#xff08;二&am…

【nodejs】前后端身份认证

前后端身份认证 一、web开发模式 服务器渲染&#xff0c;前后端分离。 不同开发模式下的身份认证&#xff1a; 服务端渲染推荐使用Session认证机制前后端分离推荐使用JWT认证机制 二、session认证机制 1.HTTP协议的无状态性 了解HTTP协议的无状态性是进一步学习Session认…

Vue2+element-ui 实现select选择器结合Tree树形控件实现下拉树效果

效果&#xff1a; DOM部分 &#xff1a; // 设置el-option隐藏的下拉选项&#xff0c;选项显示的是汉字label&#xff0c;值是value // 如果不设置一个下拉选项&#xff0c;下面的树形组件将无法正常使用 <el-form-item label"报警区域" prop"monitorId"…

Spring Boot 基于Redisson实现注解式分布式锁

依赖版本 JDK 17 Spring Boot 3.2.0 Redisson 3.25.0 源码地址&#xff1a;Gitee 导入依赖 <properties><redisson.version>3.25.0</redisson.version> </properties><dependencies><dependency><groupId>org.projectlombok</…

Linux 安装Jupyter notebook 并开启远程访问

文章目录 安装Python安装pip安装Jupyter启动Jupyter Notebook1. 生成配置文件2. 创建密码3. 修改jupyter notebook的配置文件4. 启动jupyter notebook5. 远程访问jupyter notebook 安装Python 确保你的系统上已经安装了Python。大多数Linux发行版都预装了Python。你可以在终端…

QT/C++ 远程数据采集上位机+服务器

一、项目介绍&#xff1a; 远程数据采集与传输 课题要求:编写个基于TCP的网络数据获取与传输的应用程序; 该程序具备以下功能: 1)本地端程序够通过串口与下位机(单片机)进行通信&#xff0c;实现数据采集任务 2)本地端程序能将所获取下位机数据进行保存(如csv文本格式等); 3…

[ 云计算 | AWS ] 对比分析:Amazon SNS 与 SQS 消息服务的异同与选择

文章目录 一、前言二、Amazon SNS 服务&#xff08;Amazon Simple Notification Service&#xff09;三、Amazon SQS 服务&#xff08;Amazon Simple Queue Service&#xff09;四、SNS 与 SQS 的区别&#xff08;本文重点&#xff09;4.1 基于推送和轮询区别4.2 消费者数量对应…

【教学类-43-04】20231229 N宫格数独4.0(n=2,4,6,8) (ChatGPT AI对话大师生成 回溯算法)

作品展示&#xff1a; 背景需求&#xff1a; 幼儿表示自己适合做5宫格 第一次AI生成九宫格数独python代码 【教学类-43-03】20231229 N宫格数独3.0&#xff08;n1、2、3、4、6、8、9&#xff09; &#xff08;ChatGPT AI对话大师生成&#xff09;-CSDN博客文章浏览阅读162次&…

Python武器库开发-武器库篇之上传本地仓库到Git(三十八)

武器库篇之上传本地仓库到Git(三十八) 当我们在Git中创建远程仓库和进行了SSH key免密登陆之后&#xff0c;我们点击 Your respositories 可以查看我们所创建的远程仓库&#xff0c;如图所示&#xff1a; 如果我们需要将本地的仓库上传到Git&#xff0c;首先我们需要建立一个本…

nodeJS搭建免费代理IP池爬取贴吧图片实战

之前用python写过爬虫&#xff0c;这次想试试nodeJS爬虫爬取贴吧图片&#xff0c;话不多说代码如下&#xff0c;爬取制定吧的前十页所有帖子里的图片 爬取贴吧图片脚本 你得提前创建一个images文件夹 const axios require("axios"); const cheerio require("…

Spark应用程序的结构与驱动程序

Apache Spark是一个强大的分布式计算框架&#xff0c;用于处理大规模数据。了解Spark应用程序的结构和驱动程序是构建高效应用的关键。本文将深入探讨Spark应用程序的组成部分&#xff0c;以及如何编写一个Spark驱动程序来处理数据和执行计算。 Spark应用程序的结构 Spark应用…

vue3项目使用pako库解压后端返回zip数据

文章目录 前言一、pako 介绍一些特点和功能&#xff1a;简单示例 二、vue3 实战示例1.安装后引入库安装:引用用自定义hooks 抽取共用逻辑部署小插曲 前言 外部接口返回一个图片数据是经过zip压缩的&#xff0c;前端需要把这个数据处理成可以显示的图片。大概思路&#xff1a;z…

LTPI协议的理解——2、LTPI实现的底层架构

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 LTPI协议的理解——2、LTPI实现的底层架构 前言一、体系结构三、实现细节四、物理接口信号传输方法总结 前言 前面讲了LTPI的定义和大概结构&#xff0c;接下来继续理解LTPI…

封装uniapp签字板

新开发的业务涉及到签字功能&#xff0c;由于是动态的表单&#xff0c;无法确定它会出现在哪里&#xff0c;不得已封装模块。 其中涉及到一个难点就是this的指向性问题&#xff0c; 第二个是微信小程序写法&#xff0c; 我这个写法里用了u-view的写法&#xff0c;可以自己修改组…

PiflowX组件-ReadFromKafka

ReadFromKafka组件 组件说明 从kafka中读取数据。 计算引擎 flink 有界性 Unbounded 组件分组 kafka 端口 Inport&#xff1a;默认端口 outport&#xff1a;默认端口 组件属性 名称展示名称默认值允许值是否必填描述例子kafka_hostKAFKA_HOST“”无是逗号分隔的Ka…

Zookeeper之手写一个分布式锁

前言 我之前写了一篇快速上手ZK的文章&#xff1a;https://blog.csdn.net/qq_38974073/article/details/135293106 本篇最要是进一步加深学习ZK&#xff0c;算是一次简单的实践&#xff0c;巩固学习成果。 设计一个分布式锁 对锁的基本要求 可重入&#xff1a;允许同一个应…

QT上位机开发(掌握一点c++基础)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 c是c语言的补充和扩展&#xff0c;本身的语法构成也是在一直迭代中。相信很多同学上大学读书的时候&#xff0c;或多或少对c语言有所了解&#xff…